mirror of
https://github.com/fluencelabs/wasm-bindgen
synced 2025-03-19 19:50:52 +00:00
* Try to enable all webidls * Separate out unavailable webidl files by reason. * Create record of fully tested WebIDL files * Update notes to reflect new situation with web-idl * Make a blank ident fail, disable the necessary widls. It turns out that all the blank idents came from blank enum variants, which is allowed in webidl apparently.
66 lines
2.2 KiB
Plaintext
Vendored
66 lines
2.2 KiB
Plaintext
Vendored
/* -*- 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 RTCIdentityProviderOptions options);
|
|
/* 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,
|
|
RTCIdentityProviderOptions options);
|
|
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;
|
|
};
|
|
|
|
dictionary RTCIdentityProviderOptions {
|
|
DOMString protocol = "default";
|
|
DOMString usernameHint;
|
|
DOMString peerIdentity;
|
|
};
|
|
|