OLD | NEW |
(Empty) | |
| 1 // Copyright (c) 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. |
| 4 |
| 5 /** |
| 6 * @fileoverview U2F gnubbyd background page |
| 7 */ |
| 8 |
| 9 'use strict'; |
| 10 |
| 11 // Singleton tracking available devices. |
| 12 var gnubbies = new Gnubbies(); |
| 13 llUsbGnubby.register(gnubbies); |
| 14 // Only include HID support if it's available in this browser. |
| 15 if (chrome.hid) { |
| 16 llHidGnubby.register(gnubbies); |
| 17 } |
| 18 |
| 19 var GNUBBY_FACTORY = new UsbGnubbyFactory(gnubbies); |
| 20 var SIGN_HELPER_FACTORY = new UsbSignHelperFactory(GNUBBY_FACTORY); |
| 21 var ENROLL_HELPER_FACTORY = new UsbEnrollHelperFactory(GNUBBY_FACTORY); |
| 22 |
| 23 /** |
| 24 * @param {boolean} toleratesMultipleResponses Whether the web page can handle |
| 25 * multiple responses given to its sendResponse callback. |
| 26 * @param {Object} request |
| 27 * @param {MessageSender} sender |
| 28 * @param {Function} sendResponse |
| 29 * @return {Closeable} |
| 30 */ |
| 31 function handleWebPageRequest(toleratesMultipleResponses, request, sender, |
| 32 sendResponse) { |
| 33 var enforceAppIdValid = true; |
| 34 switch (request.type) { |
| 35 case GnubbyMsgTypes.ENROLL_WEB_REQUEST: |
| 36 return handleEnrollRequest(ENROLL_HELPER_FACTORY, sender, request, |
| 37 enforceAppIdValid, sendResponse, toleratesMultipleResponses); |
| 38 |
| 39 case GnubbyMsgTypes.SIGN_WEB_REQUEST: |
| 40 return handleSignRequest(SIGN_HELPER_FACTORY, sender, request, |
| 41 enforceAppIdValid, sendResponse, toleratesMultipleResponses); |
| 42 |
| 43 default: |
| 44 var response = formatWebPageResponse( |
| 45 GnubbyMsgTypes.ENROLL_WEB_REPLY, GnubbyCodeTypes.BAD_REQUEST); |
| 46 sendResponse(response); |
| 47 return null; |
| 48 } |
| 49 } |
| 50 |
| 51 // Message handler for requests coming from web pages. |
| 52 function messageHandler(toleratesMultipleResponses, request, sender, |
| 53 sendResponse) { |
| 54 console.log(UTIL_fmt('onMessageExternal listener: ' + request.type)); |
| 55 console.log(UTIL_fmt('request')); |
| 56 console.log(request); |
| 57 console.log(UTIL_fmt('sender')); |
| 58 console.log(sender); |
| 59 |
| 60 handleWebPageRequest(toleratesMultipleResponses, request, sender, |
| 61 sendResponse); |
| 62 return true; |
| 63 } |
| 64 |
| 65 // Listen to web pages. |
| 66 chrome.runtime.onMessageExternal.addListener(messageHandler.bind(null, false)); |
| 67 |
| 68 // List to connection events, and wire up a message handler on the port. |
| 69 chrome.runtime.onConnectExternal.addListener(function(port) { |
| 70 var closeable; |
| 71 port.onMessage.addListener(function(request) { |
| 72 var toleratesMultipleResponses = true; |
| 73 closeable = handleWebPageRequest(toleratesMultipleResponses, request, |
| 74 port.sender, |
| 75 function(response) { |
| 76 response['requestId'] = request['requestId']; |
| 77 port.postMessage(response); |
| 78 }); |
| 79 }); |
| 80 port.onDisconnect.addListener(function() { |
| 81 if (closeable) { |
| 82 closeable.close(); |
| 83 } |
| 84 }); |
| 85 }); |
OLD | NEW |