/* * Copyright 2017 The OpenYOLO for Web Authors. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import {Credential, CredentialHintOptions} from '../protocol/data'; import {OpenYoloError} from '../protocol/errors'; import {hintMessage, RPC_MESSAGE_TYPES} from '../protocol/rpc_messages'; import {BaseRequest} from './base_request'; const TIMEOUT_MS = 5000; /** * Handles the get hint request, by displaying the IFrame or not to let * the user selects a hint, if any is available. */ export class HintRequest extends BaseRequest { /** * Starts the Hint Request flow. */ dispatch(options: CredentialHintOptions): Promise { this.registerHandler( RPC_MESSAGE_TYPES.credential, (credential: Credential) => this.handleResult(credential)); this.registerHandler(RPC_MESSAGE_TYPES.none, () => this.handleResult(null)); this.setAndRegisterTimeout(() => { this.reject(OpenYoloError.requestTimeout()); this.dispose(); }, TIMEOUT_MS); this.debugLog(`Sending hint request`); this.channel.send(hintMessage(this.id, options)); return this.getPromise(); } /** * Handles the initial response from a hint request. */ private handleResult(credential: Credential|null): void { this.debugLog(`Hint request complete`); this.clearTimeouts(); this.resolve(credential); this.dispose(); } }