Hex Artifact Content

Artifact 6f10afa9dfce041424fb569f07884dfc8a257e40:


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 76 61 72 20 63 61 63 6b 65   null;.var cacke
0160: 79 50 43 53 43 48 61 6e 64 6c 65 20 3d 20 6e 75  yPCSCHandle = nu
0170: 6c 6c 3b 0a 76 61 72 20 63 61 63 6b 65 79 50 43  ll;.var cackeyPC
0180: 53 43 48 61 6e 64 6c 65 55 73 61 62 6c 65 20 3d  SCHandleUsable =
0190: 20 66 61 6c 73 65 3b 0a 0a 2f 2a 0a 20 2a 20 48   false;../*. * H
01a0: 61 6e 64 6c 65 20 61 6e 64 20 49 44 20 66 6f 72  andle and ID for
01b0: 20 6f 75 74 73 74 61 6e 64 69 6e 67 20 63 61 6c   outstanding cal
01c0: 6c 62 61 63 6b 73 0a 20 2a 2f 0a 76 61 72 20 63  lbacks. */.var c
01d0: 61 63 6b 65 79 4f 75 74 73 74 61 6e 64 69 6e 67  ackeyOutstanding
01e0: 43 61 6c 6c 62 61 63 6b 73 20 3d 20 7b 7d 0a 76  Callbacks = {}.v
01f0: 61 72 20 63 61 63 6b 65 79 4f 75 74 73 74 61 6e  ar cackeyOutstan
0200: 64 69 6e 67 43 61 6c 6c 62 61 63 6b 43 6f 75 6e  dingCallbackCoun
0210: 74 65 72 20 3d 20 2d 31 3b 0a 0a 2f 2a 0a 20 2a  ter = -1;../*. *
0220: 20 43 6f 6d 6d 75 6e 69 63 61 74 69 6f 6e 20 77   Communication w
0230: 69 74 68 20 74 68 65 20 50 49 4e 20 65 6e 74 72  ith the PIN entr
0240: 79 20 77 69 6e 64 6f 77 0a 20 2a 2f 0a 76 61 72  y window. */.var
0250: 20 70 69 6e 57 69 6e 64 6f 77 50 49 4e 56 61 6c   pinWindowPINVal
0260: 75 65 20 3d 20 22 22 3b 0a 76 61 72 20 70 69 6e  ue = "";.var pin
0270: 57 69 6e 64 6f 77 50 72 65 76 69 6f 75 73 48 61  WindowPreviousHa
0280: 6e 64 6c 65 20 3d 20 6e 75 6c 6c 3b 0a 0a 2f 2a  ndle = null;../*
0290: 0a 20 2a 20 4d 65 73 73 61 67 65 73 20 74 68 61  . * Messages tha
02a0: 74 20 6d 61 79 20 6e 65 65 64 20 74 6f 20 62 65  t may need to be
02b0: 20 72 65 74 72 69 65 64 20 61 66 74 65 72 20 67   retried after g
02c0: 65 74 74 69 6e 67 20 61 20 50 49 4e 0a 20 2a 2f  etting a PIN. */
02d0: 0a 76 61 72 20 63 61 63 6b 65 79 4d 65 73 73 61  .var cackeyMessa
02e0: 67 65 73 54 6f 52 65 74 72 79 20 3d 20 5b 5d 3b  gesToRetry = [];
02f0: 0a 0a 2f 2a 0a 20 2a 20 53 74 6f 72 65 64 20 50  ../*. * Stored P
0300: 49 4e 20 66 6f 72 20 61 20 67 69 76 65 6e 20 63  IN for a given c
0310: 65 72 74 69 66 69 63 61 74 65 0a 20 2a 2f 0a 76  ertificate. */.v
0320: 61 72 20 63 61 63 6b 65 79 43 65 72 74 69 66 69  ar cackeyCertifi
0330: 63 61 74 65 54 6f 50 49 4e 4d 61 70 20 3d 20 7b  cateToPINMap = {
0340: 7d 3b 0a 76 61 72 20 63 61 63 6b 65 79 43 65 72  };.var cackeyCer
0350: 74 69 66 69 63 61 74 65 54 6f 50 49 4e 4d 61 70  tificateToPINMap
0360: 4c 61 73 74 55 73 65 64 52 75 6e 6e 65 72 20 3d  LastUsedRunner =
0370: 20 66 61 6c 73 65 3b 0a 0a 2f 2a 0a 20 2a 20 43   false;../*. * C
0380: 61 6c 6c 62 61 63 6b 73 20 74 6f 20 70 65 72 66  allbacks to perf
0390: 6f 72 6d 20 61 66 74 65 72 20 50 43 53 43 20 63  orm after PCSC c
03a0: 6f 6d 65 73 20 6f 6e 6c 69 6e 65 0a 20 2a 2f 0a  omes online. */.
03b0: 63 61 63 6b 65 79 43 61 6c 6c 62 61 63 6b 41 66  cackeyCallbackAf
03c0: 74 65 72 49 6e 69 74 20 3d 20 5b 5d 3b 0a 0a 2f  terInit = [];../
03d0: 2a 0a 20 2a 20 43 6f 6d 70 75 74 65 20 61 20 74  *. * Compute a t
03e0: 65 78 74 2d 62 61 73 65 64 20 68 61 6e 64 6c 65  ext-based handle
03f0: 20 66 6f 72 20 61 20 63 65 72 74 69 66 69 63 61   for a certifica
0400: 74 65 20 74 6f 20 62 65 20 68 61 73 68 65 64 20  te to be hashed 
0410: 62 79 0a 20 2a 2f 0a 66 75 6e 63 74 69 6f 6e 20  by. */.function 
0420: 63 61 63 6b 65 79 43 65 72 74 69 66 69 63 61 74  cackeyCertificat
0430: 65 54 6f 50 49 4e 49 44 28 63 65 72 74 69 66 69  eToPINID(certifi
0440: 63 61 74 65 29 20 7b 0a 09 76 61 72 20 69 64 3b  cate) {..var id;
0450: 0a 09 76 61 72 20 63 65 72 74 69 66 69 63 61 74  ..var certificat
0460: 65 41 72 72 61 79 3b 0a 0a 09 69 64 20 3d 20 22  eArray;...id = "
0470: 22 3b 0a 0a 09 63 65 72 74 69 66 69 63 61 74 65  ";...certificate
0480: 41 72 72 61 79 20 3d 20 6e 65 77 20 55 69 6e 74  Array = new Uint
0490: 38 41 72 72 61 79 28 63 65 72 74 69 66 69 63 61  8Array(certifica
04a0: 74 65 29 3b 0a 0a 09 63 65 72 74 69 66 69 63 61  te);...certifica
04b0: 74 65 41 72 72 61 79 2e 6d 61 70 28 0a 09 09 66  teArray.map(...f
04c0: 75 6e 63 74 69 6f 6e 28 62 79 74 65 29 20 7b 0a  unction(byte) {.
04d0: 09 09 09 69 64 20 2b 3d 20 28 22 30 22 20 2b 20  ...id += ("0" + 
04e0: 62 79 74 65 2e 74 6f 53 74 72 69 6e 67 28 31 36  byte.toString(16
04f0: 29 29 2e 73 6c 69 63 65 28 2d 32 29 3b 0a 09 09  )).slice(-2);...
0500: 7d 0a 09 29 3b 0a 0a 09 64 65 6c 65 74 65 20 63  }..);...delete c
0510: 65 72 74 69 66 69 63 61 74 65 41 72 72 61 79 3b  ertificateArray;
0520: 0a 0a 09 72 65 74 75 72 6e 28 69 64 29 3b 0a 7d  ...return(id);.}
0530: 0a 0a 2f 2a 0a 20 2a 20 48 61 6e 64 6c 65 20 61  ../*. * Handle a
0540: 20 72 65 73 70 6f 6e 73 65 20 66 72 6f 6d 20 74   response from t
0550: 68 65 20 4e 61 43 6c 20 73 69 64 65 20 72 65 67  he NaCl side reg
0560: 61 72 64 69 6e 67 20 63 65 72 74 69 66 69 63 61  arding certifica
0570: 74 65 73 20 61 76 61 69 6c 61 62 6c 65 0a 20 2a  tes available. *
0580: 2f 0a 66 75 6e 63 74 69 6f 6e 20 63 61 63 6b 65  /.function cacke
0590: 79 4d 65 73 73 61 67 65 49 6e 63 6f 6d 69 6e 67  yMessageIncoming
05a0: 4c 69 73 74 43 65 72 74 69 66 69 63 61 74 65 73  ListCertificates
05b0: 28 6d 65 73 73 61 67 65 2c 20 63 68 72 6f 6d 65  (message, chrome
05c0: 43 61 6c 6c 62 61 63 6b 29 20 7b 0a 09 76 61 72  Callback) {..var
05d0: 20 69 64 78 3b 0a 09 76 61 72 20 63 65 72 74 69   idx;..var certi
05e0: 66 69 63 61 74 65 73 20 3d 20 5b 5d 3b 0a 0a 09  ficates = [];...
05f0: 66 6f 72 20 28 69 64 78 20 3d 20 30 3b 20 69 64  for (idx = 0; id
0600: 78 20 3c 20 6d 65 73 73 61 67 65 2e 63 65 72 74  x < message.cert
0610: 69 66 69 63 61 74 65 73 2e 6c 65 6e 67 74 68 3b  ificates.length;
0620: 20 69 64 78 2b 2b 29 20 7b 0a 09 09 63 65 72 74   idx++) {...cert
0630: 69 66 69 63 61 74 65 73 2e 70 75 73 68 28 0a 09  ificates.push(..
0640: 09 09 7b 0a 09 09 09 09 63 65 72 74 69 66 69 63  ..{.....certific
0650: 61 74 65 3a 20 6d 65 73 73 61 67 65 2e 63 65 72  ate: message.cer
0660: 74 69 66 69 63 61 74 65 73 5b 69 64 78 5d 2c 0a  tificates[idx],.
0670: 09 09 09 09 73 75 70 70 6f 72 74 65 64 48 61 73  ....supportedHas
0680: 68 65 73 3a 20 5b 27 53 48 41 31 27 2c 20 27 53  hes: ['SHA1', 'S
0690: 48 41 32 35 36 27 2c 20 27 4d 44 35 5f 53 48 41  HA256', 'MD5_SHA
06a0: 31 27 5d 0a 09 09 09 7d 0a 09 09 29 3b 0a 09 7d  1']....}...);..}
06b0: 0a 0a 09 63 68 72 6f 6d 65 43 61 6c 6c 62 61 63  ...chromeCallbac
06c0: 6b 28 63 65 72 74 69 66 69 63 61 74 65 73 2c 0a  k(certificates,.
06d0: 09 09 66 75 6e 63 74 69 6f 6e 28 72 65 6a 65 63  ..function(rejec
06e0: 74 65 64 43 65 72 74 73 29 20 7b 0a 09 09 09 69  tedCerts) {....i
06f0: 66 20 28 63 68 72 6f 6d 65 2e 72 75 6e 74 69 6d  f (chrome.runtim
0700: 65 2e 6c 61 73 74 45 72 72 6f 72 29 20 7b 0a 09  e.lastError) {..
0710: 09 09 09 72 65 74 75 72 6e 3b 0a 09 09 09 7d 0a  ...return;....}.
0720: 0a 09 09 09 69 66 20 28 72 65 6a 65 63 74 65 64  ....if (rejected
0730: 43 65 72 74 73 2e 6c 65 6e 67 74 68 20 21 3d 3d  Certs.length !==
0740: 20 30 29 20 7b 0a 09 09 09 09 6f 6e 43 65 72 74   0) {.....onCert
0750: 69 66 69 63 61 74 65 73 52 65 6a 65 63 74 65 64  ificatesRejected
0760: 28 72 65 6a 65 63 74 65 64 43 65 72 74 73 29 3b  (rejectedCerts);
0770: 0a 09 09 09 7d 0a 0a 09 09 09 72 65 74 75 72 6e  ....}.....return
0780: 3b 0a 09 09 7d 0a 09 29 3b 0a 0a 09 72 65 74 75  ;...}..);...retu
0790: 72 6e 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 20 48 61 6e  rn;.}../*. * Han
07a0: 64 6c 65 20 61 20 72 65 73 70 6f 6e 73 65 20 66  dle a response f
07b0: 72 6f 6d 20 74 68 65 20 4e 61 43 6c 20 73 69 64  rom the NaCl sid
07c0: 65 20 72 65 67 61 72 64 69 6e 67 20 73 69 67 6e  e regarding sign
07d0: 69 6e 67 20 61 20 6d 65 73 73 61 67 65 0a 20 2a  ing a message. *
07e0: 2f 0a 66 75 6e 63 74 69 6f 6e 20 63 61 63 6b 65  /.function cacke
07f0: 79 4d 65 73 73 61 67 65 49 6e 63 6f 6d 69 6e 67  yMessageIncoming
0800: 53 69 67 6e 4d 65 73 73 61 67 65 28 6d 65 73 73  SignMessage(mess
0810: 61 67 65 2c 20 63 68 72 6f 6d 65 43 61 6c 6c 62  age, chromeCallb
0820: 61 63 6b 29 20 7b 0a 09 76 61 72 20 70 61 79 6c  ack) {..var payl
0830: 6f 61 64 3b 0a 0a 09 70 61 79 6c 6f 61 64 20 3d  oad;...payload =
0840: 20 6d 65 73 73 61 67 65 2e 73 69 67 6e 65 64 44   message.signedD
0850: 61 74 61 3b 0a 0a 09 63 68 72 6f 6d 65 43 61 6c  ata;...chromeCal
0860: 6c 62 61 63 6b 28 70 61 79 6c 6f 61 64 29 3b 0a  lback(payload);.
0870: 0a 09 72 65 74 75 72 6e 3b 0a 7d 0a 0a 2f 2a 0a  ..return;.}../*.
0880: 20 2a 20 55 70 64 61 74 65 20 74 68 65 20 74 69   * Update the ti
0890: 6d 65 20 61 20 50 49 4e 20 77 61 73 20 6c 61 73  me a PIN was las
08a0: 74 20 75 73 65 64 20 66 6f 72 20 61 20 63 65 72  t used for a cer
08b0: 74 69 66 69 63 61 74 65 0a 20 2a 2f 0a 66 75 6e  tificate. */.fun
08c0: 63 74 69 6f 6e 20 63 61 63 6b 65 79 43 65 72 74  ction cackeyCert
08d0: 69 66 69 63 61 74 65 54 6f 50 49 4e 4d 61 70 55  ificateToPINMapU
08e0: 70 64 61 74 65 4c 61 73 74 55 73 65 64 28 69 64  pdateLastUsed(id
08f0: 29 20 7b 0a 09 69 66 20 28 69 64 20 21 3d 20 6e  ) {..if (id != n
0900: 75 6c 6c 29 20 7b 0a 09 09 63 61 63 6b 65 79 43  ull) {...cackeyC
0910: 65 72 74 69 66 69 63 61 74 65 54 6f 50 49 4e 4d  ertificateToPINM
0920: 61 70 5b 69 64 5d 2e 6c 61 73 74 55 73 65 64 20  ap[id].lastUsed 
0930: 3d 20 28 6e 65 77 20 44 61 74 65 28 29 29 2e 67  = (new Date()).g
0940: 65 74 54 69 6d 65 28 29 3b 0a 09 7d 0a 0a 09 69  etTime();..}...i
0950: 66 20 28 21 63 61 63 6b 65 79 43 65 72 74 69 66  f (!cackeyCertif
0960: 69 63 61 74 65 54 6f 50 49 4e 4d 61 70 4c 61 73  icateToPINMapLas
0970: 74 55 73 65 64 52 75 6e 6e 65 72 29 20 7b 0a 09  tUsedRunner) {..
0980: 09 63 61 63 6b 65 79 43 65 72 74 69 66 69 63 61  .cackeyCertifica
0990: 74 65 54 6f 50 49 4e 4d 61 70 4c 61 73 74 55 73  teToPINMapLastUs
09a0: 65 64 52 75 6e 6e 65 72 20 3d 20 74 72 75 65 3b  edRunner = true;
09b0: 0a 0a 09 09 73 65 74 54 69 6d 65 6f 75 74 28 66  ....setTimeout(f
09c0: 75 6e 63 74 69 6f 6e 28 29 20 7b 0a 09 09 09 76  unction() {....v
09d0: 61 72 20 63 75 72 72 65 6e 74 54 69 6d 65 3b 0a  ar currentTime;.
09e0: 09 09 09 76 61 72 20 63 65 72 74 69 66 69 63 61  ...var certifica
09f0: 74 65 73 2c 20 63 65 72 74 69 66 69 63 61 74 65  tes, certificate
0a00: 3b 0a 09 09 09 76 61 72 20 69 64 78 3b 0a 0a 09  ;....var idx;...
0a10: 09 09 63 75 72 72 65 6e 74 54 69 6d 65 20 3d 20  ..currentTime = 
0a20: 28 6e 65 77 20 44 61 74 65 28 29 29 2e 67 65 74  (new Date()).get
0a30: 54 69 6d 65 28 29 3b 0a 0a 09 09 09 63 65 72 74  Time();.....cert
0a40: 69 66 69 63 61 74 65 73 20 3d 20 4f 62 6a 65 63  ificates = Objec
0a50: 74 2e 6b 65 79 73 28 63 61 63 6b 65 79 43 65 72  t.keys(cackeyCer
0a60: 74 69 66 69 63 61 74 65 54 6f 50 49 4e 4d 61 70  tificateToPINMap
0a70: 29 3b 0a 0a 09 09 09 63 6f 6e 73 6f 6c 65 2e 6c  );.....console.l
0a80: 6f 67 28 22 4c 6f 6f 6b 69 6e 67 20 66 6f 72 20  og("Looking for 
0a90: 50 49 4e 73 20 74 6f 20 63 6c 65 61 72 22 29 3b  PINs to clear");
0aa0: 0a 0a 09 09 09 66 6f 72 20 28 69 64 78 20 3d 20  .....for (idx = 
0ab0: 30 3b 20 69 64 78 20 3c 20 63 65 72 74 69 66 69  0; idx < certifi
0ac0: 63 61 74 65 73 2e 6c 65 6e 67 74 68 3b 20 69 64  cates.length; id
0ad0: 78 2b 2b 29 20 7b 0a 09 09 09 09 63 65 72 74 69  x++) {.....certi
0ae0: 66 69 63 61 74 65 20 3d 20 63 65 72 74 69 66 69  ficate = certifi
0af0: 63 61 74 65 73 5b 69 64 78 5d 3b 0a 0a 09 09 09  cates[idx];.....
0b00: 09 69 66 20 28 28 63 61 63 6b 65 79 43 65 72 74  .if ((cackeyCert
0b10: 69 66 69 63 61 74 65 54 6f 50 49 4e 4d 61 70 5b  ificateToPINMap[
0b20: 63 65 72 74 69 66 69 63 61 74 65 5d 2e 6c 61 73  certificate].las
0b30: 74 55 73 65 64 20 2b 20 39 30 30 30 30 30 29 20  tUsed + 900000) 
0b40: 3e 20 63 75 72 72 65 6e 74 54 69 6d 65 29 20 7b  > currentTime) {
0b50: 0a 09 09 09 09 09 63 6f 6e 74 69 6e 75 65 3b 0a  ......continue;.
0b60: 09 09 09 09 7d 0a 0a 09 09 09 09 63 6f 6e 73 6f  ....}......conso
0b70: 6c 65 2e 6c 6f 67 28 22 44 65 6c 65 74 65 74 69  le.log("Deleteti
0b80: 6e 67 20 22 20 2b 20 63 65 72 74 69 66 69 63 61  ng " + certifica
0b90: 74 65 29 3b 0a 0a 09 09 09 09 64 65 6c 65 74 65  te);......delete
0ba0: 20 63 61 63 6b 65 79 43 65 72 74 69 66 69 63 61   cackeyCertifica
0bb0: 74 65 54 6f 50 49 4e 4d 61 70 5b 63 65 72 74 69  teToPINMap[certi
0bc0: 66 69 63 61 74 65 5d 3b 0a 09 09 09 7d 0a 0a 09  ficate];....}...
0bd0: 09 09 63 65 72 74 69 66 69 63 61 74 65 73 20 3d  ..certificates =
0be0: 20 4f 62 6a 65 63 74 2e 6b 65 79 73 28 63 61 63   Object.keys(cac
0bf0: 6b 65 79 43 65 72 74 69 66 69 63 61 74 65 54 6f  keyCertificateTo
0c00: 50 49 4e 4d 61 70 29 3b 0a 0a 09 09 09 63 61 63  PINMap);.....cac
0c10: 6b 65 79 43 65 72 74 69 66 69 63 61 74 65 54 6f  keyCertificateTo
0c20: 50 49 4e 4d 61 70 4c 61 73 74 55 73 65 64 52 75  PINMapLastUsedRu
0c30: 6e 6e 65 72 20 3d 20 66 61 6c 73 65 3b 0a 0a 09  nner = false;...
0c40: 09 09 69 66 20 28 63 65 72 74 69 66 69 63 61 74  ..if (certificat
0c50: 65 73 2e 6c 65 6e 67 74 68 20 3d 3d 20 30 29 20  es.length == 0) 
0c60: 7b 0a 09 09 09 09 72 65 74 75 72 6e 3b 0a 09 09  {.....return;...
0c70: 09 7d 0a 0a 09 09 09 63 61 63 6b 65 79 43 65 72  .}.....cackeyCer
0c80: 74 69 66 69 63 61 74 65 54 6f 50 49 4e 4d 61 70  tificateToPINMap
0c90: 55 70 64 61 74 65 4c 61 73 74 55 73 65 64 28 6e  UpdateLastUsed(n
0ca0: 75 6c 6c 29 3b 0a 09 09 7d 2c 20 39 30 30 30 30  ull);...}, 90000
0cb0: 30 29 3b 0a 09 7d 0a 7d 0a 0a 2f 2a 0a 20 2a 20  0);..}.}../*. * 
0cc0: 48 61 6e 64 6c 65 20 61 6e 20 69 6e 63 6f 6d 69  Handle an incomi
0cd0: 6e 67 20 6d 65 73 73 61 67 65 20 66 72 6f 6d 20  ng message from 
0ce0: 74 68 65 20 4e 61 43 6c 20 73 69 64 65 20 61 6e  the NaCl side an
0cf0: 64 20 70 61 73 73 20 69 74 20 6f 66 66 20 74 6f  d pass it off to
0d00: 0a 20 2a 20 6f 6e 65 20 6f 66 20 74 68 65 20 68  . * one of the h
0d10: 61 6e 64 6c 65 72 73 20 61 62 6f 76 65 20 66 6f  andlers above fo
0d20: 72 20 61 63 74 75 61 6c 20 66 6f 72 6d 61 74 74  r actual formatt
0d30: 69 6e 67 20 61 6e 64 20 70 61 73 73 69 6e 67 20  ing and passing 
0d40: 74 6f 0a 20 2a 20 74 68 65 20 63 61 6c 6c 62 61  to. * the callba
0d50: 63 6b 0a 20 2a 0a 20 2a 20 49 66 20 61 6e 20 65  ck. *. * If an e
0d60: 72 72 6f 72 20 6f 63 63 75 72 65 64 2c 20 69 6e  rror occured, in
0d70: 76 6f 6b 65 20 74 68 65 20 63 61 6c 6c 62 61 63  voke the callbac
0d80: 6b 20 77 69 74 68 20 6e 6f 20 61 72 67 75 6d 65  k with no argume
0d90: 6e 74 73 2e 0a 20 2a 2f 0a 66 75 6e 63 74 69 6f  nts.. */.functio
0da0: 6e 20 63 61 63 6b 65 79 4d 65 73 73 61 67 65 49  n cackeyMessageI
0db0: 6e 63 6f 6d 69 6e 67 28 6d 65 73 73 61 67 65 45  ncoming(messageE
0dc0: 76 65 6e 74 29 20 7b 0a 09 76 61 72 20 6e 65 78  vent) {..var nex
0dd0: 74 46 75 6e 63 74 69 6f 6e 20 3d 20 6e 75 6c 6c  tFunction = null
0de0: 3b 0a 09 76 61 72 20 63 68 72 6f 6d 65 43 61 6c  ;..var chromeCal
0df0: 6c 62 61 63 6b 20 3d 20 6e 75 6c 6c 3b 0a 0a 09  lback = null;...
0e00: 69 66 20 28 6d 65 73 73 61 67 65 45 76 65 6e 74  if (messageEvent
0e10: 2e 64 61 74 61 2e 74 61 72 67 65 74 20 21 3d 20  .data.target != 
0e20: 22 63 61 63 6b 65 79 22 29 20 7b 0a 09 09 72 65  "cackey") {...re
0e30: 74 75 72 6e 3b 0a 09 7d 0a 0a 09 69 66 20 28 47  turn;..}...if (G
0e40: 6f 6f 67 6c 65 53 6d 61 72 74 43 61 72 64 2e 49  oogleSmartCard.I
0e50: 53 5f 44 45 42 55 47 5f 42 55 49 4c 44 29 20 7b  S_DEBUG_BUILD) {
0e60: 0a 09 09 63 6f 6e 73 6f 6c 65 2e 6c 6f 67 28 22  ...console.log("
0e70: 53 54 41 52 54 20 4d 45 53 53 41 47 45 22 29 3b  START MESSAGE");
0e80: 0a 09 09 63 6f 6e 73 6f 6c 65 2e 6c 6f 67 28 6d  ...console.log(m
0e90: 65 73 73 61 67 65 45 76 65 6e 74 2e 64 61 74 61  essageEvent.data
0ea0: 29 3b 0a 09 09 63 6f 6e 73 6f 6c 65 2e 6c 6f 67  );...console.log
0eb0: 28 22 45 4e 44 20 4d 45 53 53 41 47 45 22 29 3b  ("END MESSAGE");
0ec0: 0a 09 7d 0a 0a 09 2f 2a 0a 09 20 2a 20 49 66 20  ..}.../*.. * If 
0ed0: 77 65 20 66 61 69 6c 65 64 20 66 6f 72 20 73 6f  we failed for so
0ee0: 6d 65 20 72 65 61 73 6f 6e 20 61 6e 64 20 77 65  me reason and we
0ef0: 20 68 61 76 65 20 61 20 63 65 72 74 69 66 69 63   have a certific
0f00: 61 74 65 20 69 6e 20 74 68 65 20 6f 72 69 67 69  ate in the origi
0f10: 6e 61 6c 0a 09 20 2a 20 72 65 71 75 65 73 74 20  nal.. * request 
0f20: 74 68 65 6e 20 66 6f 72 67 65 74 20 61 6e 79 20  then forget any 
0f30: 50 49 4e 20 61 73 73 6f 63 69 61 74 65 64 20 77  PIN associated w
0f40: 69 74 68 20 74 68 61 74 20 63 65 72 74 69 66 69  ith that certifi
0f50: 63 61 74 65 0a 09 20 2a 2f 0a 09 69 66 20 28 6d  cate.. */..if (m
0f60: 65 73 73 61 67 65 45 76 65 6e 74 2e 64 61 74 61  essageEvent.data
0f70: 2e 73 74 61 74 75 73 20 21 3d 20 22 73 75 63 63  .status != "succ
0f80: 65 73 73 22 29 20 7b 0a 09 09 69 66 20 28 6d 65  ess") {...if (me
0f90: 73 73 61 67 65 45 76 65 6e 74 2e 64 61 74 61 2e  ssageEvent.data.
0fa0: 6f 72 69 67 69 6e 61 6c 72 65 71 75 65 73 74 29  originalrequest)
0fb0: 20 7b 0a 09 09 09 69 66 20 28 6d 65 73 73 61 67   {....if (messag
0fc0: 65 45 76 65 6e 74 2e 64 61 74 61 2e 6f 72 69 67  eEvent.data.orig
0fd0: 69 6e 61 6c 72 65 71 75 65 73 74 2e 63 65 72 74  inalrequest.cert
0fe0: 69 66 69 63 61 74 65 29 20 7b 0a 09 09 09 09 64  ificate) {.....d
0ff0: 65 6c 65 74 65 20 63 61 63 6b 65 79 43 65 72 74  elete cackeyCert
1000: 69 66 69 63 61 74 65 54 6f 50 49 4e 4d 61 70 5b  ificateToPINMap[
1010: 63 61 63 6b 65 79 43 65 72 74 69 66 69 63 61 74  cackeyCertificat
1020: 65 54 6f 50 49 4e 49 44 28 6d 65 73 73 61 67 65  eToPINID(message
1030: 45 76 65 6e 74 2e 64 61 74 61 2e 6f 72 69 67 69  Event.data.origi
1040: 6e 61 6c 72 65 71 75 65 73 74 2e 63 65 72 74 69  nalrequest.certi
1050: 66 69 63 61 74 65 29 5d 3b 0a 09 09 09 7d 0a 09  ficate)];....}..
1060: 09 7d 0a 09 7d 0a 0a 09 69 66 20 28 6d 65 73 73  .}..}...if (mess
1070: 61 67 65 45 76 65 6e 74 2e 64 61 74 61 2e 63 6f  ageEvent.data.co
1080: 6d 6d 61 6e 64 20 3d 3d 20 22 69 6e 69 74 22 20  mmand == "init" 
1090: 26 26 20 6d 65 73 73 61 67 65 45 76 65 6e 74 2e  && messageEvent.
10a0: 64 61 74 61 2e 73 74 61 74 75 73 20 3d 3d 20 22  data.status == "
10b0: 73 75 63 63 65 73 73 22 29 20 7b 0a 09 09 69 66  success") {...if
10c0: 20 28 47 6f 6f 67 6c 65 53 6d 61 72 74 43 61 72   (GoogleSmartCar
10d0: 64 2e 49 53 5f 44 45 42 55 47 5f 42 55 49 4c 44  d.IS_DEBUG_BUILD
10e0: 29 20 7b 0a 09 09 09 63 6f 6e 73 6f 6c 65 2e 6c  ) {....console.l
10f0: 6f 67 28 22 5b 63 61 63 6b 65 79 5d 20 49 6e 69  og("[cackey] Ini
1100: 74 69 61 6c 69 7a 61 74 69 6f 6e 20 63 6f 6d 70  tialization comp
1110: 6c 65 74 65 64 2c 20 72 65 73 65 6e 64 69 6e 67  leted, resending
1120: 20 61 6e 79 20 71 75 65 75 65 64 20 6d 65 73 73   any queued mess
1130: 61 67 65 73 22 29 3b 0a 09 09 7d 0a 0a 09 09 63  ages");...}....c
1140: 61 63 6b 65 79 49 6e 69 74 50 43 53 43 43 6f 6d  ackeyInitPCSCCom
1150: 70 6c 65 74 65 64 28 22 73 75 63 63 65 73 73 22  pleted("success"
1160: 29 3b 0a 09 7d 0a 0a 09 69 66 20 28 6d 65 73 73  );..}...if (mess
1170: 61 67 65 45 76 65 6e 74 2e 64 61 74 61 2e 69 64  ageEvent.data.id
1180: 20 3d 3d 20 6e 75 6c 6c 29 20 7b 0a 09 09 72 65   == null) {...re
1190: 74 75 72 6e 3b 0a 09 7d 0a 0a 09 63 68 72 6f 6d  turn;..}...chrom
11a0: 65 43 61 6c 6c 62 61 63 6b 20 3d 20 63 61 63 6b  eCallback = cack
11b0: 65 79 4f 75 74 73 74 61 6e 64 69 6e 67 43 61 6c  eyOutstandingCal
11c0: 6c 62 61 63 6b 73 5b 6d 65 73 73 61 67 65 45 76  lbacks[messageEv
11d0: 65 6e 74 2e 64 61 74 61 2e 69 64 5d 3b 0a 0a 09  ent.data.id];...
11e0: 69 66 20 28 63 68 72 6f 6d 65 43 61 6c 6c 62 61  if (chromeCallba
11f0: 63 6b 20 3d 3d 20 6e 75 6c 6c 29 20 7b 0a 09 09  ck == null) {...
1200: 63 6f 6e 73 6f 6c 65 2e 65 72 72 6f 72 28 22 5b  console.error("[
1210: 63 61 63 6b 65 79 5d 20 44 69 73 63 61 72 64 69  cackey] Discardi
1220: 6e 67 20 6f 75 74 64 61 74 65 64 20 6d 65 73 73  ng outdated mess
1230: 61 67 65 22 29 3b 0a 0a 09 09 72 65 74 75 72 6e  age");....return
1240: 3b 0a 09 7d 0a 0a 09 73 77 69 74 63 68 20 28 6d  ;..}...switch (m
1250: 65 73 73 61 67 65 45 76 65 6e 74 2e 64 61 74 61  essageEvent.data
1260: 2e 73 74 61 74 75 73 29 20 7b 0a 09 09 63 61 73  .status) {...cas
1270: 65 20 22 65 72 72 6f 72 22 3a 0a 09 09 09 63 6f  e "error":....co
1280: 6e 73 6f 6c 65 2e 65 72 72 6f 72 28 22 5b 63 61  nsole.error("[ca
1290: 63 6b 65 79 5d 20 46 61 69 6c 65 64 20 74 6f 20  ckey] Failed to 
12a0: 65 78 65 63 75 74 65 20 63 6f 6d 6d 61 6e 64 20  execute command 
12b0: 27 22 20 2b 20 6d 65 73 73 61 67 65 45 76 65 6e  '" + messageEven
12c0: 74 2e 64 61 74 61 2e 63 6f 6d 6d 61 6e 64 20 2b  t.data.command +
12d0: 20 22 27 3a 20 22 20 2b 20 6d 65 73 73 61 67 65   "': " + message
12e0: 45 76 65 6e 74 2e 64 61 74 61 2e 65 72 72 6f 72  Event.data.error
12f0: 29 3b 0a 0a 09 09 09 63 68 72 6f 6d 65 43 61 6c  );.....chromeCal
1300: 6c 62 61 63 6b 28 29 3b 0a 0a 09 09 09 62 72 65  lback();.....bre
1310: 61 6b 3b 0a 09 09 63 61 73 65 20 22 72 65 74 72  ak;...case "retr
1320: 79 22 3a 0a 09 09 09 2f 2a 0a 09 09 09 20 2a 20  y":..../*.... * 
1330: 41 64 64 20 74 68 65 20 6e 65 77 20 72 65 71 75  Add the new requ
1340: 65 73 74 20 74 6f 20 74 68 65 20 71 75 65 75 65  est to the queue
1350: 20 6f 66 20 65 76 65 6e 74 73 20 74 6f 20 70 72   of events to pr
1360: 6f 63 65 73 73 20 77 68 65 6e 20 74 68 65 20 50  ocess when the P
1370: 49 4e 0a 09 09 09 20 2a 20 70 72 6f 6d 70 74 20  IN.... * prompt 
1380: 69 73 20 74 65 72 6d 69 6e 61 74 65 64 2e 0a 09  is terminated...
1390: 09 09 20 2a 2f 0a 09 09 09 63 61 63 6b 65 79 4d  .. */....cackeyM
13a0: 65 73 73 61 67 65 73 54 6f 52 65 74 72 79 2e 70  essagesToRetry.p
13b0: 75 73 68 28 6d 65 73 73 61 67 65 45 76 65 6e 74  ush(messageEvent
13c0: 29 3b 0a 0a 09 09 09 69 66 20 28 70 69 6e 57 69  );.....if (pinWi
13d0: 6e 64 6f 77 50 72 65 76 69 6f 75 73 48 61 6e 64  ndowPreviousHand
13e0: 6c 65 29 20 7b 0a 09 09 09 09 2f 2a 0a 09 09 09  le) {...../*....
13f0: 09 20 2a 20 41 6e 20 65 78 69 73 74 69 6e 67 20  . * An existing 
1400: 50 49 4e 20 65 6e 74 72 79 20 69 73 20 69 6e 20  PIN entry is in 
1410: 70 72 6f 67 72 65 73 73 0a 09 09 09 09 20 2a 20  progress..... * 
1420: 4a 75 73 74 20 61 64 64 20 74 68 65 20 72 65 71  Just add the req
1430: 75 65 73 74 20 74 6f 20 74 68 65 20 71 75 65 75  uest to the queu
1440: 65 20 28 61 62 6f 76 65 29 20 61 6e 64 20 77 61  e (above) and wa
1450: 69 74 0a 09 09 09 09 20 2a 2f 0a 0a 09 09 09 09  it..... */......
1460: 72 65 74 75 72 6e 3b 0a 09 09 09 7d 0a 0a 09 09  return;....}....
1470: 09 2f 2a 0a 09 09 09 20 2a 20 53 65 74 20 74 68  ./*.... * Set th
1480: 65 20 68 61 6e 64 6c 65 20 74 6f 20 61 6e 20 69  e handle to an i
1490: 6e 76 61 6c 69 64 20 28 62 75 74 20 6e 6f 6e 2d  nvalid (but non-
14a0: 6e 75 6c 6c 29 20 76 61 6c 75 65 20 75 6e 74 69  null) value unti
14b0: 6c 20 74 68 65 20 77 69 6e 64 6f 77 0a 09 09 09  l the window....
14c0: 20 2a 20 69 73 20 63 72 65 61 74 65 64 20 69 6e   * is created in
14d0: 20 63 61 73 65 20 77 65 20 61 72 65 20 69 6e 76   case we are inv
14e0: 6f 6b 65 64 20 61 67 61 69 6e 20 73 6f 6f 6e 2e  oked again soon.
14f0: 0a 09 09 09 20 2a 2f 0a 09 09 09 70 69 6e 57 69  .... */....pinWi
1500: 6e 64 6f 77 50 72 65 76 69 6f 75 73 48 61 6e 64  ndowPreviousHand
1510: 6c 65 20 3d 20 22 69 6e 76 61 6c 69 64 22 3b 0a  le = "invalid";.
1520: 0a 09 09 09 63 68 72 6f 6d 65 2e 61 70 70 2e 77  ....chrome.app.w
1530: 69 6e 64 6f 77 2e 63 72 65 61 74 65 28 22 70 69  indow.create("pi
1540: 6e 2e 68 74 6d 6c 22 2c 20 7b 0a 09 09 09 09 22  n.html", {....."
1550: 69 64 22 3a 20 22 63 61 63 6b 65 79 50 49 4e 45  id": "cackeyPINE
1560: 6e 74 72 79 22 2c 0a 09 09 09 09 22 72 65 73 69  ntry",....."resi
1570: 7a 61 62 6c 65 22 3a 20 66 61 6c 73 65 2c 0a 09  zable": false,..
1580: 09 09 09 22 61 6c 77 61 79 73 4f 6e 54 6f 70 22  ..."alwaysOnTop"
1590: 3a 20 74 72 75 65 2c 0a 09 09 09 09 22 66 6f 63  : true,....."foc
15a0: 75 73 65 64 22 3a 20 74 72 75 65 2c 0a 09 09 09  used": true,....
15b0: 09 22 76 69 73 69 62 6c 65 4f 6e 41 6c 6c 57 6f  ."visibleOnAllWo
15c0: 72 6b 73 70 61 63 65 73 22 3a 20 74 72 75 65 2c  rkspaces": true,
15d0: 0a 09 09 09 09 22 69 6e 6e 65 72 42 6f 75 6e 64  ....."innerBound
15e0: 73 22 3a 20 7b 0a 09 09 09 09 09 22 77 69 64 74  s": {......"widt
15f0: 68 22 3a 20 33 35 30 2c 0a 09 09 09 09 09 22 6d  h": 350,......"m
1600: 69 6e 57 69 64 74 68 22 3a 20 33 35 30 2c 0a 09  inWidth": 350,..
1610: 09 09 09 09 22 68 65 69 67 68 74 22 3a 20 31 33  ...."height": 13
1620: 35 2c 0a 09 09 09 09 09 22 6d 69 6e 48 65 69 67  5,......"minHeig
1630: 68 74 22 3a 20 31 33 35 0a 09 09 09 09 7d 0a 09  ht": 135.....}..
1640: 09 09 7d 2c 20 66 75 6e 63 74 69 6f 6e 28 70 69  ..}, function(pi
1650: 6e 57 69 6e 64 6f 77 29 20 7b 0a 09 09 09 09 2f  nWindow) {...../
1660: 2a 0a 09 09 09 09 20 2a 20 53 65 74 20 74 68 65  *..... * Set the
1670: 20 50 49 4e 20 76 61 6c 75 65 20 74 6f 20 62 6c   PIN value to bl
1680: 61 6e 6b 0a 09 09 09 09 20 2a 2f 0a 09 09 09 09  ank..... */.....
1690: 70 69 6e 57 69 6e 64 6f 77 50 49 4e 56 61 6c 75  pinWindowPINValu
16a0: 65 20 3d 20 22 22 3b 0a 0a 09 09 09 09 69 66 20  e = "";......if 
16b0: 28 21 70 69 6e 57 69 6e 64 6f 77 29 20 7b 0a 09  (!pinWindow) {..
16c0: 09 09 09 09 63 6f 6e 73 6f 6c 65 2e 65 72 72 6f  ....console.erro
16d0: 72 28 22 5b 63 61 63 6b 65 79 5d 20 4e 6f 20 77  r("[cackey] No w
16e0: 69 6e 64 6f 77 20 77 61 73 20 70 72 6f 76 69 64  indow was provid
16f0: 65 64 20 66 6f 72 20 50 49 4e 20 65 6e 74 72 79  ed for PIN entry
1700: 2c 20 74 68 69 73 20 77 69 6c 6c 20 6e 6f 74 20  , this will not 
1710: 67 6f 20 77 65 6c 6c 2e 22 29 3b 0a 0a 09 09 09  go well.");.....
1720: 09 09 72 65 74 75 72 6e 3b 0a 09 09 09 09 7d 0a  ..return;.....}.
1730: 0a 09 09 09 09 70 69 6e 57 69 6e 64 6f 77 50 72  .....pinWindowPr
1740: 65 76 69 6f 75 73 48 61 6e 64 6c 65 20 3d 20 70  eviousHandle = p
1750: 69 6e 57 69 6e 64 6f 77 3b 0a 0a 09 09 09 09 70  inWindow;......p
1760: 69 6e 57 69 6e 64 6f 77 2e 64 72 61 77 41 74 74  inWindow.drawAtt
1770: 65 6e 74 69 6f 6e 28 29 3b 0a 09 09 09 09 70 69  ention();.....pi
1780: 6e 57 69 6e 64 6f 77 2e 66 6f 63 75 73 28 29 3b  nWindow.focus();
1790: 0a 0a 09 09 09 09 2f 2a 0a 09 09 09 09 20 2a 20  ....../*..... * 
17a0: 52 65 67 69 73 74 65 72 20 61 20 68 61 6e 64 6c  Register a handl
17b0: 65 72 20 74 6f 20 68 61 6e 64 6c 65 20 74 68 65  er to handle the
17c0: 20 77 69 6e 64 6f 77 20 62 65 69 6e 67 20 63 6c   window being cl
17d0: 6f 73 65 64 20 77 69 74 68 6f 75 74 0a 09 09 09  osed without....
17e0: 09 20 2a 20 68 61 76 69 6e 67 20 73 65 6e 74 20  . * having sent 
17f0: 61 6e 79 74 68 69 6e 67 0a 09 09 09 09 20 2a 2f  anything..... */
1800: 0a 09 09 09 09 70 69 6e 57 69 6e 64 6f 77 2e 6f  .....pinWindow.o
1810: 6e 43 6c 6f 73 65 64 2e 61 64 64 4c 69 73 74 65  nClosed.addListe
1820: 6e 65 72 28 66 75 6e 63 74 69 6f 6e 28 29 20 7b  ner(function() {
1830: 0a 09 09 09 09 09 76 61 72 20 6d 65 73 73 61 67  ......var messag
1840: 65 49 64 78 3b 0a 09 09 09 09 09 76 61 72 20 63  eIdx;......var c
1850: 68 72 6f 6d 65 43 61 6c 6c 62 61 63 6b 3b 0a 0a  hromeCallback;..
1860: 09 09 09 09 09 70 69 6e 57 69 6e 64 6f 77 50 72  .....pinWindowPr
1870: 65 76 69 6f 75 73 48 61 6e 64 6c 65 20 3d 20 6e  eviousHandle = n
1880: 75 6c 6c 3b 0a 0a 09 09 09 09 09 66 6f 72 20 28  ull;.......for (
1890: 6d 65 73 73 61 67 65 49 64 78 20 3d 20 30 3b 20  messageIdx = 0; 
18a0: 6d 65 73 73 61 67 65 49 64 78 20 3c 20 63 61 63  messageIdx < cac
18b0: 6b 65 79 4d 65 73 73 61 67 65 73 54 6f 52 65 74  keyMessagesToRet
18c0: 72 79 2e 6c 65 6e 67 74 68 3b 20 6d 65 73 73 61  ry.length; messa
18d0: 67 65 49 64 78 2b 2b 29 20 7b 0a 09 09 09 09 09  geIdx++) {......
18e0: 09 76 61 72 20 74 6d 70 4d 65 73 73 61 67 65 45  .var tmpMessageE
18f0: 76 65 6e 74 3b 0a 0a 09 09 09 09 09 09 74 6d 70  vent;........tmp
1900: 4d 65 73 73 61 67 65 45 76 65 6e 74 20 3d 20 63  MessageEvent = c
1910: 61 63 6b 65 79 4d 65 73 73 61 67 65 73 54 6f 52  ackeyMessagesToR
1920: 65 74 72 79 5b 6d 65 73 73 61 67 65 49 64 78 5d  etry[messageIdx]
1930: 3b 0a 0a 09 09 09 09 09 09 69 66 20 28 70 69 6e  ;........if (pin
1940: 57 69 6e 64 6f 77 50 49 4e 56 61 6c 75 65 20 3d  WindowPINValue =
1950: 3d 20 22 22 29 20 7b 0a 09 09 09 09 09 09 09 69  = "") {........i
1960: 66 20 28 47 6f 6f 67 6c 65 53 6d 61 72 74 43 61  f (GoogleSmartCa
1970: 72 64 2e 49 53 5f 44 45 42 55 47 5f 42 55 49 4c  rd.IS_DEBUG_BUIL
1980: 44 29 20 7b 0a 09 09 09 09 09 09 09 09 63 6f 6e  D) {.........con
1990: 73 6f 6c 65 2e 6c 6f 67 28 22 5b 63 61 63 6b 65  sole.log("[cacke
19a0: 79 5d 20 54 68 65 20 50 49 4e 20 64 69 61 6c 6f  y] The PIN dialo
19b0: 67 20 77 61 73 20 63 6c 6f 73 65 64 20 77 69 74  g was closed wit
19c0: 68 6f 75 74 20 67 61 74 68 65 72 69 6e 67 20 61  hout gathering a
19d0: 20 50 49 4e 2c 20 74 72 65 61 74 69 6e 67 20 69   PIN, treating i
19e0: 74 20 61 73 20 61 20 66 61 69 6c 75 72 65 2e 22  t as a failure."
19f0: 29 3b 0a 09 09 09 09 09 09 09 7d 0a 0a 09 09 09  );........}.....
1a00: 09 09 09 09 74 6d 70 4d 65 73 73 61 67 65 45 76  ....tmpMessageEv
1a10: 65 6e 74 2e 64 61 74 61 2e 73 74 61 74 75 73 20  ent.data.status 
1a20: 3d 20 22 65 72 72 6f 72 22 3b 0a 09 09 09 09 09  = "error";......
1a30: 09 09 74 6d 70 4d 65 73 73 61 67 65 45 76 65 6e  ..tmpMessageEven
1a40: 74 2e 64 61 74 61 2e 65 72 72 6f 72 20 3d 20 22  t.data.error = "
1a50: 50 49 4e 20 77 69 6e 64 6f 77 20 63 6c 6f 73 65  PIN window close
1a60: 64 20 77 69 74 68 6f 75 74 20 61 20 50 49 4e 20  d without a PIN 
1a70: 62 65 69 6e 67 20 70 72 6f 76 69 64 65 64 22 3b  being provided";
1a80: 0a 0a 09 09 09 09 09 09 09 63 61 63 6b 65 79 4d  .........cackeyM
1a90: 65 73 73 61 67 65 49 6e 63 6f 6d 69 6e 67 28 74  essageIncoming(t
1aa0: 6d 70 4d 65 73 73 61 67 65 45 76 65 6e 74 29 3b  mpMessageEvent);
1ab0: 0a 09 09 09 09 09 09 7d 20 65 6c 73 65 20 7b 0a  .......} else {.
1ac0: 09 09 09 09 09 09 09 74 6d 70 4d 65 73 73 61 67  .......tmpMessag
1ad0: 65 45 76 65 6e 74 2e 64 61 74 61 2e 6f 72 69 67  eEvent.data.orig
1ae0: 69 6e 61 6c 72 65 71 75 65 73 74 2e 70 69 6e 20  inalrequest.pin 
1af0: 3d 20 70 69 6e 57 69 6e 64 6f 77 50 49 4e 56 61  = pinWindowPINVa
1b00: 6c 75 65 3b 0a 0a 09 09 09 09 09 09 09 63 61 63  lue;.........cac
1b10: 6b 65 79 43 65 72 74 69 66 69 63 61 74 65 54 6f  keyCertificateTo
1b20: 50 49 4e 4d 61 70 5b 63 61 63 6b 65 79 43 65 72  PINMap[cackeyCer
1b30: 74 69 66 69 63 61 74 65 54 6f 50 49 4e 49 44 28  tificateToPINID(
1b40: 74 6d 70 4d 65 73 73 61 67 65 45 76 65 6e 74 2e  tmpMessageEvent.
1b50: 64 61 74 61 2e 6f 72 69 67 69 6e 61 6c 72 65 71  data.originalreq
1b60: 75 65 73 74 2e 63 65 72 74 69 66 69 63 61 74 65  uest.certificate
1b70: 29 5d 20 3d 20 7b 7d 0a 09 09 09 09 09 09 09 63  )] = {}........c
1b80: 61 63 6b 65 79 43 65 72 74 69 66 69 63 61 74 65  ackeyCertificate
1b90: 54 6f 50 49 4e 4d 61 70 5b 63 61 63 6b 65 79 43  ToPINMap[cackeyC
1ba0: 65 72 74 69 66 69 63 61 74 65 54 6f 50 49 4e 49  ertificateToPINI
1bb0: 44 28 74 6d 70 4d 65 73 73 61 67 65 45 76 65 6e  D(tmpMessageEven
1bc0: 74 2e 64 61 74 61 2e 6f 72 69 67 69 6e 61 6c 72  t.data.originalr
1bd0: 65 71 75 65 73 74 2e 63 65 72 74 69 66 69 63 61  equest.certifica
1be0: 74 65 29 5d 2e 70 69 6e 20 3d 20 70 69 6e 57 69  te)].pin = pinWi
1bf0: 6e 64 6f 77 50 49 4e 56 61 6c 75 65 3b 0a 0a 09  ndowPINValue;...
1c00: 09 09 09 09 09 09 63 61 63 6b 65 79 43 65 72 74  ......cackeyCert
1c10: 69 66 69 63 61 74 65 54 6f 50 49 4e 4d 61 70 55  ificateToPINMapU
1c20: 70 64 61 74 65 4c 61 73 74 55 73 65 64 28 63 61  pdateLastUsed(ca
1c30: 63 6b 65 79 43 65 72 74 69 66 69 63 61 74 65 54  ckeyCertificateT
1c40: 6f 50 49 4e 49 44 28 74 6d 70 4d 65 73 73 61 67  oPINID(tmpMessag
1c50: 65 45 76 65 6e 74 2e 64 61 74 61 2e 6f 72 69 67  eEvent.data.orig
1c60: 69 6e 61 6c 72 65 71 75 65 73 74 2e 63 65 72 74  inalrequest.cert
1c70: 69 66 69 63 61 74 65 29 29 3b 0a 0a 09 09 09 09  ificate));......
1c80: 09 09 09 63 68 72 6f 6d 65 43 61 6c 6c 62 61 63  ...chromeCallbac
1c90: 6b 20 3d 20 6e 75 6c 6c 3b 0a 09 09 09 09 09 09  k = null;.......
1ca0: 09 69 66 20 28 74 6d 70 4d 65 73 73 61 67 65 45  .if (tmpMessageE
1cb0: 76 65 6e 74 2e 64 61 74 61 2e 69 64 29 20 7b 0a  vent.data.id) {.
1cc0: 09 09 09 09 09 09 09 09 69 66 20 28 63 61 63 6b  ........if (cack
1cd0: 65 79 4f 75 74 73 74 61 6e 64 69 6e 67 43 61 6c  eyOutstandingCal
1ce0: 6c 62 61 63 6b 73 29 20 7b 0a 09 09 09 09 09 09  lbacks) {.......
1cf0: 09 09 09 63 68 72 6f 6d 65 43 61 6c 6c 62 61 63  ...chromeCallbac
1d00: 6b 20 3d 20 63 61 63 6b 65 79 4f 75 74 73 74 61  k = cackeyOutsta
1d10: 6e 64 69 6e 67 43 61 6c 6c 62 61 63 6b 73 5b 74  ndingCallbacks[t
1d20: 6d 70 4d 65 73 73 61 67 65 45 76 65 6e 74 2e 64  mpMessageEvent.d
1d30: 61 74 61 2e 69 64 5d 3b 0a 09 09 09 09 09 09 09  ata.id];........
1d40: 09 7d 0a 09 09 09 09 09 09 09 7d 0a 0a 09 09 09  .}........}.....
1d50: 09 09 09 09 63 61 63 6b 65 79 49 6e 69 74 50 43  ....cackeyInitPC
1d60: 53 43 28 66 75 6e 63 74 69 6f 6e 28 29 20 7b 0a  SC(function() {.
1d70: 09 09 09 09 09 09 09 09 63 61 63 6b 65 79 48 61  ........cackeyHa
1d80: 6e 64 6c 65 2e 70 6f 73 74 4d 65 73 73 61 67 65  ndle.postMessage
1d90: 28 74 6d 70 4d 65 73 73 61 67 65 45 76 65 6e 74  (tmpMessageEvent
1da0: 2e 64 61 74 61 2e 6f 72 69 67 69 6e 61 6c 72 65  .data.originalre
1db0: 71 75 65 73 74 29 3b 0a 09 09 09 09 09 09 09 7d  quest);........}
1dc0: 2c 20 66 75 6e 63 74 69 6f 6e 28 29 20 7b 0a 09  , function() {..
1dd0: 09 09 09 09 09 09 09 69 66 20 28 63 68 72 6f 6d  .......if (chrom
1de0: 65 43 61 6c 6c 62 61 63 6b 29 20 7b 0a 09 09 09  eCallback) {....
1df0: 09 09 09 09 09 09 63 68 72 6f 6d 65 43 61 6c 6c  ......chromeCall
1e00: 62 61 63 6b 28 29 3b 0a 09 09 09 09 09 09 09 09  back();.........
1e10: 7d 0a 0a 09 09 09 09 09 09 09 09 69 66 20 28 74  }..........if (t
1e20: 6d 70 4d 65 73 73 61 67 65 45 76 65 6e 74 2e 64  mpMessageEvent.d
1e30: 61 74 61 2e 69 64 20 26 26 20 63 61 63 6b 65 79  ata.id && cackey
1e40: 4f 75 74 73 74 61 6e 64 69 6e 67 43 61 6c 6c 62  OutstandingCallb
1e50: 61 63 6b 73 5b 74 6d 70 4d 65 73 73 61 67 65 45  acks[tmpMessageE
1e60: 76 65 6e 74 2e 64 61 74 61 2e 69 64 5d 29 20 7b  vent.data.id]) {
1e70: 0a 09 09 09 09 09 09 09 09 09 64 65 6c 65 74 65  ..........delete
1e80: 20 63 61 63 6b 65 79 4f 75 74 73 74 61 6e 64 69   cackeyOutstandi
1e90: 6e 67 43 61 6c 6c 62 61 63 6b 73 5b 74 6d 70 4d  ngCallbacks[tmpM
1ea0: 65 73 73 61 67 65 45 76 65 6e 74 2e 64 61 74 61  essageEvent.data
1eb0: 2e 69 64 5d 3b 0a 09 09 09 09 09 09 09 09 7d 0a  .id];.........}.
1ec0: 09 09 09 09 09 09 09 7d 29 3b 0a 09 09 09 09 09  .......});......
1ed0: 09 7d 0a 09 09 09 09 09 7d 0a 0a 0a 09 09 09 09  .}......}.......
1ee0: 09 2f 2a 0a 09 09 09 09 09 20 2a 20 44 65 6c 65  ./*...... * Dele
1ef0: 74 65 20 74 68 65 20 65 78 69 73 74 69 6e 67 20  te the existing 
1f00: 68 61 6e 64 6c 65 20 61 6e 64 20 63 72 65 61 74  handle and creat
1f10: 65 20 61 20 6e 65 77 20 6f 6e 65 0a 09 09 09 09  e a new one.....
1f20: 09 20 2a 2f 0a 09 09 09 09 09 64 65 6c 65 74 65  . */......delete
1f30: 20 63 61 63 6b 65 79 4d 65 73 73 61 67 65 73 54   cackeyMessagesT
1f40: 6f 52 65 74 72 79 3b 0a 0a 09 09 09 09 09 63 61  oRetry;.......ca
1f50: 63 6b 65 79 4d 65 73 73 61 67 65 73 54 6f 52 65  ckeyMessagesToRe
1f60: 74 72 79 20 3d 20 5b 5d 3b 0a 0a 09 09 09 09 09  try = [];.......
1f70: 2f 2a 0a 09 09 09 09 09 20 2a 20 57 65 20 61 72  /*...... * We ar
1f80: 65 20 64 6f 6e 65 20 66 65 74 63 68 69 6e 67 20  e done fetching 
1f90: 74 68 65 20 75 73 65 72 20 50 49 4e 2c 20 63 6c  the user PIN, cl
1fa0: 65 61 72 20 74 68 65 20 76 61 6c 75 65 0a 09 09  ear the value...
1fb0: 09 09 09 20 2a 2f 0a 09 09 09 09 09 70 69 6e 57  ... */......pinW
1fc0: 69 6e 64 6f 77 50 49 4e 56 61 6c 75 65 20 3d 20  indowPINValue = 
1fd0: 22 22 3b 0a 0a 09 09 09 09 09 72 65 74 75 72 6e  "";.......return
1fe0: 3b 0a 09 09 09 09 7d 29 0a 0a 09 09 09 09 2f 2a  ;.....})....../*
1ff0: 0a 09 09 09 09 20 2a 20 50 61 73 73 20 74 68 69  ..... * Pass thi
2000: 73 20 6d 65 73 73 61 67 65 20 6f 66 66 20 74 6f  s message off to
2010: 20 74 68 65 20 6f 74 68 65 72 20 77 69 6e 64 6f   the other windo
2020: 77 20 73 6f 20 74 68 61 74 20 69 74 20 6d 61 79  w so that it may
2030: 20 72 65 73 75 62 6d 69 74 20 74 68 65 20 72 65   resubmit the re
2040: 71 75 65 73 74 2e 0a 09 09 09 09 20 2a 2f 0a 09  quest...... */..
2050: 09 09 09 70 69 6e 57 69 6e 64 6f 77 2e 63 6f 6e  ...pinWindow.con
2060: 74 65 6e 74 57 69 6e 64 6f 77 2e 70 61 72 65 6e  tentWindow.paren
2070: 74 57 69 6e 64 6f 77 20 3d 20 77 69 6e 64 6f 77  tWindow = window
2080: 3b 0a 09 09 09 09 70 69 6e 57 69 6e 64 6f 77 2e  ;.....pinWindow.
2090: 63 6f 6e 74 65 6e 74 57 69 6e 64 6f 77 2e 6d 65  contentWindow.me
20a0: 73 73 61 67 65 45 76 65 6e 74 20 3d 20 6d 65 73  ssageEvent = mes
20b0: 73 61 67 65 45 76 65 6e 74 3b 0a 0a 09 09 09 09  sageEvent;......
20c0: 72 65 74 75 72 6e 3b 0a 09 09 09 7d 29 3b 0a 0a  return;....});..
20d0: 09 09 09 2f 2a 0a 09 09 09 20 2a 20 57 65 20 72  .../*.... * We r
20e0: 65 74 75 72 6e 20 68 65 72 65 20 69 6e 73 74 65  eturn here inste
20f0: 61 64 20 6f 66 20 62 72 65 61 6b 20 74 6f 20 61  ad of break to a
2100: 76 6f 69 64 20 64 65 6c 65 74 69 6e 67 20 74 68  void deleting th
2110: 65 20 63 61 6c 6c 62 61 63 6b 0a 09 09 09 20 2a  e callback.... *
2120: 20 65 6e 74 72 79 2e 0a 09 09 09 20 2a 2f 0a 09   entry..... */..
2130: 09 09 72 65 74 75 72 6e 3b 0a 09 09 63 61 73 65  ..return;...case
2140: 20 22 73 75 63 63 65 73 73 22 3a 0a 09 09 09 73   "success":....s
2150: 77 69 74 63 68 20 28 6d 65 73 73 61 67 65 45 76  witch (messageEv
2160: 65 6e 74 2e 64 61 74 61 2e 63 6f 6d 6d 61 6e 64  ent.data.command
2170: 29 20 7b 0a 09 09 09 09 63 61 73 65 20 22 6c 69  ) {.....case "li
2180: 73 74 63 65 72 74 69 66 69 63 61 74 65 73 22 3a  stcertificates":
2190: 0a 09 09 09 09 09 6e 65 78 74 46 75 6e 63 74 69  ......nextFuncti
21a0: 6f 6e 20 3d 20 63 61 63 6b 65 79 4d 65 73 73 61  on = cackeyMessa
21b0: 67 65 49 6e 63 6f 6d 69 6e 67 4c 69 73 74 43 65  geIncomingListCe
21c0: 72 74 69 66 69 63 61 74 65 73 3b 0a 0a 09 09 09  rtificates;.....
21d0: 09 09 62 72 65 61 6b 3b 0a 09 09 09 09 63 61 73  ..break;.....cas
21e0: 65 20 22 73 69 67 6e 22 3a 0a 09 09 09 09 09 6e  e "sign":......n
21f0: 65 78 74 46 75 6e 63 74 69 6f 6e 20 3d 20 63 61  extFunction = ca
2200: 63 6b 65 79 4d 65 73 73 61 67 65 49 6e 63 6f 6d  ckeyMessageIncom
2210: 69 6e 67 53 69 67 6e 4d 65 73 73 61 67 65 3b 0a  ingSignMessage;.
2220: 0a 09 09 09 09 09 62 72 65 61 6b 3b 0a 09 09 09  ......break;....
2230: 7d 0a 0a 09 09 09 62 72 65 61 6b 3b 0a 09 7d 0a  }.....break;..}.
2240: 0a 09 69 66 20 28 6e 65 78 74 46 75 6e 63 74 69  ..if (nextFuncti
2250: 6f 6e 20 21 3d 20 6e 75 6c 6c 29 20 7b 0a 09 09  on != null) {...
2260: 6e 65 78 74 46 75 6e 63 74 69 6f 6e 28 6d 65 73  nextFunction(mes
2270: 73 61 67 65 45 76 65 6e 74 2e 64 61 74 61 2c 20  sageEvent.data, 
2280: 63 68 72 6f 6d 65 43 61 6c 6c 62 61 63 6b 29 3b  chromeCallback);
2290: 0a 09 7d 0a 0a 09 64 65 6c 65 74 65 20 63 61 63  ..}...delete cac
22a0: 6b 65 79 4f 75 74 73 74 61 6e 64 69 6e 67 43 61  keyOutstandingCa
22b0: 6c 6c 62 61 63 6b 73 5b 6d 65 73 73 61 67 65 45  llbacks[messageE
22c0: 76 65 6e 74 2e 64 61 74 61 2e 69 64 5d 3b 0a 0a  vent.data.id];..
22d0: 09 72 65 74 75 72 6e 3b 0a 7d 0a 0a 2f 2a 0a 20  .return;.}../*. 
22e0: 2a 20 48 61 6e 64 6c 65 72 20 66 6f 72 20 6d 65  * Handler for me
22f0: 73 73 61 67 65 73 20 66 72 6f 6d 20 43 68 72 6f  ssages from Chro
2300: 6d 65 20 72 65 6c 61 74 65 64 20 74 6f 20 6c 69  me related to li
2310: 73 74 69 6e 67 20 63 65 72 74 69 66 69 63 61 74  sting certificat
2320: 65 73 0a 20 2a 2f 0a 66 75 6e 63 74 69 6f 6e 20  es. */.function 
2330: 63 61 63 6b 65 79 4c 69 73 74 43 65 72 74 69 66  cackeyListCertif
2340: 69 63 61 74 65 73 28 63 68 72 6f 6d 65 43 61 6c  icates(chromeCal
2350: 6c 62 61 63 6b 29 20 7b 0a 09 76 61 72 20 63 61  lback) {..var ca
2360: 6c 6c 62 61 63 6b 49 64 3b 0a 0a 09 69 66 20 28  llbackId;...if (
2370: 47 6f 6f 67 6c 65 53 6d 61 72 74 43 61 72 64 2e  GoogleSmartCard.
2380: 49 53 5f 44 45 42 55 47 5f 42 55 49 4c 44 29 20  IS_DEBUG_BUILD) 
2390: 7b 0a 09 09 63 6f 6e 73 6f 6c 65 2e 6c 6f 67 28  {...console.log(
23a0: 22 5b 63 61 63 6b 65 79 5d 20 41 73 6b 65 64 20  "[cackey] Asked 
23b0: 74 6f 20 70 72 6f 76 69 64 65 20 61 20 6c 69 73  to provide a lis
23c0: 74 20 6f 66 20 63 65 72 74 69 66 69 63 61 74 65  t of certificate
23d0: 73 20 2d 2d 20 74 68 72 6f 77 69 6e 67 20 74 68  s -- throwing th
23e0: 61 74 20 72 65 71 75 65 73 74 20 6f 76 65 72 20  at request over 
23f0: 74 6f 20 74 68 65 20 4e 61 43 6c 20 73 69 64 65  to the NaCl side
2400: 2e 2e 2e 20 22 29 3b 0a 09 7d 0a 0a 09 63 61 6c  ... ");..}...cal
2410: 6c 62 61 63 6b 49 64 20 3d 20 63 61 63 6b 65 79  lbackId = cackey
2420: 4f 75 74 73 74 61 6e 64 69 6e 67 43 61 6c 6c 62  OutstandingCallb
2430: 61 63 6b 43 6f 75 6e 74 65 72 20 2b 20 31 3b 0a  ackCounter + 1;.
2440: 0a 09 63 61 63 6b 65 79 49 6e 69 74 50 43 53 43  ..cackeyInitPCSC
2450: 28 66 75 6e 63 74 69 6f 6e 28 29 20 7b 0a 09 09  (function() {...
2460: 63 61 63 6b 65 79 48 61 6e 64 6c 65 2e 70 6f 73  cackeyHandle.pos
2470: 74 4d 65 73 73 61 67 65 28 0a 09 09 09 7b 0a 09  tMessage(....{..
2480: 09 09 09 27 74 61 72 67 65 74 27 3a 20 22 63 61  ...'target': "ca
2490: 63 6b 65 79 22 2c 0a 09 09 09 09 27 63 6f 6d 6d  ckey",.....'comm
24a0: 61 6e 64 27 3a 20 22 6c 69 73 74 63 65 72 74 69  and': "listcerti
24b0: 66 69 63 61 74 65 73 22 2c 0a 09 09 09 09 27 69  ficates",.....'i
24c0: 64 27 3a 20 63 61 6c 6c 62 61 63 6b 49 64 0a 09  d': callbackId..
24d0: 09 09 7d 0a 09 09 29 3b 0a 0a 09 09 63 61 63 6b  ..}...);....cack
24e0: 65 79 4f 75 74 73 74 61 6e 64 69 6e 67 43 61 6c  eyOutstandingCal
24f0: 6c 62 61 63 6b 43 6f 75 6e 74 65 72 20 3d 20 63  lbackCounter = c
2500: 61 6c 6c 62 61 63 6b 49 64 3b 0a 09 09 63 61 63  allbackId;...cac
2510: 6b 65 79 4f 75 74 73 74 61 6e 64 69 6e 67 43 61  keyOutstandingCa
2520: 6c 6c 62 61 63 6b 73 5b 63 61 6c 6c 62 61 63 6b  llbacks[callback
2530: 49 64 5d 20 3d 20 63 68 72 6f 6d 65 43 61 6c 6c  Id] = chromeCall
2540: 62 61 63 6b 3b 0a 0a 09 09 69 66 20 28 47 6f 6f  back;....if (Goo
2550: 67 6c 65 53 6d 61 72 74 43 61 72 64 2e 49 53 5f  gleSmartCard.IS_
2560: 44 45 42 55 47 5f 42 55 49 4c 44 29 20 7b 0a 09  DEBUG_BUILD) {..
2570: 09 09 63 6f 6e 73 6f 6c 65 2e 6c 6f 67 28 22 5b  ..console.log("[
2580: 63 61 63 6b 65 79 5d 20 54 68 72 6f 77 6e 2e 22  cackey] Thrown."
2590: 29 3b 0a 09 09 7d 0a 09 7d 2c 20 63 68 72 6f 6d  );...}..}, chrom
25a0: 65 43 61 6c 6c 62 61 63 6b 29 3b 0a 0a 09 72 65  eCallback);...re
25b0: 74 75 72 6e 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 20 48  turn;.}../*. * H
25c0: 61 6e 64 6c 65 72 20 66 6f 72 20 6d 65 73 73 61  andler for messa
25d0: 67 65 73 20 66 72 6f 6d 20 43 68 72 6f 6d 65 20  ges from Chrome 
25e0: 72 65 6c 61 74 65 64 20 74 6f 20 73 69 67 6e 69  related to signi
25f0: 6e 67 20 61 20 68 61 73 68 20 6f 66 20 73 6f 6d  ng a hash of som
2600: 65 20 73 6f 72 74 0a 20 2a 2f 0a 66 75 6e 63 74  e sort. */.funct
2610: 69 6f 6e 20 63 61 63 6b 65 79 53 69 67 6e 4d 65  ion cackeySignMe
2620: 73 73 61 67 65 28 73 69 67 6e 52 65 71 75 65 73  ssage(signReques
2630: 74 2c 20 63 68 72 6f 6d 65 43 61 6c 6c 62 61 63  t, chromeCallbac
2640: 6b 29 20 7b 0a 09 76 61 72 20 63 61 6c 6c 62 61  k) {..var callba
2650: 63 6b 49 64 3b 0a 09 76 61 72 20 63 6f 6d 6d 61  ckId;..var comma
2660: 6e 64 3b 0a 09 76 61 72 20 63 65 72 74 69 66 69  nd;..var certifi
2670: 63 61 74 65 49 64 3b 0a 09 76 61 72 20 64 69 67  cateId;..var dig
2680: 65 73 74 2c 20 64 69 67 65 73 74 48 65 61 64 65  est, digestHeade
2690: 72 3b 0a 0a 09 2f 2a 0a 09 20 2a 20 50 72 65 66  r;.../*.. * Pref
26a0: 69 78 20 74 68 65 20 64 69 67 65 73 74 20 77 69  ix the digest wi
26b0: 74 68 20 74 68 65 20 41 53 4e 2e 31 20 68 65 61  th the ASN.1 hea
26c0: 64 65 72 20 72 65 71 75 69 72 65 64 20 6f 66 20  der required of 
26d0: 69 74 0a 09 20 2a 2f 0a 09 73 77 69 74 63 68 20  it.. */..switch 
26e0: 28 73 69 67 6e 52 65 71 75 65 73 74 2e 68 61 73  (signRequest.has
26f0: 68 29 20 7b 0a 09 09 63 61 73 65 20 22 53 48 41  h) {...case "SHA
2700: 31 22 3a 0a 09 09 09 64 69 67 65 73 74 48 65 61  1":....digestHea
2710: 64 65 72 20 3d 20 6e 65 77 20 55 69 6e 74 38 41  der = new Uint8A
2720: 72 72 61 79 28 5b 30 78 33 30 2c 20 30 78 32 31  rray([0x30, 0x21
2730: 2c 20 30 78 33 30 2c 20 30 78 30 39 2c 20 30 78  , 0x30, 0x09, 0x
2740: 30 36 2c 20 30 78 30 35 2c 20 30 78 32 62 2c 20  06, 0x05, 0x2b, 
2750: 30 78 30 65 2c 20 30 78 30 33 2c 20 30 78 30 32  0x0e, 0x03, 0x02
2760: 2c 20 30 78 31 61 2c 20 30 78 30 35 2c 20 30 78  , 0x1a, 0x05, 0x
2770: 30 30 2c 20 30 78 30 34 2c 20 30 78 31 34 5d 29  00, 0x04, 0x14])
2780: 3b 0a 09 09 09 62 72 65 61 6b 3b 0a 09 09 63 61  ;....break;...ca
2790: 73 65 20 22 53 48 41 32 35 36 22 3a 0a 09 09 09  se "SHA256":....
27a0: 64 69 67 65 73 74 48 65 61 64 65 72 20 3d 20 6e  digestHeader = n
27b0: 65 77 20 55 69 6e 74 38 41 72 72 61 79 28 5b 30  ew Uint8Array([0
27c0: 78 33 30 2c 20 30 78 33 31 2c 20 30 78 33 30 2c  x30, 0x31, 0x30,
27d0: 20 30 78 30 64 2c 20 30 78 30 36 2c 20 30 78 30   0x0d, 0x06, 0x0
27e0: 39 2c 20 30 78 36 30 2c 20 30 78 38 36 2c 20 30  9, 0x60, 0x86, 0
27f0: 78 34 38 2c 20 30 78 30 31 2c 20 30 78 36 35 2c  x48, 0x01, 0x65,
2800: 20 30 78 30 33 2c 20 30 78 30 34 2c 20 30 78 30   0x03, 0x04, 0x0
2810: 32 2c 20 30 78 30 31 2c 20 30 78 30 35 2c 20 30  2, 0x01, 0x05, 0
2820: 78 30 30 2c 20 30 78 30 34 2c 20 30 78 32 30 5d  x00, 0x04, 0x20]
2830: 29 3b 0a 09 09 09 62 72 65 61 6b 3b 0a 09 09 63  );....break;...c
2840: 61 73 65 20 22 4d 44 35 5f 53 48 41 31 22 3a 0a  ase "MD5_SHA1":.
2850: 09 09 09 64 69 67 65 73 74 48 65 61 64 65 72 20  ...digestHeader 
2860: 3d 20 6e 65 77 20 55 69 6e 74 38 41 72 72 61 79  = new Uint8Array
2870: 28 29 3b 0a 09 09 09 62 72 65 61 6b 3b 0a 09 09  ();....break;...
2880: 64 65 66 61 75 6c 74 3a 0a 09 09 09 63 6f 6e 73  default:....cons
2890: 6f 6c 65 2e 65 72 72 6f 72 28 22 5b 63 61 63 6b  ole.error("[cack
28a0: 65 79 5d 20 41 73 6b 65 64 20 74 6f 20 73 69 67  ey] Asked to sig
28b0: 6e 20 61 20 6d 65 73 73 61 67 65 20 77 69 74 68  n a message with
28c0: 20 61 20 68 61 73 68 20 77 65 20 64 6f 20 6e 6f   a hash we do no
28d0: 74 20 73 75 70 70 6f 72 74 3a 20 22 20 2b 20 73  t support: " + s
28e0: 69 67 6e 52 65 71 75 65 73 74 2e 68 61 73 68 29  ignRequest.hash)
28f0: 3b 0a 0a 09 09 09 63 68 72 6f 6d 65 43 61 6c 6c  ;.....chromeCall
2900: 62 61 63 6b 28 29 3b 0a 0a 09 09 09 72 65 74 75  back();.....retu
2910: 72 6e 3b 0a 09 7d 0a 0a 09 64 69 67 65 73 74 20  rn;..}...digest 
2920: 3d 20 6e 65 77 20 55 69 6e 74 38 41 72 72 61 79  = new Uint8Array
2930: 28 64 69 67 65 73 74 48 65 61 64 65 72 2e 6c 65  (digestHeader.le
2940: 6e 67 74 68 20 2b 20 73 69 67 6e 52 65 71 75 65  ngth + signReque
2950: 73 74 2e 64 69 67 65 73 74 2e 62 79 74 65 4c 65  st.digest.byteLe
2960: 6e 67 74 68 29 3b 0a 09 64 69 67 65 73 74 2e 73  ngth);..digest.s
2970: 65 74 28 64 69 67 65 73 74 48 65 61 64 65 72 2c  et(digestHeader,
2980: 20 30 29 3b 0a 09 64 69 67 65 73 74 2e 73 65 74   0);..digest.set
2990: 28 6e 65 77 20 55 69 6e 74 38 41 72 72 61 79 28  (new Uint8Array(
29a0: 73 69 67 6e 52 65 71 75 65 73 74 2e 64 69 67 65  signRequest.dige
29b0: 73 74 29 2c 20 64 69 67 65 73 74 48 65 61 64 65  st), digestHeade
29c0: 72 2e 6c 65 6e 67 74 68 29 3b 0a 0a 09 64 65 6c  r.length);...del
29d0: 65 74 65 20 64 69 67 65 73 74 48 65 61 64 65 72  ete digestHeader
29e0: 3b 0a 0a 09 69 66 20 28 47 6f 6f 67 6c 65 53 6d  ;...if (GoogleSm
29f0: 61 72 74 43 61 72 64 2e 49 53 5f 44 45 42 55 47  artCard.IS_DEBUG
2a00: 5f 42 55 49 4c 44 29 20 7b 0a 09 09 63 6f 6e 73  _BUILD) {...cons
2a10: 6f 6c 65 2e 6c 6f 67 28 22 5b 63 61 63 6b 65 79  ole.log("[cackey
2a20: 5d 20 41 73 6b 65 64 20 74 6f 20 73 69 67 6e 20  ] Asked to sign 
2a30: 61 20 6d 65 73 73 61 67 65 20 2d 2d 20 74 68 72  a message -- thr
2a40: 6f 77 69 6e 67 20 74 68 61 74 20 72 65 71 75 65  owing that reque
2a50: 73 74 20 6f 76 65 72 20 74 6f 20 74 68 65 20 4e  st over to the N
2a60: 61 43 6c 20 73 69 64 65 2e 2e 2e 20 22 29 3b 0a  aCl side... ");.
2a70: 09 7d 0a 0a 09 63 61 6c 6c 62 61 63 6b 49 64 20  .}...callbackId 
2a80: 3d 20 63 61 63 6b 65 79 4f 75 74 73 74 61 6e 64  = cackeyOutstand
2a90: 69 6e 67 43 61 6c 6c 62 61 63 6b 43 6f 75 6e 74  ingCallbackCount
2aa0: 65 72 20 2b 20 31 3b 0a 0a 09 63 6f 6d 6d 61 6e  er + 1;...comman
2ab0: 64 20 3d 20 7b 0a 09 09 27 74 61 72 67 65 74 27  d = {...'target'
2ac0: 3a 20 22 63 61 63 6b 65 79 22 2c 0a 09 09 27 63  : "cackey",...'c
2ad0: 6f 6d 6d 61 6e 64 27 3a 20 22 73 69 67 6e 22 2c  ommand': "sign",
2ae0: 0a 09 09 27 69 64 27 3a 20 63 61 6c 6c 62 61 63  ...'id': callbac
2af0: 6b 49 64 2c 0a 09 09 27 63 65 72 74 69 66 69 63  kId,...'certific
2b00: 61 74 65 27 3a 20 73 69 67 6e 52 65 71 75 65 73  ate': signReques
2b10: 74 2e 63 65 72 74 69 66 69 63 61 74 65 2c 0a 09  t.certificate,..
2b20: 09 27 64 61 74 61 27 3a 20 64 69 67 65 73 74 2e  .'data': digest.
2b30: 62 75 66 66 65 72 0a 09 7d 3b 0a 0a 09 63 65 72  buffer..};...cer
2b40: 74 69 66 69 63 61 74 65 49 64 20 3d 20 63 61 63  tificateId = cac
2b50: 6b 65 79 43 65 72 74 69 66 69 63 61 74 65 54 6f  keyCertificateTo
2b60: 50 49 4e 49 44 28 63 6f 6d 6d 61 6e 64 2e 63 65  PINID(command.ce
2b70: 72 74 69 66 69 63 61 74 65 29 3b 0a 0a 09 69 66  rtificate);...if
2b80: 20 28 63 61 63 6b 65 79 43 65 72 74 69 66 69 63   (cackeyCertific
2b90: 61 74 65 54 6f 50 49 4e 4d 61 70 5b 63 65 72 74  ateToPINMap[cert
2ba0: 69 66 69 63 61 74 65 49 64 5d 20 26 26 20 63 61  ificateId] && ca
2bb0: 63 6b 65 79 43 65 72 74 69 66 69 63 61 74 65 54  ckeyCertificateT
2bc0: 6f 50 49 4e 4d 61 70 5b 63 65 72 74 69 66 69 63  oPINMap[certific
2bd0: 61 74 65 49 64 5d 2e 70 69 6e 29 20 7b 0a 09 09  ateId].pin) {...
2be0: 63 6f 6d 6d 61 6e 64 2e 70 69 6e 20 3d 20 63 61  command.pin = ca
2bf0: 63 6b 65 79 43 65 72 74 69 66 69 63 61 74 65 54  ckeyCertificateT
2c00: 6f 50 49 4e 4d 61 70 5b 63 65 72 74 69 66 69 63  oPINMap[certific
2c10: 61 74 65 49 64 5d 2e 70 69 6e 3b 0a 0a 09 09 63  ateId].pin;....c
2c20: 61 63 6b 65 79 43 65 72 74 69 66 69 63 61 74 65  ackeyCertificate
2c30: 54 6f 50 49 4e 4d 61 70 55 70 64 61 74 65 4c 61  ToPINMapUpdateLa
2c40: 73 74 55 73 65 64 28 63 65 72 74 69 66 69 63 61  stUsed(certifica
2c50: 74 65 49 64 29 3b 0a 09 7d 0a 0a 09 63 61 63 6b  teId);..}...cack
2c60: 65 79 49 6e 69 74 50 43 53 43 28 66 75 6e 63 74  eyInitPCSC(funct
2c70: 69 6f 6e 28 29 20 7b 0a 09 09 63 61 63 6b 65 79  ion() {...cackey
2c80: 48 61 6e 64 6c 65 2e 70 6f 73 74 4d 65 73 73 61  Handle.postMessa
2c90: 67 65 28 63 6f 6d 6d 61 6e 64 29 3b 0a 0a 09 09  ge(command);....
2ca0: 63 61 63 6b 65 79 4f 75 74 73 74 61 6e 64 69 6e  cackeyOutstandin
2cb0: 67 43 61 6c 6c 62 61 63 6b 43 6f 75 6e 74 65 72  gCallbackCounter
2cc0: 20 3d 20 63 61 6c 6c 62 61 63 6b 49 64 3b 0a 09   = callbackId;..
2cd0: 09 63 61 63 6b 65 79 4f 75 74 73 74 61 6e 64 69  .cackeyOutstandi
2ce0: 6e 67 43 61 6c 6c 62 61 63 6b 73 5b 63 61 6c 6c  ngCallbacks[call
2cf0: 62 61 63 6b 49 64 5d 20 3d 20 63 68 72 6f 6d 65  backId] = chrome
2d00: 43 61 6c 6c 62 61 63 6b 3b 0a 0a 09 09 69 66 20  Callback;....if 
2d10: 28 47 6f 6f 67 6c 65 53 6d 61 72 74 43 61 72 64  (GoogleSmartCard
2d20: 2e 49 53 5f 44 45 42 55 47 5f 42 55 49 4c 44 29  .IS_DEBUG_BUILD)
2d30: 20 7b 0a 09 09 09 63 6f 6e 73 6f 6c 65 2e 6c 6f   {....console.lo
2d40: 67 28 22 5b 63 61 63 6b 65 79 5d 20 54 68 72 6f  g("[cackey] Thro
2d50: 77 6e 2e 22 29 3b 0a 09 09 7d 0a 09 7d 2c 20 63  wn.");...}..}, c
2d60: 68 72 6f 6d 65 43 61 6c 6c 62 61 63 6b 29 3b 0a  hromeCallback);.
2d70: 0a 09 72 65 74 75 72 6e 3b 0a 7d 0a 0a 2f 2a 0a  ..return;.}../*.
2d80: 20 2a 20 55 6e 69 74 69 74 61 6c 69 7a 65 73 20   * Unititalizes 
2d90: 74 68 65 20 43 41 43 4b 65 79 20 50 43 53 43 20  the CACKey PCSC 
2da0: 63 6f 6e 6e 65 63 74 69 6f 6e 0a 20 2a 2f 0a 66  connection. */.f
2db0: 75 6e 63 74 69 6f 6e 20 63 61 63 6b 65 79 55 6e  unction cackeyUn
2dc0: 69 6e 69 74 50 43 53 43 28 29 20 7b 0a 09 63 6f  initPCSC() {..co
2dd0: 6e 73 6f 6c 65 2e 6c 6f 67 28 22 5b 63 61 63 6b  nsole.log("[cack
2de0: 65 79 5d 20 63 61 63 6b 65 79 55 6e 69 6e 69 74  ey] cackeyUninit
2df0: 50 43 53 43 28 29 20 63 61 6c 6c 65 64 22 29 3b  PCSC() called");
2e00: 0a 0a 09 69 66 20 28 63 61 63 6b 65 79 50 43 53  ...if (cackeyPCS
2e10: 43 48 61 6e 64 6c 65 20 21 3d 20 6e 75 6c 6c 29  CHandle != null)
2e20: 20 7b 0a 09 09 63 6f 6e 73 6f 6c 65 2e 6c 6f 67   {...console.log
2e30: 28 22 5b 63 61 63 6b 65 79 5d 20 44 65 6c 65 74  ("[cackey] Delet
2e40: 69 6e 67 20 50 43 53 43 20 68 61 6e 64 6c 65 22  ing PCSC handle"
2e50: 29 3b 0a 0a 09 09 64 65 6c 65 74 65 20 63 61 63  );....delete cac
2e60: 6b 65 79 50 43 53 43 48 61 6e 64 6c 65 3b 0a 0a  keyPCSCHandle;..
2e70: 09 09 63 61 63 6b 65 79 50 43 53 43 48 61 6e 64  ..cackeyPCSCHand
2e80: 6c 65 20 3d 20 6e 75 6c 6c 3b 0a 09 7d 0a 0a 09  le = null;..}...
2e90: 63 61 63 6b 65 79 50 43 53 43 48 61 6e 64 6c 65  cackeyPCSCHandle
2ea0: 55 73 61 62 6c 65 20 3d 20 66 61 6c 73 65 3b 0a  Usable = false;.
2eb0: 0a 09 63 6f 6e 73 6f 6c 65 2e 6c 6f 67 28 22 5b  ..console.log("[
2ec0: 63 61 63 6b 65 79 5d 20 63 61 63 6b 65 79 55 6e  cackey] cackeyUn
2ed0: 69 6e 69 74 50 43 53 43 28 29 20 72 65 74 75 72  initPCSC() retur
2ee0: 6e 69 6e 67 22 29 3b 0a 0a 09 72 65 74 75 72 6e  ning");...return
2ef0: 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 20 55 6e 69 6e 69  ;.}../*. * Unini
2f00: 74 69 61 6c 69 7a 65 73 20 43 41 43 4b 65 79 20  tializes CACKey 
2f10: 28 70 72 6f 62 61 62 6c 79 20 64 75 65 20 74 6f  (probably due to
2f20: 20 61 20 63 72 61 73 68 29 0a 20 2a 2f 0a 66 75   a crash). */.fu
2f30: 6e 63 74 69 6f 6e 20 63 61 63 6b 65 79 55 6e 69  nction cackeyUni
2f40: 6e 69 74 28 29 20 7b 0a 09 63 6f 6e 73 6f 6c 65  nit() {..console
2f50: 2e 6c 6f 67 28 22 5b 63 61 63 6b 65 79 5d 20 63  .log("[cackey] c
2f60: 61 63 6b 65 79 55 6e 69 6e 69 74 28 29 20 63 61  ackeyUninit() ca
2f70: 6c 6c 65 64 22 29 3b 0a 0a 09 69 66 20 28 63 68  lled");...if (ch
2f80: 72 6f 6d 65 2e 63 65 72 74 69 66 69 63 61 74 65  rome.certificate
2f90: 50 72 6f 76 69 64 65 72 29 20 7b 0a 09 09 63 6f  Provider) {...co
2fa0: 6e 73 6f 6c 65 2e 6c 6f 67 28 22 5b 63 61 63 6b  nsole.log("[cack
2fb0: 65 79 5d 20 55 6e 72 65 67 69 73 74 65 72 65 64  ey] Unregistered
2fc0: 20 43 68 72 6f 6d 65 20 63 65 72 74 69 66 69 63   Chrome certific
2fd0: 61 74 65 20 68 61 6e 64 6c 65 72 73 22 29 3b 0a  ate handlers");.
2fe0: 0a 09 09 63 68 72 6f 6d 65 2e 63 65 72 74 69 66  ...chrome.certif
2ff0: 69 63 61 74 65 50 72 6f 76 69 64 65 72 2e 6f 6e  icateProvider.on
3000: 43 65 72 74 69 66 69 63 61 74 65 73 52 65 71 75  CertificatesRequ
3010: 65 73 74 65 64 2e 72 65 6d 6f 76 65 4c 69 73 74  ested.removeList
3020: 65 6e 65 72 28 63 61 63 6b 65 79 4c 69 73 74 43  ener(cackeyListC
3030: 65 72 74 69 66 69 63 61 74 65 73 29 3b 0a 09 09  ertificates);...
3040: 63 68 72 6f 6d 65 2e 63 65 72 74 69 66 69 63 61  chrome.certifica
3050: 74 65 50 72 6f 76 69 64 65 72 2e 6f 6e 53 69 67  teProvider.onSig
3060: 6e 44 69 67 65 73 74 52 65 71 75 65 73 74 65 64  nDigestRequested
3070: 2e 72 65 6d 6f 76 65 4c 69 73 74 65 6e 65 72 28  .removeListener(
3080: 63 61 63 6b 65 79 53 69 67 6e 4d 65 73 73 61 67  cackeySignMessag
3090: 65 29 3b 0a 09 7d 0a 0a 09 63 61 63 6b 65 79 55  e);..}...cackeyU
30a0: 6e 69 6e 69 74 50 43 53 43 28 29 3b 0a 0a 09 69  ninitPCSC();...i
30b0: 66 20 28 63 61 63 6b 65 79 48 61 6e 64 6c 65 20  f (cackeyHandle 
30c0: 21 3d 20 6e 75 6c 6c 29 20 7b 0a 09 09 63 6f 6e  != null) {...con
30d0: 73 6f 6c 65 2e 6c 6f 67 28 22 5b 63 61 63 6b 65  sole.log("[cacke
30e0: 79 5d 20 44 65 6c 65 74 69 6e 67 20 50 4e 61 43  y] Deleting PNaC
30f0: 6c 20 6d 6f 64 75 6c 65 22 29 3b 0a 0a 09 09 74  l module");....t
3100: 72 79 20 7b 0a 09 09 09 64 6f 63 75 6d 65 6e 74  ry {....document
3110: 2e 62 6f 64 79 2e 72 65 6d 6f 76 65 43 68 69 6c  .body.removeChil
3120: 64 28 63 61 63 6b 65 79 48 61 6e 64 6c 65 29 3b  d(cackeyHandle);
3130: 0a 09 09 7d 20 63 61 74 63 68 20 28 65 29 20 7b  ...} catch (e) {
3140: 20 7d 0a 0a 09 09 64 65 6c 65 74 65 20 63 61 63   }....delete cac
3150: 6b 65 79 48 61 6e 64 6c 65 3b 0a 0a 09 09 63 61  keyHandle;....ca
3160: 63 6b 65 79 48 61 6e 64 6c 65 20 3d 20 6e 75 6c  ckeyHandle = nul
3170: 6c 3b 0a 09 7d 0a 0a 09 63 6f 6e 73 6f 6c 65 2e  l;..}...console.
3180: 6c 6f 67 28 22 5b 63 61 63 6b 65 79 5d 20 63 61  log("[cackey] ca
3190: 63 6b 65 79 55 6e 69 6e 69 74 28 29 20 63 6f 6d  ckeyUninit() com
31a0: 70 6c 65 74 65 22 29 3b 0a 0a 09 72 65 74 75 72  plete");...retur
31b0: 6e 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 20 52 65 73 74  n;.}../*. * Rest
31c0: 61 72 74 73 20 43 41 43 4b 65 79 0a 20 2a 2f 0a  arts CACKey. */.
31d0: 66 75 6e 63 74 69 6f 6e 20 63 61 63 6b 65 79 52  function cackeyR
31e0: 65 73 74 61 72 74 28 29 20 7b 0a 09 63 61 63 6b  estart() {..cack
31f0: 65 79 55 6e 69 6e 69 74 28 29 3b 0a 09 63 61 63  eyUninit();..cac
3200: 6b 65 79 49 6e 69 74 28 29 3b 0a 0a 09 72 65 74  keyInit();...ret
3210: 75 72 6e 3b 0a 7d 0a 0a 66 75 6e 63 74 69 6f 6e  urn;.}..function
3220: 20 63 61 63 6b 65 79 49 6e 69 74 47 6c 6f 62 61   cackeyInitGloba
3230: 6c 53 74 61 74 65 28 29 20 7b 0a 09 63 61 63 6b  lState() {..cack
3240: 65 79 4f 75 74 73 74 61 6e 64 69 6e 67 43 61 6c  eyOutstandingCal
3250: 6c 62 61 63 6b 73 20 3d 20 7b 7d 3b 0a 7d 3b 0a  lbacks = {};.};.
3260: 0a 2f 2a 0a 20 2a 20 48 61 6e 64 6c 65 20 61 20  ./*. * Handle a 
3270: 43 41 43 4b 65 79 20 63 72 61 73 68 20 28 70 72  CACKey crash (pr
3280: 6f 62 61 62 6c 79 20 64 75 65 20 74 6f 20 6c 6f  obably due to lo
3290: 73 73 20 6f 66 20 63 6f 6e 6e 65 63 74 69 76 69  ss of connectivi
32a0: 74 79 20 74 6f 20 74 68 65 20 50 43 53 43 20 64  ty to the PCSC d
32b0: 61 65 6d 6f 6e 29 0a 20 2a 2f 0a 66 75 6e 63 74  aemon). */.funct
32c0: 69 6f 6e 20 63 61 63 6b 65 79 43 72 61 73 68 28  ion cackeyCrash(
32d0: 29 20 7b 0a 09 2f 2a 0a 09 20 2a 20 44 65 2d 69  ) {../*.. * De-i
32e0: 6e 69 74 69 61 6c 69 7a 65 20 43 41 43 4b 65 79  nitialize CACKey
32f0: 0a 09 20 2a 2f 0a 09 63 61 63 6b 65 79 55 6e 69  .. */..cackeyUni
3300: 6e 69 74 28 29 3b 0a 0a 09 2f 2a 0a 09 20 2a 20  nit();.../*.. * 
3310: 52 65 69 6e 69 74 69 61 6c 69 7a 65 20 67 6c 6f  Reinitialize glo
3320: 62 61 6c 20 73 74 61 74 65 0a 09 20 2a 2f 0a 09  bal state.. */..
3330: 63 61 63 6b 65 79 49 6e 69 74 47 6c 6f 62 61 6c  cackeyInitGlobal
3340: 53 74 61 74 65 28 29 3b 0a 0a 09 2f 2a 0a 09 20  State();.../*.. 
3350: 2a 20 53 63 68 65 64 75 6c 65 20 74 68 65 20 72  * Schedule the r
3360: 65 73 74 61 72 74 20 74 6f 20 6f 63 63 75 72 20  estart to occur 
3370: 69 6e 20 33 30 20 73 65 63 6f 6e 64 73 20 69 6e  in 30 seconds in
3380: 20 63 61 73 65 20 77 65 20 72 65 61 6c 6c 79 20   case we really 
3390: 61 72 65 0a 09 20 2a 20 6e 6f 74 20 77 6f 72 6b  are.. * not work
33a0: 69 6e 67 2e 0a 09 20 2a 2f 0a 09 73 65 74 54 69  ing... */..setTi
33b0: 6d 65 6f 75 74 28 63 61 63 6b 65 79 49 6e 69 74  meout(cackeyInit
33c0: 2c 20 33 30 30 30 30 29 3b 0a 0a 09 72 65 74 75  , 30000);...retu
33d0: 72 6e 3b 0a 7d 0a 0a 66 75 6e 63 74 69 6f 6e 20  rn;.}..function 
33e0: 63 61 63 6b 65 79 49 6e 69 74 50 43 53 43 43 6f  cackeyInitPCSCCo
33f0: 6d 70 6c 65 74 65 64 28 73 74 61 74 65 29 20 7b  mpleted(state) {
3400: 0a 09 76 61 72 20 69 64 78 3b 0a 0a 09 63 6f 6e  ..var idx;...con
3410: 73 6f 6c 65 2e 6c 6f 67 28 22 5b 63 61 63 6b 65  sole.log("[cacke
3420: 79 5d 20 43 6f 6e 6e 65 63 74 69 6f 6e 20 63 6f  y] Connection co
3430: 6d 70 6c 65 74 65 64 20 28 73 74 61 74 65 20 3d  mpleted (state =
3440: 20 5c 22 22 20 2b 20 73 74 61 74 65 20 2b 20 22   \"" + state + "
3450: 5c 22 29 2c 20 73 65 6e 64 69 6e 67 20 71 75 65  \"), sending que
3460: 75 65 64 20 65 76 65 6e 74 73 3a 20 22 20 2b 20  ued events: " + 
3470: 63 61 63 6b 65 79 43 61 6c 6c 62 61 63 6b 41 66  cackeyCallbackAf
3480: 74 65 72 49 6e 69 74 2e 6c 65 6e 67 74 68 29 3b  terInit.length);
3490: 0a 0a 09 73 77 69 74 63 68 20 28 73 74 61 74 65  ...switch (state
34a0: 29 20 7b 0a 09 09 63 61 73 65 20 22 73 75 63 63  ) {...case "succ
34b0: 65 73 73 22 3a 0a 09 09 09 63 61 63 6b 65 79 50  ess":....cackeyP
34c0: 43 53 43 48 61 6e 64 6c 65 55 73 61 62 6c 65 20  CSCHandleUsable 
34d0: 3d 20 74 72 75 65 3b 0a 0a 09 09 09 62 72 65 61  = true;.....brea
34e0: 6b 3b 0a 09 09 63 61 73 65 20 22 66 61 69 6c 75  k;...case "failu
34f0: 72 65 22 3a 0a 09 09 09 63 61 63 6b 65 79 50 43  re":....cackeyPC
3500: 53 43 48 61 6e 64 6c 65 55 73 61 62 6c 65 20 3d  SCHandleUsable =
3510: 20 66 61 6c 73 65 3b 0a 0a 09 09 09 62 72 65 61   false;.....brea
3520: 6b 3b 0a 09 7d 0a 0a 09 66 6f 72 20 28 69 64 78  k;..}...for (idx
3530: 20 3d 20 30 3b 20 69 64 78 20 3c 20 63 61 63 6b   = 0; idx < cack
3540: 65 79 43 61 6c 6c 62 61 63 6b 41 66 74 65 72 49  eyCallbackAfterI
3550: 6e 69 74 2e 6c 65 6e 67 74 68 3b 20 69 64 78 2b  nit.length; idx+
3560: 2b 29 20 7b 0a 09 09 69 66 20 28 21 63 61 63 6b  +) {...if (!cack
3570: 65 79 43 61 6c 6c 62 61 63 6b 41 66 74 65 72 49  eyCallbackAfterI
3580: 6e 69 74 5b 69 64 78 5d 29 20 7b 0a 09 09 09 63  nit[idx]) {....c
3590: 6f 6e 74 69 6e 75 65 3b 0a 09 09 7d 0a 0a 09 09  ontinue;...}....
35a0: 73 77 69 74 63 68 20 28 73 74 61 74 65 29 20 7b  switch (state) {
35b0: 0a 09 09 09 63 61 73 65 20 22 73 75 63 63 65 73  ....case "succes
35c0: 73 22 3a 0a 09 09 09 09 28 63 61 63 6b 65 79 43  s":.....(cackeyC
35d0: 61 6c 6c 62 61 63 6b 41 66 74 65 72 49 6e 69 74  allbackAfterInit
35e0: 5b 69 64 78 5d 2e 73 75 63 63 65 73 73 43 61 6c  [idx].successCal
35f0: 6c 62 61 63 6b 29 28 29 3b 0a 0a 09 09 09 09 62  lback)();......b
3600: 72 65 61 6b 3b 0a 09 09 09 63 61 73 65 20 22 66  reak;....case "f
3610: 61 69 6c 75 72 65 22 3a 0a 09 09 09 09 28 63 61  ailure":.....(ca
3620: 63 6b 65 79 43 61 6c 6c 62 61 63 6b 41 66 74 65  ckeyCallbackAfte
3630: 72 49 6e 69 74 5b 69 64 78 5d 2e 66 61 69 6c 75  rInit[idx].failu
3640: 72 65 43 61 6c 6c 62 61 63 6b 29 28 29 3b 0a 0a  reCallback)();..
3650: 09 09 09 09 62 72 65 61 6b 3b 0a 09 09 7d 0a 09  ....break;...}..
3660: 7d 0a 0a 09 64 65 6c 65 74 65 20 63 61 63 6b 65  }...delete cacke
3670: 79 43 61 6c 6c 62 61 63 6b 41 66 74 65 72 49 6e  yCallbackAfterIn
3680: 69 74 3b 0a 0a 09 63 61 63 6b 65 79 43 61 6c 6c  it;...cackeyCall
3690: 62 61 63 6b 41 66 74 65 72 49 6e 69 74 20 3d 20  backAfterInit = 
36a0: 5b 5d 3b 0a 0a 09 63 6f 6e 73 6f 6c 65 2e 6c 6f  [];...console.lo
36b0: 67 28 22 5b 63 61 63 6b 65 79 5d 20 41 6c 6c 20  g("[cackey] All 
36c0: 71 75 65 75 65 64 20 65 76 65 6e 74 73 20 70 72  queued events pr
36d0: 6f 63 65 73 73 65 64 22 29 3b 0a 0a 09 72 65 74  ocessed");...ret
36e0: 75 72 6e 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 20 49 6e  urn;.}../*. * In
36f0: 69 74 69 61 6c 69 7a 65 20 74 68 65 20 50 43 53  itialize the PCS
3700: 43 20 63 6f 6e 6e 65 63 74 69 6f 6e 0a 20 2a 2f  C connection. */
3710: 0a 66 75 6e 63 74 69 6f 6e 20 63 61 63 6b 65 79  .function cackey
3720: 49 6e 69 74 50 43 53 43 28 63 61 6c 6c 62 61 63  InitPCSC(callbac
3730: 6b 41 66 74 65 72 49 6e 69 74 2c 20 63 61 6c 6c  kAfterInit, call
3740: 62 61 63 6b 49 6e 69 74 46 61 69 6c 65 64 29 20  backInitFailed) 
3750: 7b 0a 09 2f 2a 0a 09 20 2a 20 53 74 61 72 74 20  {../*.. * Start 
3760: 74 68 65 20 47 6f 6f 67 6c 65 20 50 43 53 43 20  the Google PCSC 
3770: 49 6e 74 65 72 66 61 63 65 0a 09 20 2a 2f 0a 0a  Interface.. */..
3780: 09 63 6f 6e 73 6f 6c 65 2e 6c 6f 67 28 22 5b 63  .console.log("[c
3790: 61 63 6b 65 79 5d 20 63 61 63 6b 65 79 49 6e 69  ackey] cackeyIni
37a0: 74 50 43 53 43 28 29 20 63 61 6c 6c 65 64 22 29  tPCSC() called")
37b0: 3b 0a 0a 09 2f 2a 0a 09 20 2a 20 51 75 65 75 65  ;.../*.. * Queue
37c0: 20 74 68 69 73 20 63 61 6c 6c 62 61 63 6b 20 74   this callback t
37d0: 6f 20 62 65 20 63 6f 6d 70 6c 65 74 65 64 20 77  o be completed w
37e0: 68 65 6e 20 69 6e 69 74 69 61 6c 69 7a 61 74 69  hen initializati
37f0: 6f 6e 20 69 73 20 63 6f 6d 70 6c 65 74 65 0a 09  on is complete..
3800: 20 2a 2f 0a 09 69 66 20 28 63 61 6c 6c 62 61 63   */..if (callbac
3810: 6b 41 66 74 65 72 49 6e 69 74 29 20 7b 0a 09 09  kAfterInit) {...
3820: 63 61 63 6b 65 79 43 61 6c 6c 62 61 63 6b 41 66  cackeyCallbackAf
3830: 74 65 72 49 6e 69 74 2e 70 75 73 68 28 7b 22 73  terInit.push({"s
3840: 75 63 63 65 73 73 43 61 6c 6c 62 61 63 6b 22 3a  uccessCallback":
3850: 20 63 61 6c 6c 62 61 63 6b 41 66 74 65 72 49 6e   callbackAfterIn
3860: 69 74 2c 20 22 66 61 69 6c 75 72 65 43 61 6c 6c  it, "failureCall
3870: 62 61 63 6b 22 3a 20 63 61 6c 6c 62 61 63 6b 49  back": callbackI
3880: 6e 69 74 46 61 69 6c 65 64 7d 29 3b 0a 09 7d 0a  nitFailed});..}.
3890: 0a 09 2f 2a 0a 09 20 2a 20 4e 6f 20 61 64 64 69  ../*.. * No addi
38a0: 74 69 6f 6e 61 6c 20 77 6f 72 6b 20 69 73 20 72  tional work is r
38b0: 65 71 75 69 72 65 64 0a 09 20 2a 2f 0a 0a 09 69  equired.. */...i
38c0: 66 20 28 63 61 63 6b 65 79 50 43 53 43 48 61 6e  f (cackeyPCSCHan
38d0: 64 6c 65 29 20 7b 0a 09 09 63 6f 6e 73 6f 6c 65  dle) {...console
38e0: 2e 6c 6f 67 28 22 5b 63 61 63 6b 65 79 5d 20 50  .log("[cackey] P
38f0: 43 53 43 20 68 61 6e 64 6c 65 20 69 73 20 61 6c  CSC handle is al
3900: 72 65 61 64 79 20 76 61 6c 69 64 2c 20 6e 6f 74  ready valid, not
3910: 68 69 6e 67 20 74 6f 20 64 6f 2e 22 29 3b 0a 0a  hing to do.");..
3920: 09 09 69 66 20 28 63 61 63 6b 65 79 50 43 53 43  ..if (cackeyPCSC
3930: 48 61 6e 64 6c 65 55 73 61 62 6c 65 29 20 7b 0a  HandleUsable) {.
3940: 09 09 09 63 61 63 6b 65 79 49 6e 69 74 50 43 53  ...cackeyInitPCS
3950: 43 43 6f 6d 70 6c 65 74 65 64 28 22 73 75 63 63  CCompleted("succ
3960: 65 73 73 22 29 3b 0a 09 09 7d 0a 0a 09 09 72 65  ess");...}....re
3970: 74 75 72 6e 3b 0a 09 7d 0a 0a 09 2f 2a 0a 09 20  turn;..}.../*.. 
3980: 2a 20 53 61 6e 65 6c 79 20 69 6e 69 74 69 61 6c  * Sanely initial
3990: 69 7a 65 20 74 68 69 73 0a 09 20 2a 2f 0a 09 63  ize this.. */..c
39a0: 61 63 6b 65 79 50 43 53 43 48 61 6e 64 6c 65 55  ackeyPCSCHandleU
39b0: 73 61 62 6c 65 20 3d 20 66 61 6c 73 65 3b 0a 0a  sable = false;..
39c0: 09 2f 2a 0a 09 20 2a 20 49 6e 69 74 69 61 6c 69  ./*.. * Initiali
39d0: 7a 65 20 74 68 65 20 43 41 43 4b 65 79 20 50 4e  ze the CACKey PN
39e0: 61 43 6c 20 6d 6f 64 75 6c 65 20 69 66 20 6e 65  aCl module if ne
39f0: 65 64 65 64 0a 09 20 2a 2f 0a 09 69 66 20 28 63  eded.. */..if (c
3a00: 61 63 6b 65 79 48 61 6e 64 6c 65 20 3d 3d 20 6e  ackeyHandle == n
3a10: 75 6c 6c 29 20 7b 0a 09 09 63 61 63 6b 65 79 49  ull) {...cackeyI
3a20: 6e 69 74 28 29 3b 0a 09 7d 0a 0a 09 2f 2a 0a 09  nit();..}.../*..
3a30: 20 2a 20 49 6e 69 74 69 61 6c 69 7a 65 20 43 41   * Initialize CA
3a40: 43 4b 65 79 20 77 69 74 68 20 74 68 65 20 63 6f  CKey with the co
3a50: 72 72 65 63 74 20 68 61 6e 64 6c 65 20 74 6f 20  rrect handle to 
3a60: 74 61 6c 6b 20 74 6f 20 74 68 65 20 47 6f 6f 67  talk to the Goog
3a70: 6c 65 20 53 6d 61 72 74 63 61 72 64 20 4d 61 6e  le Smartcard Man
3a80: 61 67 65 72 20 41 70 70 0a 09 20 2a 2f 0a 09 63  ager App.. */..c
3a90: 61 63 6b 65 79 48 61 6e 64 6c 65 2e 70 6f 73 74  ackeyHandle.post
3aa0: 4d 65 73 73 61 67 65 28 0a 09 09 7b 0a 09 09 09  Message(...{....
3ab0: 22 74 61 72 67 65 74 22 3a 20 22 63 61 63 6b 65  "target": "cacke
3ac0: 79 22 2c 0a 09 09 09 22 63 6f 6d 6d 61 6e 64 22  y",...."command"
3ad0: 3a 20 22 69 6e 69 74 22 2c 0a 09 09 09 22 73 6d  : "init",...."sm
3ae0: 61 72 74 63 61 72 64 4d 61 6e 61 67 65 72 41 70  artcardManagerAp
3af0: 70 49 64 22 3a 20 22 6b 68 70 66 65 61 61 6e 6a  pId": "khpfeaanj
3b00: 6e 67 6d 63 6e 70 6c 62 64 6c 70 65 67 69 69 66  ngmcnplbdlpegiif
3b10: 67 70 66 67 64 63 6f 22 0a 09 09 7d 0a 09 29 3b  gpfgdco"...}..);
3b20: 0a 0a 09 2f 2a 0a 09 20 2a 20 49 6e 69 74 69 61  .../*.. * Initia
3b30: 6c 69 7a 65 20 74 68 65 20 50 43 53 43 20 4e 61  lize the PCSC Na
3b40: 43 6c 20 69 6e 74 65 72 66 61 63 65 0a 09 20 2a  Cl interface.. *
3b50: 2f 0a 09 63 61 63 6b 65 79 50 43 53 43 48 61 6e  /..cackeyPCSCHan
3b60: 64 6c 65 20 3d 20 6e 65 77 20 47 6f 6f 67 6c 65  dle = new Google
3b70: 53 6d 61 72 74 43 61 72 64 2e 50 63 73 63 4e 61  SmartCard.PcscNa
3b80: 63 6c 28 63 61 63 6b 65 79 48 61 6e 64 6c 65 29  cl(cackeyHandle)
3b90: 3b 0a 0a 09 63 6f 6e 73 6f 6c 65 2e 6c 6f 67 28  ;...console.log(
3ba0: 22 5b 63 61 63 6b 65 79 5d 20 63 61 63 6b 65 79  "[cackey] cackey
3bb0: 49 6e 69 74 50 43 53 43 28 29 20 63 6f 6d 70 6c  InitPCSC() compl
3bc0: 65 74 65 22 29 3b 0a 0a 09 72 65 74 75 72 6e 3b  ete");...return;
3bd0: 0a 7d 0a 0a 2f 2a 0a 20 2a 20 46 69 6e 69 73 68  .}../*. * Finish
3be0: 20 70 65 72 66 6f 72 6d 69 6e 67 20 69 6e 69 74   performing init
3bf0: 69 61 6c 69 7a 61 74 69 6f 6e 20 74 68 61 74 20  ialization that 
3c00: 6d 75 73 74 20 77 61 69 74 20 75 6e 74 69 6c 20  must wait until 
3c10: 77 65 20 68 61 76 65 20 6c 6f 61 64 65 64 20 74  we have loaded t
3c20: 68 65 20 43 41 43 4b 65 79 20 6d 6f 64 75 6c 65  he CACKey module
3c30: 0a 20 2a 2f 0a 66 75 6e 63 74 69 6f 6e 20 63 61  . */.function ca
3c40: 63 6b 65 79 49 6e 69 74 4c 6f 61 64 65 64 28 6d  ckeyInitLoaded(m
3c50: 65 73 73 61 67 65 45 76 65 6e 74 29 20 7b 0a 09  essageEvent) {..
3c60: 63 6f 6e 73 6f 6c 65 2e 6c 6f 67 28 22 5b 63 61  console.log("[ca
3c70: 63 6b 65 79 5d 20 4c 6f 61 64 65 64 20 43 41 43  ckey] Loaded CAC
3c80: 4b 65 79 20 50 4e 61 43 6c 20 4d 6f 64 75 6c 65  Key PNaCl Module
3c90: 22 29 3b 0a 0a 09 2f 2a 20 52 65 67 69 73 74 65  ");.../* Registe
3ca0: 72 20 6c 69 73 74 65 6e 65 72 73 20 77 69 74 68  r listeners with
3cb0: 20 43 68 72 6f 6d 65 20 2a 2f 0a 09 69 66 20 28   Chrome */..if (
3cc0: 63 68 72 6f 6d 65 2e 63 65 72 74 69 66 69 63 61  chrome.certifica
3cd0: 74 65 50 72 6f 76 69 64 65 72 29 20 7b 0a 09 09  teProvider) {...
3ce0: 63 6f 6e 73 6f 6c 65 2e 6c 6f 67 28 22 5b 63 61  console.log("[ca
3cf0: 63 6b 65 79 5d 20 52 65 67 69 73 74 65 72 65 64  ckey] Registered
3d00: 20 43 65 72 74 69 66 69 63 61 74 65 20 68 61 6e   Certificate han
3d10: 64 6c 65 72 73 20 77 69 74 68 20 43 68 72 6f 6d  dlers with Chrom
3d20: 65 22 29 3b 0a 0a 09 09 63 68 72 6f 6d 65 2e 63  e");....chrome.c
3d30: 65 72 74 69 66 69 63 61 74 65 50 72 6f 76 69 64  ertificateProvid
3d40: 65 72 2e 6f 6e 43 65 72 74 69 66 69 63 61 74 65  er.onCertificate
3d50: 73 52 65 71 75 65 73 74 65 64 2e 61 64 64 4c 69  sRequested.addLi
3d60: 73 74 65 6e 65 72 28 63 61 63 6b 65 79 4c 69 73  stener(cackeyLis
3d70: 74 43 65 72 74 69 66 69 63 61 74 65 73 29 3b 0a  tCertificates);.
3d80: 09 09 63 68 72 6f 6d 65 2e 63 65 72 74 69 66 69  ..chrome.certifi
3d90: 63 61 74 65 50 72 6f 76 69 64 65 72 2e 6f 6e 53  cateProvider.onS
3da0: 69 67 6e 44 69 67 65 73 74 52 65 71 75 65 73 74  ignDigestRequest
3db0: 65 64 2e 61 64 64 4c 69 73 74 65 6e 65 72 28 63  ed.addListener(c
3dc0: 61 63 6b 65 79 53 69 67 6e 4d 65 73 73 61 67 65  ackeySignMessage
3dd0: 29 3b 0a 09 7d 0a 0a 09 72 65 74 75 72 6e 3b 0a  );..}...return;.
3de0: 7d 0a 0a 2f 2a 0a 20 2a 20 49 6e 69 74 69 61 6c  }../*. * Initial
3df0: 69 7a 65 20 43 41 43 4b 65 79 20 61 6e 64 20 74  ize CACKey and t
3e00: 68 65 20 50 43 53 43 20 6c 69 62 72 61 72 79 20  he PCSC library 
3e10: 66 72 6f 6d 20 47 6f 6f 67 6c 65 0a 20 2a 2f 0a  from Google. */.
3e20: 66 75 6e 63 74 69 6f 6e 20 63 61 63 6b 65 79 49  function cackeyI
3e30: 6e 69 74 28 29 20 7b 0a 09 76 61 72 20 65 6c 65  nit() {..var ele
3e40: 6d 65 6e 74 45 6d 62 65 64 3b 0a 09 76 61 72 20  mentEmbed;..var 
3e50: 66 6f 72 63 65 4c 6f 61 64 45 6c 65 6d 65 6e 74  forceLoadElement
3e60: 3b 0a 0a 09 2f 2a 20 4c 6f 67 20 74 68 61 74 20  ;.../* Log that 
3e70: 77 65 20 61 72 65 20 6f 70 65 72 61 74 69 6f 6e  we are operation
3e80: 61 6c 20 2a 2f 0a 09 63 6f 6e 73 6f 6c 65 2e 6c  al */..console.l
3e90: 6f 67 28 22 5b 63 61 63 6b 65 79 5d 20 63 61 63  og("[cackey] cac
3ea0: 6b 65 79 49 6e 69 74 28 29 3a 20 43 61 6c 6c 65  keyInit(): Calle
3eb0: 64 2e 22 29 3b 0a 0a 09 2f 2a 0a 09 20 2a 20 44  d.");.../*.. * D
3ec0: 6f 20 6e 6f 74 20 69 6e 69 74 69 61 6c 69 7a 65  o not initialize
3ed0: 20 6d 75 6c 74 69 70 6c 65 20 74 69 6d 65 73 0a   multiple times.
3ee0: 09 20 2a 2f 0a 09 69 66 20 28 63 61 63 6b 65 79  . */..if (cackey
3ef0: 48 61 6e 64 6c 65 20 21 3d 20 6e 75 6c 6c 29 20  Handle != null) 
3f00: 7b 0a 09 09 63 6f 6e 73 6f 6c 65 2e 6c 6f 67 28  {...console.log(
3f10: 22 5b 63 61 63 6b 65 79 5d 20 63 61 63 6b 65 79  "[cackey] cackey
3f20: 49 6e 69 74 28 29 3a 20 41 6c 72 65 61 64 79 20  Init(): Already 
3f30: 69 6e 69 74 69 61 6c 69 7a 65 64 2e 20 20 52 65  initialized.  Re
3f40: 74 75 72 6e 69 6e 67 2e 22 29 3b 0a 0a 09 09 72  turning.");....r
3f50: 65 74 75 72 6e 3b 0a 09 7d 0a 0a 09 2f 2a 20 56  eturn;..}.../* V
3f60: 65 72 69 66 79 20 74 68 61 74 20 77 65 20 63 61  erify that we ca
3f70: 6e 20 72 65 67 69 73 74 65 72 20 63 61 6c 6c 62  n register callb
3f80: 61 63 6b 73 20 2a 2f 0a 09 69 66 20 28 21 63 68  acks */..if (!ch
3f90: 72 6f 6d 65 2e 63 65 72 74 69 66 69 63 61 74 65  rome.certificate
3fa0: 50 72 6f 76 69 64 65 72 29 20 7b 0a 09 09 69 66  Provider) {...if
3fb0: 20 28 21 47 6f 6f 67 6c 65 53 6d 61 72 74 43 61   (!GoogleSmartCa
3fc0: 72 64 2e 49 53 5f 44 45 42 55 47 5f 42 55 49 4c  rd.IS_DEBUG_BUIL
3fd0: 44 29 20 7b 0a 09 09 09 63 6f 6e 73 6f 6c 65 2e  D) {....console.
3fe0: 69 6e 66 6f 28 22 5b 63 61 63 6b 65 79 5d 20 54  info("[cackey] T
3ff0: 68 69 73 20 65 78 74 65 6e 73 69 6f 6e 27 73 20  his extension's 
4000: 70 72 69 6d 61 72 79 20 66 75 6e 63 74 69 6f 6e  primary function
4010: 61 6c 69 74 79 20 6f 6e 6c 79 20 77 6f 72 6b 73  ality only works
4020: 20 6f 6e 20 43 68 72 6f 6d 65 4f 53 21 20 20 59   on ChromeOS!  Y
4030: 6f 75 20 77 6f 6e 27 74 20 62 65 20 61 62 6c 65  ou won't be able
4040: 20 74 6f 20 64 6f 20 6d 75 63 68 20 77 69 74 68   to do much with
4050: 20 69 74 2e 22 29 3b 0a 09 09 7d 0a 09 7d 0a 0a   it.");...}..}..
4060: 09 65 6c 65 6d 65 6e 74 45 6d 62 65 64 20 3d 20  .elementEmbed = 
4070: 64 6f 63 75 6d 65 6e 74 2e 63 72 65 61 74 65 45  document.createE
4080: 6c 65 6d 65 6e 74 28 27 65 6d 62 65 64 27 29 3b  lement('embed');
4090: 0a 09 65 6c 65 6d 65 6e 74 45 6d 62 65 64 2e 74  ..elementEmbed.t
40a0: 79 70 65 20 3d 20 22 61 70 70 6c 69 63 61 74 69  ype = "applicati
40b0: 6f 6e 2f 78 2d 70 6e 61 63 6c 22 3b 0a 09 65 6c  on/x-pnacl";..el
40c0: 65 6d 65 6e 74 45 6d 62 65 64 2e 77 69 64 74 68  ementEmbed.width
40d0: 20 3d 20 30 3b 0a 09 65 6c 65 6d 65 6e 74 45 6d   = 0;..elementEm
40e0: 62 65 64 2e 68 65 69 67 68 74 20 3d 20 30 3b 0a  bed.height = 0;.
40f0: 09 65 6c 65 6d 65 6e 74 45 6d 62 65 64 2e 73 72  .elementEmbed.sr
4100: 63 20 3d 20 22 63 61 63 6b 65 79 2e 6e 6d 66 22  c = "cackey.nmf"
4110: 3b 0a 09 65 6c 65 6d 65 6e 74 45 6d 62 65 64 2e  ;..elementEmbed.
4120: 69 64 20 3d 20 22 63 61 63 6b 65 79 4d 6f 64 75  id = "cackeyModu
4130: 6c 65 22 3b 0a 09 65 6c 65 6d 65 6e 74 45 6d 62  le";..elementEmb
4140: 65 64 2e 61 64 64 45 76 65 6e 74 4c 69 73 74 65  ed.addEventListe
4150: 6e 65 72 28 27 65 72 72 6f 72 27 2c 20 66 75 6e  ner('error', fun
4160: 63 74 69 6f 6e 28 6d 65 73 73 61 67 65 45 76 65  ction(messageEve
4170: 6e 74 29 20 7b 20 63 6f 6e 73 6f 6c 65 2e 65 72  nt) { console.er
4180: 72 6f 72 28 22 45 72 72 6f 72 20 6c 6f 61 64 69  ror("Error loadi
4190: 6e 67 20 43 41 43 4b 65 79 20 50 4e 61 43 6c 20  ng CACKey PNaCl 
41a0: 4d 6f 64 75 6c 65 3a 20 22 20 2b 20 6d 65 73 73  Module: " + mess
41b0: 61 67 65 45 76 65 6e 74 2e 64 61 74 61 29 3b 20  ageEvent.data); 
41c0: 7d 2c 20 74 72 75 65 29 3b 0a 09 65 6c 65 6d 65  }, true);..eleme
41d0: 6e 74 45 6d 62 65 64 2e 61 64 64 45 76 65 6e 74  ntEmbed.addEvent
41e0: 4c 69 73 74 65 6e 65 72 28 27 6c 6f 61 64 27 2c  Listener('load',
41f0: 20 63 61 63 6b 65 79 49 6e 69 74 4c 6f 61 64 65   cackeyInitLoade
4200: 64 2c 20 74 72 75 65 29 3b 0a 09 65 6c 65 6d 65  d, true);..eleme
4210: 6e 74 45 6d 62 65 64 2e 61 64 64 45 76 65 6e 74  ntEmbed.addEvent
4220: 4c 69 73 74 65 6e 65 72 28 27 63 72 61 73 68 27  Listener('crash'
4230: 2c 20 63 61 63 6b 65 79 43 72 61 73 68 2c 20 74  , cackeyCrash, t
4240: 72 75 65 29 3b 0a 09 65 6c 65 6d 65 6e 74 45 6d  rue);..elementEm
4250: 62 65 64 2e 61 64 64 45 76 65 6e 74 4c 69 73 74  bed.addEventList
4260: 65 6e 65 72 28 27 6d 65 73 73 61 67 65 27 2c 20  ener('message', 
4270: 63 61 63 6b 65 79 4d 65 73 73 61 67 65 49 6e 63  cackeyMessageInc
4280: 6f 6d 69 6e 67 2c 20 74 72 75 65 29 3b 0a 0a 09  oming, true);...
4290: 63 61 63 6b 65 79 48 61 6e 64 6c 65 20 3d 20 65  cackeyHandle = e
42a0: 6c 65 6d 65 6e 74 45 6d 62 65 64 3b 0a 0a 09 64  lementEmbed;...d
42b0: 6f 63 75 6d 65 6e 74 2e 62 6f 64 79 2e 61 70 70  ocument.body.app
42c0: 65 6e 64 43 68 69 6c 64 28 63 61 63 6b 65 79 48  endChild(cackeyH
42d0: 61 6e 64 6c 65 29 0a 0a 09 2f 2a 0a 09 20 2a 20  andle).../*.. * 
42e0: 46 6f 72 63 65 20 74 68 65 20 62 72 6f 77 73 65  Force the browse
42f0: 72 20 74 6f 20 6c 6f 61 64 20 74 68 65 20 65 6c  r to load the el
4300: 65 6d 65 6e 74 0a 09 20 2a 20 62 79 20 72 65 71  ement.. * by req
4310: 75 65 73 74 69 6e 67 20 69 74 73 20 70 6f 73 69  uesting its posi
4320: 74 69 6f 6e 0a 09 20 2a 2f 0a 09 66 6f 72 63 65  tion.. */..force
4330: 4c 6f 61 64 45 6c 65 6d 65 6e 74 20 3d 20 63 61  LoadElement = ca
4340: 63 6b 65 79 48 61 6e 64 6c 65 2e 6f 66 66 73 65  ckeyHandle.offse
4350: 74 54 6f 70 3b 0a 0a 09 63 6f 6e 73 6f 6c 65 2e  tTop;...console.
4360: 6c 6f 67 28 22 5b 63 61 63 6b 65 79 5d 20 63 61  log("[cackey] ca
4370: 63 6b 65 79 49 6e 69 74 28 29 3a 20 43 6f 6d 70  ckeyInit(): Comp
4380: 6c 65 74 65 64 2e 20 20 52 65 74 75 72 6e 69 6e  leted.  Returnin
4390: 67 2e 22 29 3b 0a 0a 09 72 65 74 75 72 6e 3b 0a  g.");...return;.
43a0: 7d 0a 0a 2f 2a 0a 20 2a 20 49 6e 69 74 69 61 6c  }../*. * Initial
43b0: 69 7a 65 20 74 68 65 20 43 41 43 4b 65 79 20 43  ize the CACKey C
43c0: 68 72 6f 6d 65 20 41 70 70 6c 69 63 61 74 69 6f  hrome Applicatio
43d0: 6e 0a 20 2a 2f 0a 66 75 6e 63 74 69 6f 6e 20 63  n. */.function c
43e0: 61 63 6b 65 79 41 70 70 49 6e 69 74 28 29 20 7b  ackeyAppInit() {
43f0: 0a 09 76 61 72 20 6f 6c 64 4f 6e 50 6f 72 74 44  ..var oldOnPortD
4400: 69 73 63 6f 6e 6e 65 63 74 65 64 46 75 6e 63 74  isconnectedFunct
4410: 69 6f 6e 3b 0a 09 76 61 72 20 6f 6c 64 50 43 53  ion;..var oldPCS
4420: 43 49 6e 69 74 69 61 6c 69 7a 61 74 69 6f 6e 43  CInitializationC
4430: 61 6c 6c 62 61 63 6b 3b 0a 0a 09 2f 2a 0a 09 20  allback;.../*.. 
4440: 2a 20 43 72 65 61 74 65 20 61 20 68 61 6e 64 6c  * Create a handl
4450: 65 72 20 66 6f 72 20 73 74 61 72 74 69 6e 67 20  er for starting 
4460: 74 68 65 20 61 70 70 6c 69 63 61 74 69 6f 6e 20  the application 
4470: 55 49 0a 09 20 2a 2f 0a 09 63 68 72 6f 6d 65 2e  UI.. */..chrome.
4480: 61 70 70 2e 72 75 6e 74 69 6d 65 2e 6f 6e 4c 61  app.runtime.onLa
4490: 75 6e 63 68 65 64 2e 61 64 64 4c 69 73 74 65 6e  unched.addListen
44a0: 65 72 28 66 75 6e 63 74 69 6f 6e 28 29 20 7b 0a  er(function() {.
44b0: 09 09 63 68 72 6f 6d 65 2e 61 70 70 2e 77 69 6e  ..chrome.app.win
44c0: 64 6f 77 2e 63 72 65 61 74 65 28 27 75 69 2e 68  dow.create('ui.h
44d0: 74 6d 6c 27 2c 20 7b 0a 09 09 09 22 69 64 22 3a  tml', {...."id":
44e0: 20 22 63 61 63 6b 65 79 55 49 22 2c 0a 09 09 09   "cackeyUI",....
44f0: 22 66 6f 63 75 73 65 64 22 3a 20 74 72 75 65 2c  "focused": true,
4500: 0a 09 09 09 22 69 6e 6e 65 72 42 6f 75 6e 64 73  ...."innerBounds
4510: 22 3a 20 7b 0a 09 09 09 09 22 77 69 64 74 68 22  ": {....."width"
4520: 3a 20 33 35 30 2c 0a 09 09 09 09 22 6d 69 6e 57  : 350,....."minW
4530: 69 64 74 68 22 3a 20 33 35 30 2c 0a 09 09 09 09  idth": 350,.....
4540: 22 68 65 69 67 68 74 22 3a 20 31 33 35 2c 0a 09  "height": 135,..
4550: 09 09 09 22 6d 69 6e 48 65 69 67 68 74 22 3a 20  ..."minHeight": 
4560: 31 33 35 0a 09 09 09 7d 0a 09 09 7d 2c 20 66 75  135....}...}, fu
4570: 6e 63 74 69 6f 6e 28 75 69 57 69 6e 64 6f 77 29  nction(uiWindow)
4580: 20 7b 0a 09 09 09 69 66 20 28 21 75 69 57 69 6e   {....if (!uiWin
4590: 64 6f 77 29 20 7b 0a 09 09 09 09 72 65 74 75 72  dow) {.....retur
45a0: 6e 3b 0a 09 09 09 7d 0a 0a 09 09 09 75 69 57 69  n;....}.....uiWi
45b0: 6e 64 6f 77 2e 63 6f 6e 74 65 6e 74 57 69 6e 64  ndow.contentWind
45c0: 6f 77 2e 70 61 72 65 6e 74 57 69 6e 64 6f 77 20  ow.parentWindow 
45d0: 3d 20 77 69 6e 64 6f 77 3b 0a 09 09 7d 29 3b 0a  = window;...});.
45e0: 09 7d 29 3b 0a 0a 09 2f 2a 0a 09 20 2a 20 52 65  .});.../*.. * Re
45f0: 67 69 73 74 65 72 20 61 20 68 61 6e 64 6c 65 72  gister a handler
4600: 20 66 6f 72 20 64 65 61 6c 69 6e 67 20 77 69 74   for dealing wit
4610: 68 20 74 68 65 20 50 43 53 43 20 70 6f 72 74 20  h the PCSC port 
4620: 62 65 69 6e 67 20 64 69 73 63 6f 6e 6e 65 63 74  being disconnect
4630: 65 64 0a 09 20 2a 2f 0a 09 6f 6c 64 4f 6e 50 6f  ed.. */..oldOnPo
4640: 72 74 44 69 73 63 6f 6e 6e 65 63 74 65 64 46 75  rtDisconnectedFu
4650: 6e 63 74 69 6f 6e 20 3d 20 47 6f 6f 67 6c 65 53  nction = GoogleS
4660: 6d 61 72 74 43 61 72 64 2e 50 63 73 63 2e 70 72  martCard.Pcsc.pr
4670: 6f 74 6f 74 79 70 65 2e 6f 6e 50 6f 72 74 44 69  ototype.onPortDi
4680: 73 63 6f 6e 6e 65 63 74 65 64 5f 3b 0a 09 47 6f  sconnected_;..Go
4690: 6f 67 6c 65 53 6d 61 72 74 43 61 72 64 2e 50 63  ogleSmartCard.Pc
46a0: 73 63 2e 70 72 6f 74 6f 74 79 70 65 2e 6f 6e 50  sc.prototype.onP
46b0: 6f 72 74 44 69 73 63 6f 6e 6e 65 63 74 65 64 5f  ortDisconnected_
46c0: 20 3d 20 66 75 6e 63 74 69 6f 6e 28 29 20 7b 0a   = function() {.
46d0: 09 09 6f 6c 64 4f 6e 50 6f 72 74 44 69 73 63 6f  ..oldOnPortDisco
46e0: 6e 6e 65 63 74 65 64 46 75 6e 63 74 69 6f 6e 2e  nnectedFunction.
46f0: 61 70 70 6c 79 28 74 68 69 73 29 3b 0a 0a 09 09  apply(this);....
4700: 63 61 63 6b 65 79 49 6e 69 74 50 43 53 43 43 6f  cackeyInitPCSCCo
4710: 6d 70 6c 65 74 65 64 28 22 66 61 69 6c 75 72 65  mpleted("failure
4720: 22 29 3b 0a 0a 09 09 63 61 63 6b 65 79 52 65 73  ");....cackeyRes
4730: 74 61 72 74 28 29 3b 0a 0a 09 09 72 65 74 75 72  tart();....retur
4740: 6e 3b 0a 09 7d 3b 0a 0a 09 2f 2a 0a 09 20 2a 20  n;..};.../*.. * 
4750: 52 65 67 69 73 74 65 72 20 61 20 68 61 6e 64 6c  Register a handl
4760: 65 72 20 66 6f 72 20 64 65 61 6c 69 6e 67 20 77  er for dealing w
4770: 69 74 68 20 74 68 65 20 50 43 53 43 20 70 6f 72  ith the PCSC por
4780: 74 20 62 65 69 6e 67 20 61 76 61 69 6c 61 62 6c  t being availabl
4790: 65 0a 09 20 2a 2f 0a 09 6f 6c 64 50 43 53 43 49  e.. */..oldPCSCI
47a0: 6e 69 74 69 61 6c 69 7a 61 74 69 6f 6e 43 61 6c  nitializationCal
47b0: 6c 62 61 63 6b 20 3d 20 47 6f 6f 67 6c 65 53 6d  lback = GoogleSm
47c0: 61 72 74 43 61 72 64 2e 50 63 73 63 4e 61 63 6c  artCard.PcscNacl
47d0: 2e 70 72 6f 74 6f 74 79 70 65 2e 70 63 73 63 49  .prototype.pcscI
47e0: 6e 69 74 69 61 6c 69 7a 61 74 69 6f 6e 43 61 6c  nitializationCal
47f0: 6c 62 61 63 6b 5f 3b 0a 09 47 6f 6f 67 6c 65 53  lback_;..GoogleS
4800: 6d 61 72 74 43 61 72 64 2e 50 63 73 63 4e 61 63  martCard.PcscNac
4810: 6c 2e 70 72 6f 74 6f 74 79 70 65 2e 70 63 73 63  l.prototype.pcsc
4820: 49 6e 69 74 69 61 6c 69 7a 61 74 69 6f 6e 43 61  InitializationCa
4830: 6c 6c 62 61 63 6b 5f 20 3d 20 66 75 6e 63 74 69  llback_ = functi
4840: 6f 6e 28 72 65 71 75 65 73 74 49 64 2c 20 69 6e  on(requestId, in
4850: 73 74 61 6e 63 65 49 64 2c 20 69 6e 73 74 61 6e  stanceId, instan
4860: 63 65 2c 20 65 72 72 6f 72 29 20 7b 0a 09 09 6f  ce, error) {...o
4870: 6c 64 50 43 53 43 49 6e 69 74 69 61 6c 69 7a 61  ldPCSCInitializa
4880: 74 69 6f 6e 43 61 6c 6c 62 61 63 6b 2e 61 70 70  tionCallback.app
4890: 6c 79 28 74 68 69 73 2c 20 5b 72 65 71 75 65 73  ly(this, [reques
48a0: 74 49 64 2c 20 69 6e 73 74 61 6e 63 65 49 64 2c  tId, instanceId,
48b0: 20 69 6e 73 74 61 6e 63 65 2c 20 65 72 72 6f 72   instance, error
48c0: 5d 29 3b 0a 0a 09 09 72 65 74 75 72 6e 3b 0a 09  ]);....return;..
48d0: 7d 3b 0a 0a 09 2f 2a 0a 09 20 2a 20 49 6e 69 74  };.../*.. * Init
48e0: 69 61 6c 69 7a 65 20 67 6c 6f 62 61 6c 20 73 74  ialize global st
48f0: 61 74 65 0a 09 20 2a 2f 0a 09 63 61 63 6b 65 79  ate.. */..cackey
4900: 49 6e 69 74 47 6c 6f 62 61 6c 53 74 61 74 65 28  InitGlobalState(
4910: 29 3b 0a 0a 09 72 65 74 75 72 6e 3b 0a 7d 0a 0a  );...return;.}..
4920: 2f 2a 20 49 6e 69 74 69 61 6c 69 7a 65 20 43 41  /* Initialize CA
4930: 43 4b 65 79 20 2a 2f 0a 63 61 63 6b 65 79 41 70  CKey */.cackeyAp
4940: 70 49 6e 69 74 28 29 3b 0a 63 61 63 6b 65 79 49  pInit();.cackeyI
4950: 6e 69 74 28 29 3b 0a                             nit();.