blob: fd1b44b09291605406e447b11f70ff7aa6b86f71 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
/* -*- Mode: IDL; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
* You can obtain one at http://mozilla.org/MPL/2.0/.
*
* http://w3c.github.io/webrtc-pc/ (with https://github.com/w3c/webrtc-pc/pull/178)
*/
[NoInterfaceObject]
interface RTCIdentityProviderRegistrar {
void register(RTCIdentityProvider idp);
/* Whether an IdP was passed to register() to chrome code. */
[ChromeOnly]
readonly attribute boolean hasIdp;
/* The following two chrome-only functions forward to the corresponding
* function on the registered IdP. This is necessary because the
* JS-implemented WebIDL can't see these functions on `idp` above, chrome JS
* gets an Xray onto the content code that suppresses functions, see
* https://developer.mozilla.org/en-US/docs/Xray_vision#Xrays_for_JavaScript_objects
*/
/* Forward to idp.generateAssertion() */
[ChromeOnly, Throws]
Promise<RTCIdentityAssertionResult>
generateAssertion(DOMString contents, DOMString origin,
optional DOMString usernameHint);
/* Forward to idp.validateAssertion() */
[ChromeOnly, Throws]
Promise<RTCIdentityValidationResult>
validateAssertion(DOMString assertion, DOMString origin);
};
dictionary RTCIdentityProvider {
required GenerateAssertionCallback generateAssertion;
required ValidateAssertionCallback validateAssertion;
};
callback GenerateAssertionCallback =
Promise<RTCIdentityAssertionResult>
(DOMString contents, DOMString origin, optional DOMString usernameHint);
callback ValidateAssertionCallback =
Promise<RTCIdentityValidationResult> (DOMString assertion, DOMString origin);
dictionary RTCIdentityAssertionResult {
required RTCIdentityProviderDetails idp;
required DOMString assertion;
};
dictionary RTCIdentityProviderDetails {
required DOMString domain;
DOMString protocol = "default";
};
dictionary RTCIdentityValidationResult {
required DOMString identity;
required DOMString contents;
};
|