Hex Artifact Content

Artifact 097e060f298f7c043df11424129d56899dfcf7d3:


0000: 2f 2a 0a 20 2a 20 43 41 43 4b 65 79 20 43 68 72  /*. * CACKey Chr
0010: 6f 6d 65 4f 53 20 63 68 72 6f 6d 65 2e 63 65 72  omeOS chrome.cer
0020: 74 69 66 69 63 61 74 65 50 72 6f 76 69 64 65 72  tificateProvider
0030: 20 49 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 0a   Implementation.
0040: 20 2a 2f 0a 0a 66 75 6e 63 74 69 6f 6e 20 6f 6e   */..function on
0050: 43 65 72 74 69 66 69 63 61 74 65 73 52 65 6a 65  CertificatesReje
0060: 63 74 65 64 28 72 65 6a 65 63 74 65 64 43 65 72  cted(rejectedCer
0070: 74 73 29 20 7b 0a 09 2f 2f 20 49 66 20 63 65 72  ts) {..// If cer
0080: 74 69 66 69 63 61 74 65 73 20 77 65 72 65 20 72  tificates were r
0090: 65 6a 65 63 74 65 64 20 62 79 20 74 68 65 20 41  ejected by the A
00a0: 50 49 2c 20 6c 6f 67 20 61 6e 20 65 72 72 6f 72  PI, log an error
00b0: 2c 20 66 6f 72 20 65 78 61 6d 70 6c 65 2e 0a 09  , for example...
00c0: 63 6f 6e 73 6f 6c 65 2e 65 72 72 6f 72 28 72 65  console.error(re
00d0: 6a 65 63 74 65 64 43 65 72 74 73 2e 6c 65 6e 67  jectedCerts.leng
00e0: 74 68 20 2b 20 27 20 63 65 72 74 69 66 69 63 61  th + ' certifica
00f0: 74 65 73 20 77 65 72 65 20 72 65 6a 65 63 74 65  tes were rejecte
0100: 64 2e 27 29 3b 0a 09 72 65 74 75 72 6e 3b 0a 7d  d.');..return;.}
0110: 0a 0a 2f 2a 0a 20 2a 20 48 61 6e 64 6c 65 20 66  ../*. * Handle f
0120: 6f 72 20 74 68 65 20 43 41 43 4b 65 79 20 4e 61  or the CACKey Na
0130: 43 6c 20 54 61 72 67 65 74 0a 20 2a 2f 0a 76 61  Cl Target. */.va
0140: 72 20 63 61 63 6b 65 79 48 61 6e 64 6c 65 20 3d  r cackeyHandle =
0150: 20 6e 75 6c 6c 3b 0a 0a 2f 2a 0a 20 2a 20 48 61   null;../*. * Ha
0160: 6e 64 6c 65 20 61 6e 64 20 49 44 20 66 6f 72 20  ndle and ID for 
0170: 6f 75 74 73 74 61 6e 64 69 6e 67 20 63 61 6c 6c  outstanding call
0180: 62 61 63 6b 73 0a 20 2a 2f 0a 76 61 72 20 63 61  backs. */.var ca
0190: 63 6b 65 79 4f 75 74 73 74 61 6e 64 69 6e 67 43  ckeyOutstandingC
01a0: 61 6c 6c 62 61 63 6b 73 20 3d 20 5b 5d 0a 76 61  allbacks = [].va
01b0: 72 20 63 61 63 6b 65 79 4f 75 74 73 74 61 6e 64  r cackeyOutstand
01c0: 69 6e 67 43 61 6c 6c 62 61 63 6b 43 6f 75 6e 74  ingCallbackCount
01d0: 65 72 20 3d 20 2d 31 3b 0a 0a 2f 2a 0a 20 2a 20  er = -1;../*. * 
01e0: 48 61 6e 64 6c 65 20 61 20 72 65 73 70 6f 6e 73  Handle a respons
01f0: 65 20 66 72 6f 6d 20 74 68 65 20 4e 61 43 6c 20  e from the NaCl 
0200: 73 69 64 65 20 72 65 67 61 72 64 69 6e 67 20 63  side regarding c
0210: 65 72 74 69 66 69 63 61 74 65 73 20 61 76 61 69  ertificates avai
0220: 6c 61 62 6c 65 0a 20 2a 2f 0a 66 75 6e 63 74 69  lable. */.functi
0230: 6f 6e 20 63 61 63 6b 65 79 4d 65 73 73 61 67 65  on cackeyMessage
0240: 49 6e 63 6f 6d 69 6e 67 4c 69 73 74 43 65 72 74  IncomingListCert
0250: 69 66 69 63 61 74 65 73 28 6d 65 73 73 61 67 65  ificates(message
0260: 2c 20 63 68 72 6f 6d 65 43 61 6c 6c 62 61 63 6b  , chromeCallback
0270: 29 20 7b 0a 09 76 61 72 20 69 64 78 3b 0a 09 76  ) {..var idx;..v
0280: 61 72 20 63 65 72 74 69 66 69 63 61 74 65 73 20  ar certificates 
0290: 3d 20 5b 5d 3b 0a 0a 09 66 6f 72 20 28 69 64 78  = [];...for (idx
02a0: 20 3d 20 30 3b 20 69 64 78 20 3c 20 6d 65 73 73   = 0; idx < mess
02b0: 61 67 65 2e 63 65 72 74 69 66 69 63 61 74 65 73  age.certificates
02c0: 2e 6c 65 6e 67 74 68 3b 20 69 64 78 2b 2b 29 20  .length; idx++) 
02d0: 7b 0a 09 09 63 65 72 74 69 66 69 63 61 74 65 73  {...certificates
02e0: 2e 70 75 73 68 28 0a 09 09 09 7b 0a 09 09 09 09  .push(....{.....
02f0: 63 65 72 74 69 66 69 63 61 74 65 3a 20 6d 65 73  certificate: mes
0300: 73 61 67 65 2e 63 65 72 74 69 66 69 63 61 74 65  sage.certificate
0310: 73 5b 69 64 78 5d 2c 0a 09 09 09 09 73 75 70 70  s[idx],.....supp
0320: 6f 72 74 65 64 48 61 73 68 65 73 3a 20 5b 27 53  ortedHashes: ['S
0330: 48 41 31 27 2c 20 27 53 48 41 32 35 36 27 5d 0a  HA1', 'SHA256'].
0340: 09 09 09 7d 0a 09 09 29 3b 0a 09 7d 0a 0a 09 63  ...}...);..}...c
0350: 68 72 6f 6d 65 43 61 6c 6c 62 61 63 6b 28 63 65  hromeCallback(ce
0360: 72 74 69 66 69 63 61 74 65 73 2c 0a 09 09 66 75  rtificates,...fu
0370: 6e 63 74 69 6f 6e 28 72 65 6a 65 63 74 65 64 43  nction(rejectedC
0380: 65 72 74 73 29 20 7b 0a 09 09 09 69 66 20 28 63  erts) {....if (c
0390: 68 72 6f 6d 65 2e 72 75 6e 74 69 6d 65 2e 6c 61  hrome.runtime.la
03a0: 73 74 45 72 72 6f 72 29 20 7b 0a 09 09 09 09 72  stError) {.....r
03b0: 65 74 75 72 6e 3b 0a 09 09 09 7d 0a 0a 09 09 09  eturn;....}.....
03c0: 69 66 20 28 72 65 6a 65 63 74 65 64 43 65 72 74  if (rejectedCert
03d0: 73 2e 6c 65 6e 67 74 68 20 21 3d 3d 20 30 29 20  s.length !== 0) 
03e0: 7b 0a 09 09 09 09 6f 6e 43 65 72 74 69 66 69 63  {.....onCertific
03f0: 61 74 65 73 52 65 6a 65 63 74 65 64 28 72 65 6a  atesRejected(rej
0400: 65 63 74 65 64 43 65 72 74 73 29 3b 0a 09 09 09  ectedCerts);....
0410: 7d 0a 0a 09 09 09 72 65 74 75 72 6e 3b 0a 09 09  }.....return;...
0420: 7d 0a 09 29 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 20 48  }..);.}../*. * H
0430: 61 6e 64 6c 65 20 61 20 72 65 73 70 6f 6e 73 65  andle a response
0440: 20 66 72 6f 6d 20 74 68 65 20 4e 61 43 6c 20 73   from the NaCl s
0450: 69 64 65 20 72 65 67 61 72 64 69 6e 67 20 73 69  ide regarding si
0460: 67 6e 69 6e 67 20 61 20 6d 65 73 73 61 67 65 0a  gning a message.
0470: 20 2a 2f 0a 66 75 6e 63 74 69 6f 6e 20 63 61 63   */.function cac
0480: 6b 65 79 4d 65 73 73 61 67 65 49 6e 63 6f 6d 69  keyMessageIncomi
0490: 6e 67 53 69 67 6e 4d 65 73 73 61 67 65 28 6d 65  ngSignMessage(me
04a0: 73 73 61 67 65 2c 20 63 68 72 6f 6d 65 43 61 6c  ssage, chromeCal
04b0: 6c 62 61 63 6b 29 20 7b 0a 09 76 61 72 20 70 61  lback) {..var pa
04c0: 79 6c 6f 61 64 3b 0a 0a 09 70 61 79 6c 6f 61 64  yload;...payload
04d0: 20 3d 20 6d 65 73 73 61 67 65 2e 73 69 67 6e 65   = message.signe
04e0: 64 44 61 74 61 3b 0a 0a 09 63 68 72 6f 6d 65 43  dData;...chromeC
04f0: 61 6c 6c 62 61 63 6b 28 70 61 79 6c 6f 61 64 29  allback(payload)
0500: 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 20 48 61 6e 64 6c  ;.}../*. * Handl
0510: 65 20 61 6e 20 69 6e 63 6f 6d 69 6e 67 20 6d 65  e an incoming me
0520: 73 73 61 67 65 20 66 72 6f 6d 20 74 68 65 20 4e  ssage from the N
0530: 61 43 6c 20 73 69 64 65 20 61 6e 64 20 70 61 73  aCl side and pas
0540: 73 20 69 74 20 6f 66 66 20 74 6f 0a 20 2a 20 6f  s it off to. * o
0550: 6e 65 20 6f 66 20 74 68 65 20 68 61 6e 64 6c 65  ne of the handle
0560: 72 73 20 61 62 6f 76 65 20 66 6f 72 20 61 63 74  rs above for act
0570: 75 61 6c 20 66 6f 72 6d 61 74 74 69 6e 67 20 61  ual formatting a
0580: 6e 64 20 70 61 73 73 69 6e 67 20 74 6f 0a 20 2a  nd passing to. *
0590: 20 74 68 65 20 63 61 6c 6c 62 61 63 6b 0a 20 2a   the callback. *
05a0: 0a 20 2a 20 49 66 20 61 6e 20 65 72 72 6f 72 20  . * If an error 
05b0: 6f 63 63 75 72 65 64 2c 20 69 6e 76 6f 6b 65 20  occured, invoke 
05c0: 74 68 65 20 63 61 6c 6c 62 61 63 6b 20 77 69 74  the callback wit
05d0: 68 20 6e 6f 20 61 72 67 75 6d 65 6e 74 73 2e 0a  h no arguments..
05e0: 20 2a 2f 0a 66 75 6e 63 74 69 6f 6e 20 63 61 63   */.function cac
05f0: 6b 65 79 4d 65 73 73 61 67 65 49 6e 63 6f 6d 69  keyMessageIncomi
0600: 6e 67 28 6d 65 73 73 61 67 65 45 76 65 6e 74 29  ng(messageEvent)
0610: 20 7b 0a 09 76 61 72 20 6e 65 78 74 46 75 6e 63   {..var nextFunc
0620: 74 69 6f 6e 20 3d 20 6e 75 6c 6c 3b 0a 09 76 61  tion = null;..va
0630: 72 20 63 68 72 6f 6d 65 43 61 6c 6c 62 61 63 6b  r chromeCallback
0640: 20 3d 20 6e 75 6c 6c 3b 0a 0a 09 69 66 20 28 6d   = null;...if (m
0650: 65 73 73 61 67 65 45 76 65 6e 74 2e 64 61 74 61  essageEvent.data
0660: 2e 74 61 72 67 65 74 20 21 3d 20 22 63 61 63 6b  .target != "cack
0670: 65 79 22 29 20 7b 0a 09 09 72 65 74 75 72 6e 3b  ey") {...return;
0680: 0a 09 7d 0a 0a 09 63 6f 6e 73 6f 6c 65 2e 6c 6f  ..}...console.lo
0690: 67 28 22 53 54 41 52 54 20 4d 45 53 53 41 47 45  g("START MESSAGE
06a0: 22 29 3b 0a 09 63 6f 6e 73 6f 6c 65 2e 6c 6f 67  ");..console.log
06b0: 28 6d 65 73 73 61 67 65 45 76 65 6e 74 2e 64 61  (messageEvent.da
06c0: 74 61 29 3b 0a 09 63 6f 6e 73 6f 6c 65 2e 6c 6f  ta);..console.lo
06d0: 67 28 22 45 4e 44 20 4d 45 53 53 41 47 45 22 29  g("END MESSAGE")
06e0: 3b 0a 0a 09 63 68 72 6f 6d 65 43 61 6c 6c 62 61  ;...chromeCallba
06f0: 63 6b 20 3d 20 63 61 63 6b 65 79 4f 75 74 73 74  ck = cackeyOutst
0700: 61 6e 64 69 6e 67 43 61 6c 6c 62 61 63 6b 73 5b  andingCallbacks[
0710: 6d 65 73 73 61 67 65 45 76 65 6e 74 2e 64 61 74  messageEvent.dat
0720: 61 2e 69 64 5d 3b 0a 0a 09 69 66 20 28 63 68 72  a.id];...if (chr
0730: 6f 6d 65 43 61 6c 6c 62 61 63 6b 20 3d 3d 20 6e  omeCallback == n
0740: 75 6c 6c 29 20 7b 0a 09 09 63 6f 6e 73 6f 6c 65  ull) {...console
0750: 2e 6c 6f 67 28 22 5b 63 61 63 6b 65 79 5d 20 44  .log("[cackey] D
0760: 69 73 63 61 72 64 69 6e 67 20 6f 75 74 64 61 74  iscarding outdat
0770: 65 64 20 6d 65 73 73 61 67 65 22 29 3b 0a 0a 09  ed message");...
0780: 09 72 65 74 75 72 6e 3b 0a 09 7d 0a 0a 09 69 66  .return;..}...if
0790: 20 28 6d 65 73 73 61 67 65 45 76 65 6e 74 2e 64   (messageEvent.d
07a0: 61 74 61 2e 73 74 61 74 75 73 20 21 3d 20 22 73  ata.status != "s
07b0: 75 63 63 65 73 73 22 29 20 7b 0a 09 09 63 6f 6e  uccess") {...con
07c0: 73 6f 6c 65 2e 65 72 72 6f 72 28 22 5b 63 61 63  sole.error("[cac
07d0: 6b 65 79 5d 20 46 61 69 6c 65 64 20 74 6f 20 65  key] Failed to e
07e0: 78 65 63 75 74 65 20 63 6f 6d 6d 61 6e 64 20 27  xecute command '
07f0: 22 20 2b 20 6d 65 73 73 61 67 65 45 76 65 6e 74  " + messageEvent
0800: 2e 64 61 74 61 2e 63 6f 6d 6d 61 6e 64 20 2b 20  .data.command + 
0810: 22 27 3a 20 22 20 2b 20 6d 65 73 73 61 67 65 45  "': " + messageE
0820: 76 65 6e 74 2e 64 61 74 61 2e 65 72 72 6f 72 29  vent.data.error)
0830: 3b 0a 0a 09 09 63 68 72 6f 6d 65 43 61 6c 6c 62  ;....chromeCallb
0840: 61 63 6b 28 29 3b 0a 09 7d 20 65 6c 73 65 20 7b  ack();..} else {
0850: 0a 09 09 73 77 69 74 63 68 20 28 6d 65 73 73 61  ...switch (messa
0860: 67 65 45 76 65 6e 74 2e 64 61 74 61 2e 63 6f 6d  geEvent.data.com
0870: 6d 61 6e 64 29 20 7b 0a 09 09 09 63 61 73 65 20  mand) {....case 
0880: 22 6c 69 73 74 63 65 72 74 69 66 69 63 61 74 65  "listcertificate
0890: 73 22 3a 0a 09 09 09 09 6e 65 78 74 46 75 6e 63  s":.....nextFunc
08a0: 74 69 6f 6e 20 3d 20 63 61 63 6b 65 79 4d 65 73  tion = cackeyMes
08b0: 73 61 67 65 49 6e 63 6f 6d 69 6e 67 4c 69 73 74  sageIncomingList
08c0: 43 65 72 74 69 66 69 63 61 74 65 73 3b 0a 0a 09  Certificates;...
08d0: 09 09 09 62 72 65 61 6b 3b 0a 09 09 09 63 61 73  ...break;....cas
08e0: 65 20 22 73 69 67 6e 22 3a 0a 09 09 09 09 6e 65  e "sign":.....ne
08f0: 78 74 46 75 6e 63 74 69 6f 6e 20 3d 20 63 61 63  xtFunction = cac
0900: 6b 65 79 4d 65 73 73 61 67 65 49 6e 63 6f 6d 69  keyMessageIncomi
0910: 6e 67 53 69 67 6e 4d 65 73 73 61 67 65 3b 0a 0a  ngSignMessage;..
0920: 09 09 09 09 62 72 65 61 6b 3b 0a 09 09 7d 0a 09  ....break;...}..
0930: 7d 0a 0a 09 69 66 20 28 6e 65 78 74 46 75 6e 63  }...if (nextFunc
0940: 74 69 6f 6e 20 21 3d 20 6e 75 6c 6c 29 20 7b 0a  tion != null) {.
0950: 09 09 6e 65 78 74 46 75 6e 63 74 69 6f 6e 28 6d  ..nextFunction(m
0960: 65 73 73 61 67 65 45 76 65 6e 74 2e 64 61 74 61  essageEvent.data
0970: 2c 20 63 68 72 6f 6d 65 43 61 6c 6c 62 61 63 6b  , chromeCallback
0980: 29 3b 0a 09 7d 0a 0a 09 64 65 6c 65 74 65 20 63  );..}...delete c
0990: 61 63 6b 65 79 4f 75 74 73 74 61 6e 64 69 6e 67  ackeyOutstanding
09a0: 43 61 6c 6c 62 61 63 6b 73 5b 6d 65 73 73 61 67  Callbacks[messag
09b0: 65 45 76 65 6e 74 2e 64 61 74 61 2e 69 64 5d 3b  eEvent.data.id];
09c0: 0a 0a 09 72 65 74 75 72 6e 3b 0a 7d 0a 0a 2f 2a  ...return;.}../*
09d0: 0a 20 2a 20 48 61 6e 64 6c 65 72 20 66 6f 72 20  . * Handler for 
09e0: 6d 65 73 73 61 67 65 73 20 66 72 6f 6d 20 43 68  messages from Ch
09f0: 72 6f 6d 65 20 72 65 6c 61 74 65 64 20 74 6f 20  rome related to 
0a00: 6c 69 73 74 69 6e 67 20 63 65 72 74 69 66 69 63  listing certific
0a10: 61 74 65 73 0a 20 2a 2f 0a 66 75 6e 63 74 69 6f  ates. */.functio
0a20: 6e 20 63 61 63 6b 65 79 4c 69 73 74 43 65 72 74  n cackeyListCert
0a30: 69 66 69 63 61 74 65 73 28 63 68 72 6f 6d 65 43  ificates(chromeC
0a40: 61 6c 6c 62 61 63 6b 29 20 7b 0a 09 76 61 72 20  allback) {..var 
0a50: 63 61 6c 6c 62 61 63 6b 49 64 3b 0a 0a 09 63 6f  callbackId;...co
0a60: 6e 73 6f 6c 65 2e 6c 6f 67 28 22 5b 63 61 63 6b  nsole.log("[cack
0a70: 65 79 5d 20 41 73 6b 65 64 20 74 6f 20 70 72 6f  ey] Asked to pro
0a80: 76 69 64 65 20 61 20 6c 69 73 74 20 6f 66 20 63  vide a list of c
0a90: 65 72 74 69 66 69 63 61 74 65 73 20 2d 2d 20 74  ertificates -- t
0aa0: 68 72 6f 77 69 6e 67 20 74 68 61 74 20 72 65 71  hrowing that req
0ab0: 75 65 73 74 20 6f 76 65 72 20 74 6f 20 74 68 65  uest over to the
0ac0: 20 4e 61 43 6c 20 73 69 64 65 2e 2e 2e 20 22 29   NaCl side... ")
0ad0: 3b 0a 0a 09 63 61 6c 6c 62 61 63 6b 49 64 20 3d  ;...callbackId =
0ae0: 20 63 61 63 6b 65 79 4f 75 74 73 74 61 6e 64 69   cackeyOutstandi
0af0: 6e 67 43 61 6c 6c 62 61 63 6b 43 6f 75 6e 74 65  ngCallbackCounte
0b00: 72 20 2b 20 31 3b 0a 0a 09 63 61 63 6b 65 79 48  r + 1;...cackeyH
0b10: 61 6e 64 6c 65 2e 70 6f 73 74 4d 65 73 73 61 67  andle.postMessag
0b20: 65 28 0a 09 09 7b 0a 09 09 09 27 74 61 72 67 65  e(...{....'targe
0b30: 74 27 3a 20 22 63 61 63 6b 65 79 22 2c 0a 09 09  t': "cackey",...
0b40: 09 27 63 6f 6d 6d 61 6e 64 27 3a 20 22 6c 69 73  .'command': "lis
0b50: 74 63 65 72 74 69 66 69 63 61 74 65 73 22 2c 0a  tcertificates",.
0b60: 09 09 09 27 69 64 27 3a 20 63 61 6c 6c 62 61 63  ...'id': callbac
0b70: 6b 49 64 0a 09 09 7d 0a 09 29 3b 0a 0a 09 63 61  kId...}..);...ca
0b80: 63 6b 65 79 4f 75 74 73 74 61 6e 64 69 6e 67 43  ckeyOutstandingC
0b90: 61 6c 6c 62 61 63 6b 43 6f 75 6e 74 65 72 20 3d  allbackCounter =
0ba0: 20 63 61 6c 6c 62 61 63 6b 49 64 3b 0a 09 63 61   callbackId;..ca
0bb0: 63 6b 65 79 4f 75 74 73 74 61 6e 64 69 6e 67 43  ckeyOutstandingC
0bc0: 61 6c 6c 62 61 63 6b 73 5b 63 61 6c 6c 62 61 63  allbacks[callbac
0bd0: 6b 49 64 5d 20 3d 20 63 68 72 6f 6d 65 43 61 6c  kId] = chromeCal
0be0: 6c 62 61 63 6b 3b 0a 0a 09 63 6f 6e 73 6f 6c 65  lback;...console
0bf0: 2e 6c 6f 67 28 22 5b 63 61 63 6b 65 79 5d 20 54  .log("[cackey] T
0c00: 68 72 6f 77 6e 2e 22 29 3b 0a 0a 09 72 65 74 75  hrown.");...retu
0c10: 72 6e 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 20 48 61 6e  rn;.}../*. * Han
0c20: 64 6c 65 72 20 66 6f 72 20 6d 65 73 73 61 67 65  dler for message
0c30: 73 20 66 72 6f 6d 20 43 68 72 6f 6d 65 20 72 65  s from Chrome re
0c40: 6c 61 74 65 64 20 74 6f 20 73 69 67 6e 69 6e 67  lated to signing
0c50: 20 61 20 68 61 73 68 20 6f 66 20 73 6f 6d 65 20   a hash of some 
0c60: 73 6f 72 74 0a 20 2a 2f 0a 66 75 6e 63 74 69 6f  sort. */.functio
0c70: 6e 20 63 61 63 6b 65 79 53 69 67 6e 4d 65 73 73  n cackeySignMess
0c80: 61 67 65 28 73 69 67 6e 52 65 71 75 65 73 74 2c  age(signRequest,
0c90: 20 63 68 72 6f 6d 65 43 61 6c 6c 62 61 63 6b 29   chromeCallback)
0ca0: 20 7b 0a 09 76 61 72 20 63 61 6c 6c 62 61 63 6b   {..var callback
0cb0: 49 64 3b 0a 0a 09 63 6f 6e 73 6f 6c 65 2e 6c 6f  Id;...console.lo
0cc0: 67 28 22 5b 63 61 63 6b 65 79 5d 20 41 73 6b 65  g("[cackey] Aske
0cd0: 64 20 74 6f 20 73 69 67 6e 20 61 20 6d 65 73 73  d to sign a mess
0ce0: 61 67 65 20 2d 2d 20 74 68 72 6f 77 69 6e 67 20  age -- throwing 
0cf0: 74 68 61 74 20 72 65 71 75 65 73 74 20 6f 76 65  that request ove
0d00: 72 20 74 6f 20 74 68 65 20 4e 61 43 6c 20 73 69  r to the NaCl si
0d10: 64 65 2e 2e 2e 20 22 29 3b 0a 0a 09 63 61 6c 6c  de... ");...call
0d20: 62 61 63 6b 49 64 20 3d 20 63 61 63 6b 65 79 4f  backId = cackeyO
0d30: 75 74 73 74 61 6e 64 69 6e 67 43 61 6c 6c 62 61  utstandingCallba
0d40: 63 6b 43 6f 75 6e 74 65 72 20 2b 20 31 3b 0a 0a  ckCounter + 1;..
0d50: 09 63 61 63 6b 65 79 48 61 6e 64 6c 65 2e 70 6f  .cackeyHandle.po
0d60: 73 74 4d 65 73 73 61 67 65 28 0a 09 09 7b 0a 09  stMessage(...{..
0d70: 09 09 27 74 61 72 67 65 74 27 3a 20 22 63 61 63  ..'target': "cac
0d80: 6b 65 79 22 2c 0a 09 09 09 27 63 6f 6d 6d 61 6e  key",....'comman
0d90: 64 27 3a 20 22 73 69 67 6e 22 2c 0a 09 09 09 27  d': "sign",....'
0da0: 69 64 27 3a 20 63 61 6c 6c 62 61 63 6b 49 64 2c  id': callbackId,
0db0: 0a 09 09 09 27 63 65 72 74 69 66 69 63 61 74 65  ....'certificate
0dc0: 27 3a 20 73 69 67 6e 52 65 71 75 65 73 74 2e 63  ': signRequest.c
0dd0: 65 72 74 69 66 69 63 61 74 65 2c 0a 09 09 09 27  ertificate,....'
0de0: 64 61 74 61 27 3a 20 73 69 67 6e 52 65 71 75 65  data': signReque
0df0: 73 74 2e 64 69 67 65 73 74 20 2f 2a 20 58 58 58  st.digest /* XXX
0e00: 3a 54 4f 44 4f 3a 20 54 68 69 73 20 6e 65 65 64  :TODO: This need
0e10: 73 20 74 6f 20 62 65 20 70 72 65 66 69 78 65 64  s to be prefixed
0e20: 20 62 61 73 65 64 20 6f 6e 20 74 68 65 20 73 69   based on the si
0e30: 67 6e 52 65 71 75 65 73 74 2e 68 61 73 68 20 2a  gnRequest.hash *
0e40: 2f 0a 09 09 7d 0a 09 29 3b 0a 0a 09 63 61 63 6b  /...}..);...cack
0e50: 65 79 4f 75 74 73 74 61 6e 64 69 6e 67 43 61 6c  eyOutstandingCal
0e60: 6c 62 61 63 6b 43 6f 75 6e 74 65 72 20 3d 20 63  lbackCounter = c
0e70: 61 6c 6c 62 61 63 6b 49 64 3b 0a 09 63 61 63 6b  allbackId;..cack
0e80: 65 79 4f 75 74 73 74 61 6e 64 69 6e 67 43 61 6c  eyOutstandingCal
0e90: 6c 62 61 63 6b 73 5b 63 61 6c 6c 62 61 63 6b 49  lbacks[callbackI
0ea0: 64 5d 20 3d 20 63 68 72 6f 6d 65 43 61 6c 6c 62  d] = chromeCallb
0eb0: 61 63 6b 3b 0a 0a 09 63 6f 6e 73 6f 6c 65 2e 6c  ack;...console.l
0ec0: 6f 67 28 22 5b 63 61 63 6b 65 79 5d 20 54 68 72  og("[cackey] Thr
0ed0: 6f 77 6e 2e 22 29 3b 0a 0a 09 72 65 74 75 72 6e  own.");...return
0ee0: 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 20 46 69 6e 69 73  ;.}../*. * Finis
0ef0: 68 20 70 65 72 66 6f 72 6d 69 6e 67 20 69 6e 69  h performing ini
0f00: 74 69 61 6c 69 7a 61 74 69 6f 6e 20 74 68 61 74  tialization that
0f10: 20 6d 75 73 74 20 77 61 69 74 20 75 6e 74 69 6c   must wait until
0f20: 20 77 65 20 68 61 76 65 20 6c 6f 61 64 65 64 20   we have loaded 
0f30: 74 68 65 20 43 41 43 4b 65 79 20 6d 6f 64 75 6c  the CACKey modul
0f40: 65 0a 20 2a 2f 0a 66 75 6e 63 74 69 6f 6e 20 63  e. */.function c
0f50: 61 63 6b 65 79 49 6e 69 74 4c 6f 61 64 65 64 28  ackeyInitLoaded(
0f60: 6d 65 73 73 61 67 65 45 76 65 6e 74 29 20 7b 0a  messageEvent) {.
0f70: 09 63 6f 6e 73 6f 6c 65 2e 6c 6f 67 28 22 5b 63  .console.log("[c
0f80: 61 63 6b 65 79 5d 20 4c 6f 61 64 65 64 20 43 41  ackey] Loaded CA
0f90: 43 4b 65 79 20 50 4e 61 43 6c 20 4d 6f 64 75 6c  CKey PNaCl Modul
0fa0: 65 22 29 3b 0a 0a 09 2f 2a 20 52 65 67 69 73 74  e");.../* Regist
0fb0: 65 72 20 6c 69 73 74 65 6e 65 72 73 20 77 69 74  er listeners wit
0fc0: 68 20 43 68 72 6f 6d 65 20 2a 2f 0a 09 69 66 20  h Chrome */..if 
0fd0: 28 63 68 72 6f 6d 65 2e 63 65 72 74 69 66 69 63  (chrome.certific
0fe0: 61 74 65 50 72 6f 76 69 64 65 72 29 20 7b 0a 09  ateProvider) {..
0ff0: 09 63 68 72 6f 6d 65 2e 63 65 72 74 69 66 69 63  .chrome.certific
1000: 61 74 65 50 72 6f 76 69 64 65 72 2e 6f 6e 43 65  ateProvider.onCe
1010: 72 74 69 66 69 63 61 74 65 73 52 65 71 75 65 73  rtificatesReques
1020: 74 65 64 2e 61 64 64 4c 69 73 74 65 6e 65 72 28  ted.addListener(
1030: 63 61 63 6b 65 79 4c 69 73 74 43 65 72 74 69 66  cackeyListCertif
1040: 69 63 61 74 65 73 29 3b 0a 09 09 63 68 72 6f 6d  icates);...chrom
1050: 65 2e 63 65 72 74 69 66 69 63 61 74 65 50 72 6f  e.certificatePro
1060: 76 69 64 65 72 2e 6f 6e 53 69 67 6e 44 69 67 65  vider.onSignDige
1070: 73 74 52 65 71 75 65 73 74 65 64 2e 61 64 64 4c  stRequested.addL
1080: 69 73 74 65 6e 65 72 28 63 61 63 6b 65 79 53 69  istener(cackeySi
1090: 67 6e 4d 65 73 73 61 67 65 29 3b 0a 09 7d 0a 0a  gnMessage);..}..
10a0: 09 72 65 74 75 72 6e 3b 0a 7d 0a 0a 2f 2a 0a 20  .return;.}../*. 
10b0: 2a 20 49 6e 69 74 69 61 6c 69 7a 65 20 43 41 43  * Initialize CAC
10c0: 4b 65 79 20 61 6e 64 20 74 68 65 20 50 43 53 43  Key and the PCSC
10d0: 20 6c 69 62 72 61 72 79 20 66 72 6f 6d 20 47 6f   library from Go
10e0: 6f 67 6c 65 0a 20 2a 2f 0a 66 75 6e 63 74 69 6f  ogle. */.functio
10f0: 6e 20 63 61 63 6b 65 79 49 6e 69 74 28 29 20 7b  n cackeyInit() {
1100: 0a 09 76 61 72 20 65 6c 65 6d 65 6e 74 45 6d 62  ..var elementEmb
1110: 65 64 3b 0a 0a 09 2f 2a 20 4c 6f 67 20 74 68 61  ed;.../* Log tha
1120: 74 20 77 65 20 61 72 65 20 6f 70 65 72 61 74 69  t we are operati
1130: 6f 6e 61 6c 20 2a 2f 0a 09 63 6f 6e 73 6f 6c 65  onal */..console
1140: 2e 6c 6f 67 28 22 5b 63 61 63 6b 65 79 5d 20 63  .log("[cackey] c
1150: 61 63 6b 65 79 49 6e 69 74 28 29 3a 20 43 61 6c  ackeyInit(): Cal
1160: 6c 65 64 2e 22 29 3b 0a 0a 09 2f 2a 20 56 65 72  led.");.../* Ver
1170: 69 66 79 20 74 68 61 74 20 77 65 20 63 61 6e 20  ify that we can 
1180: 72 65 67 69 73 74 65 72 20 63 61 6c 6c 62 61 63  register callbac
1190: 6b 73 20 2a 2f 0a 09 69 66 20 28 21 63 68 72 6f  ks */..if (!chro
11a0: 6d 65 2e 63 65 72 74 69 66 69 63 61 74 65 50 72  me.certificatePr
11b0: 6f 76 69 64 65 72 29 20 7b 0a 09 09 69 66 20 28  ovider) {...if (
11c0: 21 47 6f 6f 67 6c 65 53 6d 61 72 74 43 61 72 64  !GoogleSmartCard
11d0: 2e 49 53 5f 44 45 42 55 47 5f 42 55 49 4c 44 29  .IS_DEBUG_BUILD)
11e0: 20 7b 0a 09 09 09 63 6f 6e 73 6f 6c 65 2e 65 72   {....console.er
11f0: 72 6f 72 28 22 5b 63 61 63 6b 65 79 5d 20 54 68  ror("[cackey] Th
1200: 69 73 20 65 78 74 65 6e 73 69 6f 6e 20 6f 6e 6c  is extension onl
1210: 79 20 77 6f 72 6b 73 20 6f 6e 20 43 68 72 6f 6d  y works on Chrom
1220: 65 4f 53 21 22 29 3b 0a 0a 09 09 09 72 65 74 75  eOS!");.....retu
1230: 72 6e 3b 0a 09 09 7d 20 65 6c 73 65 20 7b 0a 09  rn;...} else {..
1240: 09 09 63 6f 6e 73 6f 6c 65 2e 6c 6f 67 28 22 5b  ..console.log("[
1250: 63 61 63 6b 65 79 5d 20 54 68 69 73 20 65 78 74  cackey] This ext
1260: 65 6e 73 69 6f 6e 20 6f 6e 6c 79 20 77 6f 72 6b  ension only work
1270: 73 20 6f 6e 20 43 68 72 6f 6d 65 4f 53 2c 20 62  s on ChromeOS, b
1280: 75 74 20 79 6f 75 20 61 70 70 65 61 72 20 74 6f  ut you appear to
1290: 20 62 65 20 64 65 62 75 67 67 69 6e 67 20 69 74   be debugging it
12a0: 20 2d 2d 20 74 72 79 69 6e 67 20 61 6e 79 77 61   -- trying anywa
12b0: 79 2e 22 29 3b 0a 09 09 7d 0a 09 7d 0a 0a 09 69  y.");...}..}...i
12c0: 66 20 28 63 61 63 6b 65 79 48 61 6e 64 6c 65 20  f (cackeyHandle 
12d0: 21 3d 20 6e 75 6c 6c 29 20 7b 0a 09 09 63 6f 6e  != null) {...con
12e0: 73 6f 6c 65 2e 6c 6f 67 28 22 5b 63 61 63 6b 65  sole.log("[cacke
12f0: 79 5d 20 63 61 63 6b 65 79 49 6e 69 74 28 29 3a  y] cackeyInit():
1300: 20 41 6c 72 65 61 64 79 20 69 6e 69 74 69 61 6c   Already initial
1310: 69 7a 65 64 2e 20 20 52 65 74 75 72 6e 69 6e 67  ized.  Returning
1320: 2e 22 29 3b 0a 0a 09 09 72 65 74 75 72 6e 3b 0a  .");....return;.
1330: 09 7d 0a 0a 09 65 6c 65 6d 65 6e 74 45 6d 62 65  .}...elementEmbe
1340: 64 20 3d 20 64 6f 63 75 6d 65 6e 74 2e 63 72 65  d = document.cre
1350: 61 74 65 45 6c 65 6d 65 6e 74 28 27 65 6d 62 65  ateElement('embe
1360: 64 27 29 3b 0a 09 65 6c 65 6d 65 6e 74 45 6d 62  d');..elementEmb
1370: 65 64 2e 74 79 70 65 20 3d 20 22 61 70 70 6c 69  ed.type = "appli
1380: 63 61 74 69 6f 6e 2f 78 2d 70 6e 61 63 6c 22 3b  cation/x-pnacl";
1390: 0a 09 65 6c 65 6d 65 6e 74 45 6d 62 65 64 2e 77  ..elementEmbed.w
13a0: 69 64 74 68 20 3d 20 30 3b 0a 09 65 6c 65 6d 65  idth = 0;..eleme
13b0: 6e 74 45 6d 62 65 64 2e 68 65 69 67 68 74 20 3d  ntEmbed.height =
13c0: 20 30 3b 0a 09 65 6c 65 6d 65 6e 74 45 6d 62 65   0;..elementEmbe
13d0: 64 2e 73 72 63 20 3d 20 22 63 61 63 6b 65 79 2e  d.src = "cackey.
13e0: 6e 6d 66 22 3b 0a 09 65 6c 65 6d 65 6e 74 45 6d  nmf";..elementEm
13f0: 62 65 64 2e 69 64 20 3d 20 22 63 61 63 6b 65 79  bed.id = "cackey
1400: 4d 6f 64 75 6c 65 22 3b 0a 09 65 6c 65 6d 65 6e  Module";..elemen
1410: 74 45 6d 62 65 64 2e 61 64 64 45 76 65 6e 74 4c  tEmbed.addEventL
1420: 69 73 74 65 6e 65 72 28 27 65 72 72 6f 72 27 2c  istener('error',
1430: 20 66 75 6e 63 74 69 6f 6e 28 6d 65 73 73 61 67   function(messag
1440: 65 45 76 65 6e 74 29 20 7b 20 63 6f 6e 73 6f 6c  eEvent) { consol
1450: 65 2e 65 72 72 6f 72 28 22 45 72 72 6f 72 20 6c  e.error("Error l
1460: 6f 61 64 69 6e 67 20 43 41 43 4b 65 79 20 50 4e  oading CACKey PN
1470: 61 43 6c 20 4d 6f 64 75 6c 65 3a 20 22 20 2b 20  aCl Module: " + 
1480: 6d 65 73 73 61 67 65 45 76 65 6e 74 2e 64 61 74  messageEvent.dat
1490: 61 29 3b 20 7d 2c 20 74 72 75 65 29 3b 0a 09 65  a); }, true);..e
14a0: 6c 65 6d 65 6e 74 45 6d 62 65 64 2e 61 64 64 45  lementEmbed.addE
14b0: 76 65 6e 74 4c 69 73 74 65 6e 65 72 28 27 6c 6f  ventListener('lo
14c0: 61 64 27 2c 20 63 61 63 6b 65 79 49 6e 69 74 4c  ad', cackeyInitL
14d0: 6f 61 64 65 64 2c 20 74 72 75 65 29 3b 0a 09 65  oaded, true);..e
14e0: 6c 65 6d 65 6e 74 45 6d 62 65 64 2e 61 64 64 45  lementEmbed.addE
14f0: 76 65 6e 74 4c 69 73 74 65 6e 65 72 28 27 6d 65  ventListener('me
1500: 73 73 61 67 65 27 2c 20 63 61 63 6b 65 79 4d 65  ssage', cackeyMe
1510: 73 73 61 67 65 49 6e 63 6f 6d 69 6e 67 2c 20 74  ssageIncoming, t
1520: 72 75 65 29 3b 0a 0a 09 63 61 63 6b 65 79 48 61  rue);...cackeyHa
1530: 6e 64 6c 65 20 3d 20 65 6c 65 6d 65 6e 74 45 6d  ndle = elementEm
1540: 62 65 64 3b 0a 0a 09 2f 2a 0a 09 20 2a 20 53 74  bed;.../*.. * St
1550: 61 72 74 20 74 68 65 20 47 6f 6f 67 6c 65 20 50  art the Google P
1560: 43 53 43 20 49 6e 74 65 72 66 61 63 65 0a 09 20  CSC Interface.. 
1570: 2a 2f 0a 09 6e 65 77 20 47 6f 6f 67 6c 65 53 6d  */..new GoogleSm
1580: 61 72 74 43 61 72 64 2e 50 63 73 63 4e 61 63 6c  artCard.PcscNacl
1590: 28 63 61 63 6b 65 79 48 61 6e 64 6c 65 29 3b 0a  (cackeyHandle);.
15a0: 0a 09 64 6f 63 75 6d 65 6e 74 2e 62 6f 64 79 2e  ..document.body.
15b0: 61 70 70 65 6e 64 43 68 69 6c 64 28 63 61 63 6b  appendChild(cack
15c0: 65 79 48 61 6e 64 6c 65 29 0a 0a 09 63 6f 6e 73  eyHandle)...cons
15d0: 6f 6c 65 2e 6c 6f 67 28 22 5b 63 61 63 6b 65 79  ole.log("[cackey
15e0: 5d 20 63 61 63 6b 65 79 49 6e 69 74 28 29 3a 20  ] cackeyInit(): 
15f0: 43 6f 6d 70 6c 65 74 65 64 2e 20 20 52 65 74 75  Completed.  Retu
1600: 72 6e 69 6e 67 2e 22 29 3b 0a 7d 0a 0a 2f 2a 20  rning.");.}../* 
1610: 49 6e 69 74 69 61 6c 69 7a 65 20 43 41 43 4b 65  Initialize CACKe
1620: 79 20 2a 2f 0a 63 61 63 6b 65 79 49 6e 69 74 28  y */.cackeyInit(
1630: 29 3b 0a                                         );.