Hex Artifact Content

Artifact 7141592f34de911fc0b018943a020bf328c0ceb3:


0000: 2f 2a 0a 20 2a 20 43 41 43 4b 65 79 20 53 53 48  /*. * CACKey SSH
0010: 20 41 67 65 6e 74 20 66 6f 72 20 43 68 72 6f 6d   Agent for Chrom
0020: 65 4f 53 0a 20 2a 2f 0a 0a 63 61 63 6b 65 79 53  eOS. */..cackeyS
0030: 53 48 41 67 65 6e 74 41 70 70 72 6f 76 65 64 41  SHAgentApprovedA
0040: 70 70 73 20 3d 20 5b 0a 09 22 70 6e 68 65 63 68  pps = [.."pnhech
0050: 61 70 66 61 69 6e 64 6a 68 6f 6d 70 62 6e 66 6c  apfaindjhompbnfl
0060: 63 6c 64 61 62 62 67 68 6a 6f 22 2c 0a 09 22 6f  cldabbghjo",.."o
0070: 6b 64 64 66 66 64 62 6c 66 68 68 6e 6d 68 6f 64  kddffdblfhhnmhod
0080: 6f 67 70 6f 6a 6d 66 6b 6a 6d 68 69 6e 66 70 22  ogpojmfkjmhinfp"
0090: 0a 5d 3b 0a 0a 2f 2a 0a 20 2a 20 58 58 58 3a 54  .];../*. * XXX:T
00a0: 4f 44 4f 3a 20 45 78 70 6f 73 65 20 55 49 20 66  ODO: Expose UI f
00b0: 6f 72 20 74 68 69 73 0a 20 2a 2f 0a 63 61 63 6b  or this. */.cack
00c0: 65 79 53 53 48 41 67 65 6e 74 46 65 61 74 75 72  eySSHAgentFeatur
00d0: 65 73 20 3d 20 7b 0a 09 65 6e 61 62 6c 65 64 3a  es = {..enabled:
00e0: 20 74 72 75 65 2c 0a 09 69 6e 63 6c 75 64 65 4b   true,..includeK
00f0: 65 79 73 3a 20 74 72 75 65 2c 0a 09 69 6e 63 6c  eys: true,..incl
0100: 75 64 65 43 65 72 74 73 3a 20 74 72 75 65 2c 0a  udeCerts: true,.
0110: 09 6c 65 67 61 63 79 3a 20 66 61 6c 73 65 0a 7d  .legacy: false.}
0120: 3b 0a 0a 2f 2a 0a 20 2a 20 46 65 61 74 75 72 65  ;../*. * Feature
0130: 20 73 75 70 70 6f 72 74 20 63 68 65 63 6b 69 6e   support checkin
0140: 67 0a 20 2a 2f 0a 66 75 6e 63 74 69 6f 6e 20 63  g. */.function c
0150: 61 63 6b 65 79 53 53 48 41 67 65 6e 74 47 65 74  ackeySSHAgentGet
0160: 53 53 48 4b 65 79 54 79 70 65 73 28 29 20 7b 0a  SSHKeyTypes() {.
0170: 09 76 61 72 20 74 79 70 65 73 20 3d 20 5b 5d 3b  .var types = [];
0180: 0a 0a 09 69 66 20 28 63 61 63 6b 65 79 53 53 48  ...if (cackeySSH
0190: 41 67 65 6e 74 46 65 61 74 75 72 65 73 2e 69 6e  AgentFeatures.in
01a0: 63 6c 75 64 65 4b 65 79 73 29 20 7b 0a 09 09 74  cludeKeys) {...t
01b0: 79 70 65 73 2e 70 75 73 68 28 22 73 73 68 22 29  ypes.push("ssh")
01c0: 3b 0a 09 7d 0a 0a 09 69 66 20 28 63 61 63 6b 65  ;..}...if (cacke
01d0: 79 53 53 48 41 67 65 6e 74 46 65 61 74 75 72 65  ySSHAgentFeature
01e0: 73 2e 69 6e 63 6c 75 64 65 43 65 72 74 73 29 20  s.includeCerts) 
01f0: 7b 0a 09 09 74 79 70 65 73 2e 70 75 73 68 28 22  {...types.push("
0200: 78 35 30 39 76 33 2d 73 73 68 22 29 3b 0a 0a 09  x509v3-ssh");...
0210: 09 69 66 20 28 63 61 63 6b 65 79 53 53 48 41 67  .if (cackeySSHAg
0220: 65 6e 74 46 65 61 74 75 72 65 73 2e 6c 65 67 61  entFeatures.lega
0230: 63 79 29 20 7b 0a 09 09 09 74 79 70 65 73 2e 70  cy) {....types.p
0240: 75 73 68 28 22 78 35 30 39 76 33 2d 73 69 67 6e  ush("x509v3-sign
0250: 22 29 3b 0a 09 09 7d 0a 09 7d 0a 0a 09 72 65 74  ");...}..}...ret
0260: 75 72 6e 28 74 79 70 65 73 29 3b 0a 7d 0a 0a 61  urn(types);.}..a
0270: 73 79 6e 63 20 66 75 6e 63 74 69 6f 6e 20 63 61  sync function ca
0280: 63 6b 65 79 53 53 48 41 67 65 6e 74 47 65 74 43  ckeySSHAgentGetC
0290: 65 72 74 69 66 69 63 61 74 65 73 28 29 20 7b 0a  ertificates() {.
02a0: 09 76 61 72 20 63 65 72 74 73 3b 0a 0a 09 69 66  .var certs;...if
02b0: 20 28 21 63 61 63 6b 65 79 53 53 48 41 67 65 6e   (!cackeySSHAgen
02c0: 74 46 65 61 74 75 72 65 73 2e 65 6e 61 62 6c 65  tFeatures.enable
02d0: 64 29 20 7b 0a 09 09 72 65 74 75 72 6e 28 5b 5d  d) {...return([]
02e0: 29 3b 0a 09 7d 0a 0a 09 63 65 72 74 73 20 3d 20  );..}...certs = 
02f0: 61 77 61 69 74 20 63 61 63 6b 65 79 4c 69 73 74  await cackeyList
0300: 43 65 72 74 69 66 69 63 61 74 65 73 28 29 3b 0a  Certificates();.
0310: 0a 09 72 65 74 75 72 6e 28 63 65 72 74 73 29 3b  ..return(certs);
0320: 0a 7d 0a 0a 2f 2a 0a 20 2a 20 53 53 48 20 45 6c  .}../*. * SSH El
0330: 65 6d 65 6e 74 20 45 6e 63 6f 64 69 6e 67 2f 44  ement Encoding/D
0340: 65 63 6f 64 69 6e 67 0a 20 2a 2f 0a 66 75 6e 63  ecoding. */.func
0350: 74 69 6f 6e 20 63 61 63 6b 65 79 53 53 48 41 67  tion cackeySSHAg
0360: 65 6e 74 45 6e 63 6f 64 65 49 6e 74 28 75 69 6e  entEncodeInt(uin
0370: 74 33 32 29 20 7b 0a 09 76 61 72 20 72 65 73 75  t32) {..var resu
0380: 6c 74 3b 0a 0a 09 72 65 73 75 6c 74 20 3d 20 5b  lt;...result = [
0390: 0a 09 09 28 75 69 6e 74 33 32 20 3e 3e 20 32 34  ...(uint32 >> 24
03a0: 29 20 26 20 30 78 66 66 2c 0a 09 09 28 75 69 6e  ) & 0xff,...(uin
03b0: 74 33 32 20 3e 3e 20 31 36 29 20 26 20 30 78 66  t32 >> 16) & 0xf
03c0: 66 2c 0a 09 09 28 75 69 6e 74 33 32 20 3e 3e 20  f,...(uint32 >> 
03d0: 20 38 29 20 26 20 30 78 66 66 2c 0a 09 09 20 75   8) & 0xff,... u
03e0: 69 6e 74 33 32 20 20 20 20 20 20 20 20 26 20 30  int32        & 0
03f0: 78 66 66 0a 09 5d 3b 0a 0a 09 72 65 74 75 72 6e  xff..];...return
0400: 28 72 65 73 75 6c 74 29 3b 0a 7d 0a 0a 66 75 6e  (result);.}..fun
0410: 63 74 69 6f 6e 20 63 61 63 6b 65 79 53 53 48 41  ction cackeySSHA
0420: 67 65 6e 74 44 65 63 6f 64 65 49 6e 74 28 69 6e  gentDecodeInt(in
0430: 70 75 74 29 20 7b 0a 09 76 61 72 20 72 65 73 75  put) {..var resu
0440: 6c 74 3b 0a 0a 09 72 65 73 75 6c 74 20 3d 20 30  lt;...result = 0
0450: 3b 0a 09 72 65 73 75 6c 74 20 7c 3d 20 28 69 6e  ;..result |= (in
0460: 70 75 74 5b 30 5d 20 3c 3c 20 32 34 29 3b 0a 09  put[0] << 24);..
0470: 72 65 73 75 6c 74 20 7c 3d 20 28 69 6e 70 75 74  result |= (input
0480: 5b 31 5d 20 3c 3c 20 31 36 29 3b 0a 09 72 65 73  [1] << 16);..res
0490: 75 6c 74 20 7c 3d 20 28 69 6e 70 75 74 5b 32 5d  ult |= (input[2]
04a0: 20 3c 3c 20 38 29 3b 0a 09 72 65 73 75 6c 74 20   << 8);..result 
04b0: 7c 3d 20 20 69 6e 70 75 74 5b 33 5d 3b 0a 0a 09  |=  input[3];...
04c0: 72 65 74 75 72 6e 28 7b 0a 09 09 76 61 6c 75 65  return({...value
04d0: 3a 20 72 65 73 75 6c 74 2c 0a 09 09 6f 75 74 70  : result,...outp
04e0: 75 74 3a 20 69 6e 70 75 74 2e 73 6c 69 63 65 28  ut: input.slice(
04f0: 34 29 0a 09 7d 29 3b 0a 7d 0a 0a 66 75 6e 63 74  4)..});.}..funct
0500: 69 6f 6e 20 63 61 63 6b 65 79 53 53 48 41 67 65  ion cackeySSHAge
0510: 6e 74 45 6e 63 6f 64 65 42 69 67 49 6e 74 28 62  ntEncodeBigInt(b
0520: 69 67 49 6e 74 29 20 7b 0a 09 76 61 72 20 72 65  igInt) {..var re
0530: 73 75 6c 74 20 3d 20 5b 5d 3b 0a 0a 09 73 77 69  sult = [];...swi
0540: 74 63 68 20 28 74 79 70 65 6f 66 28 62 69 67 49  tch (typeof(bigI
0550: 6e 74 29 29 20 7b 0a 09 09 63 61 73 65 20 22 6e  nt)) {...case "n
0560: 75 6d 62 65 72 22 3a 0a 09 09 09 77 68 69 6c 65  umber":....while
0570: 20 28 62 69 67 49 6e 74 29 20 7b 0a 09 09 09 09   (bigInt) {.....
0580: 72 65 73 75 6c 74 2e 70 75 73 68 28 62 69 67 49  result.push(bigI
0590: 6e 74 20 26 20 30 78 66 66 29 3b 0a 09 09 09 09  nt & 0xff);.....
05a0: 62 69 67 49 6e 74 20 3d 20 62 69 67 49 6e 74 20  bigInt = bigInt 
05b0: 3e 3e 20 38 3b 0a 09 09 09 7d 0a 09 09 09 72 65  >> 8;....}....re
05c0: 73 75 6c 74 2e 72 65 76 65 72 73 65 28 29 3b 0a  sult.reverse();.
05d0: 09 09 09 62 72 65 61 6b 3b 0a 09 09 63 61 73 65  ...break;...case
05e0: 20 22 6f 62 6a 65 63 74 22 3a 0a 09 09 09 72 65   "object":....re
05f0: 73 75 6c 74 20 3d 20 41 72 72 61 79 2e 66 72 6f  sult = Array.fro
0600: 6d 28 6e 65 77 20 55 69 6e 74 38 41 72 72 61 79  m(new Uint8Array
0610: 28 62 69 67 49 6e 74 2e 74 6f 42 79 74 65 41 72  (bigInt.toByteAr
0620: 72 61 79 28 29 29 29 3b 0a 09 09 09 62 72 65 61  ray()));....brea
0630: 6b 3b 0a 09 7d 0a 0a 09 72 65 73 75 6c 74 20 3d  k;..}...result =
0640: 20 63 61 63 6b 65 79 53 53 48 41 67 65 6e 74 45   cackeySSHAgentE
0650: 6e 63 6f 64 65 4c 56 28 72 65 73 75 6c 74 29 3b  ncodeLV(result);
0660: 0a 0a 09 72 65 74 75 72 6e 28 72 65 73 75 6c 74  ...return(result
0670: 29 3b 0a 7d 0a 0a 66 75 6e 63 74 69 6f 6e 20 63  );.}..function c
0680: 61 63 6b 65 79 53 53 48 41 67 65 6e 74 45 6e 63  ackeySSHAgentEnc
0690: 6f 64 65 4c 56 28 69 6e 70 75 74 29 20 7b 0a 09  odeLV(input) {..
06a0: 76 61 72 20 72 65 73 75 6c 74 3b 0a 0a 09 72 65  var result;...re
06b0: 73 75 6c 74 20 3d 20 63 61 63 6b 65 79 53 53 48  sult = cackeySSH
06c0: 41 67 65 6e 74 45 6e 63 6f 64 65 49 6e 74 28 69  AgentEncodeInt(i
06d0: 6e 70 75 74 2e 6c 65 6e 67 74 68 29 3b 0a 09 72  nput.length);..r
06e0: 65 73 75 6c 74 20 3d 20 72 65 73 75 6c 74 2e 63  esult = result.c
06f0: 6f 6e 63 61 74 28 69 6e 70 75 74 29 3b 0a 0a 09  oncat(input);...
0700: 72 65 74 75 72 6e 28 72 65 73 75 6c 74 29 3b 0a  return(result);.
0710: 7d 0a 0a 66 75 6e 63 74 69 6f 6e 20 63 61 63 6b  }..function cack
0720: 65 79 53 53 48 41 67 65 6e 74 44 65 63 6f 64 65  eySSHAgentDecode
0730: 4c 56 28 69 6e 70 75 74 29 20 7b 0a 09 76 61 72  LV(input) {..var
0740: 20 72 65 73 75 6c 74 2c 20 69 6e 66 6f 3b 0a 0a   result, info;..
0750: 09 69 6e 66 6f 20 3d 20 63 61 63 6b 65 79 53 53  .info = cackeySS
0760: 48 41 67 65 6e 74 44 65 63 6f 64 65 49 6e 74 28  HAgentDecodeInt(
0770: 69 6e 70 75 74 29 3b 0a 09 69 66 20 28 69 6e 66  input);..if (inf
0780: 6f 2e 76 61 6c 75 65 20 3e 3d 20 69 6e 70 75 74  o.value >= input
0790: 2e 6c 65 6e 67 74 68 29 20 7b 0a 09 09 74 68 72  .length) {...thr
07a0: 6f 77 28 6e 65 77 20 45 72 72 6f 72 28 22 49 6e  ow(new Error("In
07b0: 76 61 6c 69 64 20 64 61 74 61 22 29 29 3b 0a 09  valid data"));..
07c0: 7d 0a 0a 09 69 6e 70 75 74 20 3d 20 69 6e 66 6f  }...input = info
07d0: 2e 6f 75 74 70 75 74 3b 0a 0a 09 72 65 73 75 6c  .output;...resul
07e0: 74 20 3d 20 69 6e 70 75 74 2e 73 6c 69 63 65 28  t = input.slice(
07f0: 30 2c 20 69 6e 66 6f 2e 76 61 6c 75 65 29 3b 0a  0, info.value);.
0800: 0a 09 72 65 74 75 72 6e 28 7b 0a 09 09 76 61 6c  ..return({...val
0810: 75 65 3a 20 72 65 73 75 6c 74 2c 0a 09 09 6f 75  ue: result,...ou
0820: 74 70 75 74 3a 20 69 6e 70 75 74 2e 73 6c 69 63  tput: input.slic
0830: 65 28 69 6e 66 6f 2e 76 61 6c 75 65 29 0a 09 7d  e(info.value)..}
0840: 29 3b 0a 7d 0a 0a 66 75 6e 63 74 69 6f 6e 20 63  );.}..function c
0850: 61 63 6b 65 79 53 53 48 41 67 65 6e 74 45 6e 63  ackeySSHAgentEnc
0860: 6f 64 65 41 72 72 61 79 28 69 6e 70 75 74 29 20  odeArray(input) 
0870: 7b 0a 09 76 61 72 20 72 65 73 75 6c 74 3b 0a 0a  {..var result;..
0880: 09 72 65 73 75 6c 74 20 3d 20 63 61 63 6b 65 79  .result = cackey
0890: 53 53 48 41 67 65 6e 74 45 6e 63 6f 64 65 49 6e  SSHAgentEncodeIn
08a0: 74 28 69 6e 70 75 74 2e 6c 65 6e 67 74 68 29 3b  t(input.length);
08b0: 0a 09 69 6e 70 75 74 2e 66 6f 72 45 61 63 68 28  ..input.forEach(
08c0: 66 75 6e 63 74 69 6f 6e 28 65 6c 65 6d 65 6e 74  function(element
08d0: 29 20 7b 0a 09 09 72 65 73 75 6c 74 20 3d 20 72  ) {...result = r
08e0: 65 73 75 6c 74 2e 63 6f 6e 63 61 74 28 63 61 63  esult.concat(cac
08f0: 6b 65 79 53 53 48 41 67 65 6e 74 45 6e 63 6f 64  keySSHAgentEncod
0900: 65 4c 56 28 65 6c 65 6d 65 6e 74 29 29 3b 0a 09  eLV(element));..
0910: 7d 29 3b 0a 0a 09 72 65 74 75 72 6e 28 72 65 73  });...return(res
0920: 75 6c 74 29 3b 0a 7d 0a 0a 66 75 6e 63 74 69 6f  ult);.}..functio
0930: 6e 20 63 61 63 6b 65 79 53 53 48 41 67 65 6e 74  n cackeySSHAgent
0940: 44 65 63 6f 64 65 41 72 72 61 79 28 69 6e 70 75  DecodeArray(inpu
0950: 74 29 20 7b 0a 09 76 61 72 20 69 74 65 6d 73 2c  t) {..var items,
0960: 20 69 6e 66 6f 3b 0a 09 76 61 72 20 69 74 65 6d   info;..var item
0970: 43 6f 75 6e 74 3b 0a 0a 09 69 6e 66 6f 20 3d 20  Count;...info = 
0980: 63 61 63 6b 65 79 53 53 48 41 67 65 6e 74 44 65  cackeySSHAgentDe
0990: 63 6f 64 65 49 6e 74 28 69 6e 70 75 74 29 3b 0a  codeInt(input);.
09a0: 09 69 6e 70 75 74 20 3d 20 69 6e 66 6f 2e 6f 75  .input = info.ou
09b0: 74 70 75 74 3b 0a 09 69 74 65 6d 43 6f 75 6e 74  tput;..itemCount
09c0: 20 3d 20 69 6e 66 6f 2e 76 61 6c 75 65 3b 0a 0a   = info.value;..
09d0: 09 69 74 65 6d 73 20 3d 20 5b 5d 3b 0a 09 77 68  .items = [];..wh
09e0: 69 6c 65 20 28 69 74 65 6d 43 6f 75 6e 74 20 3e  ile (itemCount >
09f0: 20 30 29 20 7b 0a 09 09 69 74 65 6d 43 6f 75 6e   0) {...itemCoun
0a00: 74 2d 2d 3b 0a 0a 09 09 69 6e 66 6f 20 3d 20 63  t--;....info = c
0a10: 61 63 6b 65 79 53 53 48 41 67 65 6e 74 44 65 63  ackeySSHAgentDec
0a20: 6f 64 65 4c 56 28 69 6e 70 75 74 29 3b 0a 09 09  odeLV(input);...
0a30: 69 6e 70 75 74 20 3d 20 69 6e 66 6f 2e 6f 75 74  input = info.out
0a40: 70 75 74 3b 0a 09 09 69 74 65 6d 73 2e 70 75 73  put;...items.pus
0a50: 68 28 69 6e 66 6f 2e 76 61 6c 75 65 29 3b 0a 09  h(info.value);..
0a60: 7d 0a 0a 09 72 65 74 75 72 6e 28 7b 0a 09 09 76  }...return({...v
0a70: 61 6c 75 65 3a 20 69 74 65 6d 73 2c 0a 09 09 6f  alue: items,...o
0a80: 75 74 70 75 74 3a 20 69 6e 70 75 74 0a 09 7d 29  utput: input..})
0a90: 3b 0a 7d 0a 0a 0a 66 75 6e 63 74 69 6f 6e 20 63  ;.}...function c
0aa0: 61 63 6b 65 79 53 53 48 41 67 65 6e 74 45 6e 63  ackeySSHAgentEnc
0ab0: 6f 64 65 54 6f 55 54 46 38 41 72 72 61 79 28 73  odeToUTF8Array(s
0ac0: 74 72 29 20 7b 0a 09 76 61 72 20 75 74 66 38 20  tr) {..var utf8 
0ad0: 3d 20 5b 5d 3b 0a 0a 09 69 66 20 28 74 79 70 65  = [];...if (type
0ae0: 6f 66 28 73 74 72 29 20 3d 3d 3d 20 22 73 74 72  of(str) === "str
0af0: 69 6e 67 22 29 20 7b 0a 09 09 73 74 72 20 3d 20  ing") {...str = 
0b00: 73 74 72 2e 73 70 6c 69 74 28 22 22 29 2e 6d 61  str.split("").ma
0b10: 70 28 66 75 6e 63 74 69 6f 6e 28 63 29 20 7b 0a  p(function(c) {.
0b20: 09 09 09 72 65 74 75 72 6e 28 63 2e 63 68 61 72  ...return(c.char
0b30: 43 6f 64 65 41 74 28 30 29 29 3b 0a 09 09 7d 29  CodeAt(0));...})
0b40: 3b 0a 09 7d 0a 0a 09 66 6f 72 20 28 76 61 72 20  ;..}...for (var 
0b50: 69 20 3d 20 30 3b 20 69 20 3c 20 73 74 72 2e 6c  i = 0; i < str.l
0b60: 65 6e 67 74 68 3b 20 69 2b 2b 29 20 7b 0a 09 09  ength; i++) {...
0b70: 76 61 72 20 63 68 61 72 63 6f 64 65 20 3d 20 73  var charcode = s
0b80: 74 72 5b 69 5d 3b 0a 0a 09 09 69 66 20 28 63 68  tr[i];....if (ch
0b90: 61 72 63 6f 64 65 20 3c 20 30 78 38 30 29 20 7b  arcode < 0x80) {
0ba0: 0a 09 09 09 75 74 66 38 2e 70 75 73 68 28 63 68  ....utf8.push(ch
0bb0: 61 72 63 6f 64 65 29 3b 0a 09 09 7d 20 65 6c 73  arcode);...} els
0bc0: 65 20 69 66 20 28 63 68 61 72 63 6f 64 65 20 3c  e if (charcode <
0bd0: 20 30 78 38 30 30 29 20 7b 0a 09 09 09 75 74 66   0x800) {....utf
0be0: 38 2e 70 75 73 68 28 30 78 63 30 20 7c 20 28 63  8.push(0xc0 | (c
0bf0: 68 61 72 63 6f 64 65 20 3e 3e 20 36 29 2c 20 0a  harcode >> 6), .
0c00: 09 09 09 20 20 20 20 20 20 20 20 20 20 30 78 38  ...          0x8
0c10: 30 20 7c 20 28 63 68 61 72 63 6f 64 65 20 26 20  0 | (charcode & 
0c20: 30 78 33 66 29 29 3b 0a 09 09 7d 20 65 6c 73 65  0x3f));...} else
0c30: 20 69 66 20 28 63 68 61 72 63 6f 64 65 20 3c 20   if (charcode < 
0c40: 30 78 64 38 30 30 20 7c 7c 20 63 68 61 72 63 6f  0xd800 || charco
0c50: 64 65 20 3e 3d 20 30 78 65 30 30 30 29 20 7b 0a  de >= 0xe000) {.
0c60: 09 09 09 75 74 66 38 2e 70 75 73 68 28 30 78 65  ...utf8.push(0xe
0c70: 30 20 7c 20 28 63 68 61 72 63 6f 64 65 20 3e 3e  0 | (charcode >>
0c80: 20 31 32 29 2c 20 0a 09 09 09 20 20 20 20 20 20   12), ....      
0c90: 20 20 20 20 30 78 38 30 20 7c 20 28 28 63 68 61      0x80 | ((cha
0ca0: 72 63 6f 64 65 20 3e 3e 20 36 29 20 26 20 30 78  rcode >> 6) & 0x
0cb0: 33 66 29 2c 20 0a 09 09 09 20 20 20 20 20 20 20  3f), ....       
0cc0: 20 20 20 30 78 38 30 20 7c 20 28 63 68 61 72 63     0x80 | (charc
0cd0: 6f 64 65 20 26 20 30 78 33 66 29 29 3b 0a 09 09  ode & 0x3f));...
0ce0: 7d 20 65 6c 73 65 20 7b 0a 09 09 09 2f 2f 20 73  } else {....// s
0cf0: 75 72 72 6f 67 61 74 65 20 70 61 69 72 0a 09 09  urrogate pair...
0d00: 09 69 2b 2b 3b 0a 09 09 09 2f 2f 20 55 54 46 2d  .i++;....// UTF-
0d10: 31 36 20 65 6e 63 6f 64 65 73 20 30 78 31 30 30  16 encodes 0x100
0d20: 30 30 2d 30 78 31 30 46 46 46 46 20 62 79 0a 09  00-0x10FFFF by..
0d30: 09 09 2f 2f 20 73 75 62 74 72 61 63 74 69 6e 67  ..// subtracting
0d40: 20 30 78 31 30 30 30 30 20 61 6e 64 20 73 70 6c   0x10000 and spl
0d50: 69 74 74 69 6e 67 20 74 68 65 0a 09 09 09 2f 2f  itting the....//
0d60: 20 32 30 20 62 69 74 73 20 6f 66 20 30 78 30 2d   20 bits of 0x0-
0d70: 30 78 46 46 46 46 46 20 69 6e 74 6f 20 74 77 6f  0xFFFFF into two
0d80: 20 68 61 6c 76 65 73 0a 09 09 09 63 68 61 72 63   halves....charc
0d90: 6f 64 65 20 3d 20 30 78 31 30 30 30 30 20 2b 20  ode = 0x10000 + 
0da0: 28 28 28 63 68 61 72 63 6f 64 65 20 26 20 30 78  (((charcode & 0x
0db0: 33 66 66 29 20 3c 3c 20 31 30 29 0a 09 09 09 20  3ff) << 10).... 
0dc0: 20 20 20 20 20 20 20 20 20 20 7c 20 28 73 74 72            | (str
0dd0: 5b 69 5d 20 26 20 30 78 33 66 66 29 29 3b 0a 0a  [i] & 0x3ff));..
0de0: 09 09 09 75 74 66 38 2e 70 75 73 68 28 30 78 66  ...utf8.push(0xf
0df0: 30 20 7c 20 28 63 68 61 72 63 6f 64 65 20 3e 3e  0 | (charcode >>
0e00: 31 38 29 2c 20 0a 09 09 09 20 20 20 20 20 20 20  18), ....       
0e10: 20 20 20 30 78 38 30 20 7c 20 28 28 63 68 61 72     0x80 | ((char
0e20: 63 6f 64 65 20 3e 3e 20 31 32 29 20 26 20 30 78  code >> 12) & 0x
0e30: 33 66 29 2c 20 0a 09 09 09 20 20 20 20 20 20 20  3f), ....       
0e40: 20 20 20 30 78 38 30 20 7c 20 28 28 63 68 61 72     0x80 | ((char
0e50: 63 6f 64 65 20 3e 3e 20 36 29 20 26 20 30 78 33  code >> 6) & 0x3
0e60: 66 29 2c 20 0a 09 09 09 20 20 20 20 20 20 20 20  f), ....        
0e70: 20 20 30 78 38 30 20 7c 20 28 63 68 61 72 63 6f    0x80 | (charco
0e80: 64 65 20 26 20 30 78 33 66 29 29 3b 0a 09 09 7d  de & 0x3f));...}
0e90: 0a 09 7d 0a 0a 09 72 65 74 75 72 6e 20 75 74 66  ..}...return utf
0ea0: 38 3b 0a 7d 0a 0a 66 75 6e 63 74 69 6f 6e 20 63  8;.}..function c
0eb0: 61 63 6b 65 79 53 53 48 41 67 65 6e 74 44 65 63  ackeySSHAgentDec
0ec0: 6f 64 65 46 72 6f 6d 55 54 46 38 41 72 72 61 79  odeFromUTF8Array
0ed0: 28 69 6e 70 75 74 41 72 72 61 79 29 20 7b 0a 09  (inputArray) {..
0ee0: 76 61 72 20 68 65 78 53 74 72 69 6e 67 3b 0a 09  var hexString;..
0ef0: 76 61 72 20 6f 75 74 70 75 74 3b 0a 0a 09 68 65  var output;...he
0f00: 78 53 74 72 69 6e 67 20 3d 20 63 61 63 6b 65 79  xString = cackey
0f10: 53 53 48 41 67 65 6e 74 45 6e 63 6f 64 65 42 69  SSHAgentEncodeBi
0f20: 6e 61 72 79 54 6f 48 65 78 28 69 6e 70 75 74 41  naryToHex(inputA
0f30: 72 72 61 79 2c 20 22 25 22 29 3b 0a 0a 09 6f 75  rray, "%");...ou
0f40: 74 70 75 74 20 3d 20 64 65 63 6f 64 65 55 52 49  tput = decodeURI
0f50: 43 6f 6d 70 6f 6e 65 6e 74 28 68 65 78 53 74 72  Component(hexStr
0f60: 69 6e 67 29 0a 0a 09 72 65 74 75 72 6e 28 6f 75  ing)...return(ou
0f70: 74 70 75 74 29 3b 0a 7d 0a 0a 66 75 6e 63 74 69  tput);.}..functi
0f80: 6f 6e 20 63 61 63 6b 65 79 53 53 48 41 67 65 6e  on cackeySSHAgen
0f90: 74 45 6e 63 6f 64 65 53 74 72 69 6e 67 28 73 74  tEncodeString(st
0fa0: 72 69 6e 67 29 20 7b 0a 09 76 61 72 20 72 65 73  ring) {..var res
0fb0: 75 6c 74 3b 0a 0a 09 72 65 73 75 6c 74 20 3d 20  ult;...result = 
0fc0: 63 61 63 6b 65 79 53 53 48 41 67 65 6e 74 45 6e  cackeySSHAgentEn
0fd0: 63 6f 64 65 4c 56 28 63 61 63 6b 65 79 53 53 48  codeLV(cackeySSH
0fe0: 41 67 65 6e 74 45 6e 63 6f 64 65 54 6f 55 54 46  AgentEncodeToUTF
0ff0: 38 41 72 72 61 79 28 73 74 72 69 6e 67 29 29 3b  8Array(string));
1000: 0a 0a 09 72 65 74 75 72 6e 28 72 65 73 75 6c 74  ...return(result
1010: 29 3b 0a 7d 0a 0a 66 75 6e 63 74 69 6f 6e 20 63  );.}..function c
1020: 61 63 6b 65 79 53 53 48 41 67 65 6e 74 44 65 63  ackeySSHAgentDec
1030: 6f 64 65 53 74 72 69 6e 67 28 69 6e 70 75 74 29  odeString(input)
1040: 20 7b 0a 09 76 61 72 20 6f 75 74 70 75 74 3b 0a   {..var output;.
1050: 0a 09 6f 75 74 70 75 74 20 3d 20 63 61 63 6b 65  ..output = cacke
1060: 79 53 53 48 41 67 65 6e 74 44 65 63 6f 64 65 4c  ySSHAgentDecodeL
1070: 56 28 69 6e 70 75 74 29 3b 0a 09 6f 75 74 70 75  V(input);..outpu
1080: 74 2e 76 61 6c 75 65 20 3d 20 63 61 63 6b 65 79  t.value = cackey
1090: 53 53 48 41 67 65 6e 74 44 65 63 6f 64 65 46 72  SSHAgentDecodeFr
10a0: 6f 6d 55 54 46 38 41 72 72 61 79 28 6f 75 74 70  omUTF8Array(outp
10b0: 75 74 2e 76 61 6c 75 65 29 3b 0a 0a 09 72 65 74  ut.value);...ret
10c0: 75 72 6e 28 6f 75 74 70 75 74 29 3b 0a 7d 0a 0a  urn(output);.}..
10d0: 66 75 6e 63 74 69 6f 6e 20 63 61 63 6b 65 79 53  function cackeyS
10e0: 53 48 41 67 65 6e 74 45 6e 63 6f 64 65 42 69 6e  SHAgentEncodeBin
10f0: 61 72 79 54 6f 48 65 78 28 62 69 6e 61 72 79 53  aryToHex(binaryS
1100: 74 72 69 6e 67 2c 20 70 72 65 66 69 78 29 20 7b  tring, prefix) {
1110: 0a 09 76 61 72 20 62 75 66 66 65 72 3b 0a 0a 09  ..var buffer;...
1120: 69 66 20 28 21 70 72 65 66 69 78 29 20 7b 0a 09  if (!prefix) {..
1130: 09 70 72 65 66 69 78 20 3d 20 22 22 3b 0a 09 7d  .prefix = "";..}
1140: 0a 0a 09 73 77 69 74 63 68 20 28 74 79 70 65 6f  ...switch (typeo
1150: 66 28 62 69 6e 61 72 79 53 74 72 69 6e 67 29 29  f(binaryString))
1160: 20 7b 0a 09 09 63 61 73 65 20 22 73 74 72 69 6e   {...case "strin
1170: 67 22 3a 0a 09 09 09 62 75 66 66 65 72 20 3d 20  g":....buffer = 
1180: 62 69 6e 61 72 79 53 74 72 69 6e 67 2e 73 70 6c  binaryString.spl
1190: 69 74 28 22 22 29 2e 6d 61 70 28 66 75 6e 63 74  it("").map(funct
11a0: 69 6f 6e 28 63 29 20 7b 0a 09 09 09 09 72 65 74  ion(c) {.....ret
11b0: 75 72 6e 28 70 72 65 66 69 78 20 2b 20 63 2e 63  urn(prefix + c.c
11c0: 68 61 72 43 6f 64 65 41 74 28 30 29 2e 74 6f 53  harCodeAt(0).toS
11d0: 74 72 69 6e 67 28 31 36 29 2e 70 61 64 53 74 61  tring(16).padSta
11e0: 72 74 28 32 2c 20 27 30 27 29 29 3b 0a 09 09 09  rt(2, '0'));....
11f0: 7d 29 2e 6a 6f 69 6e 28 22 22 29 3b 0a 09 09 09  }).join("");....
1200: 62 72 65 61 6b 3b 0a 09 09 64 65 66 61 75 6c 74  break;...default
1210: 3a 0a 09 09 09 62 75 66 66 65 72 20 3d 20 5b 5d  :....buffer = []
1220: 3b 0a 09 09 09 6e 65 77 20 55 69 6e 74 38 41 72  ;....new Uint8Ar
1230: 72 61 79 28 62 69 6e 61 72 79 53 74 72 69 6e 67  ray(binaryString
1240: 29 2e 6d 61 70 28 66 75 6e 63 74 69 6f 6e 28 63  ).map(function(c
1250: 29 20 7b 0a 09 09 09 09 62 75 66 66 65 72 2e 70  ) {.....buffer.p
1260: 75 73 68 28 70 72 65 66 69 78 20 2b 20 63 2e 74  ush(prefix + c.t
1270: 6f 53 74 72 69 6e 67 28 31 36 29 2e 70 61 64 53  oString(16).padS
1280: 74 61 72 74 28 32 2c 20 27 30 27 29 29 3b 0a 09  tart(2, '0'));..
1290: 09 09 7d 29 3b 0a 09 09 09 62 75 66 66 65 72 20  ..});....buffer 
12a0: 3d 20 62 75 66 66 65 72 2e 6a 6f 69 6e 28 22 22  = buffer.join(""
12b0: 29 3b 0a 09 09 09 62 72 65 61 6b 3b 0a 09 7d 0a  );....break;..}.
12c0: 0a 09 72 65 74 75 72 6e 28 62 75 66 66 65 72 29  ..return(buffer)
12d0: 3b 0a 7d 0a 0a 66 75 6e 63 74 69 6f 6e 20 63 61  ;.}..function ca
12e0: 63 6b 65 79 53 53 48 41 67 65 6e 74 45 6e 63 6f  ckeySSHAgentEnco
12f0: 64 65 43 65 72 74 54 6f 4b 65 79 41 6e 64 49 44  deCertToKeyAndID
1300: 28 63 65 72 74 2c 20 73 73 68 4b 65 79 54 79 70  (cert, sshKeyTyp
1310: 65 29 20 7b 0a 09 76 61 72 20 72 65 73 75 6c 74  e) {..var result
1320: 20 3d 20 6e 75 6c 6c 2c 20 72 65 73 75 6c 74 4b   = null, resultK
1330: 65 79 20 3d 20 6e 75 6c 6c 3b 0a 09 76 61 72 20  ey = null;..var 
1340: 63 65 72 74 4f 62 6a 2c 20 63 65 72 74 42 79 74  certObj, certByt
1350: 65 73 3b 0a 09 76 61 72 20 70 75 62 6c 69 63 4b  es;..var publicK
1360: 65 79 3b 0a 0a 09 63 65 72 74 4f 62 6a 20 3d 20  ey;...certObj = 
1370: 6e 65 77 20 58 35 30 39 3b 0a 09 69 66 20 28 21  new X509;..if (!
1380: 63 65 72 74 4f 62 6a 29 20 7b 0a 09 09 72 65 74  certObj) {...ret
1390: 75 72 6e 28 72 65 73 75 6c 74 29 3b 0a 09 7d 0a  urn(result);..}.
13a0: 0a 09 63 65 72 74 42 79 74 65 73 20 3d 20 41 72  ..certBytes = Ar
13b0: 72 61 79 2e 66 72 6f 6d 28 6e 65 77 20 55 69 6e  ray.from(new Uin
13c0: 74 38 41 72 72 61 79 28 63 65 72 74 29 29 3b 0a  t8Array(cert));.
13d0: 0a 09 63 65 72 74 4f 62 6a 2e 72 65 61 64 43 65  ..certObj.readCe
13e0: 72 74 48 65 78 28 63 61 63 6b 65 79 53 53 48 41  rtHex(cackeySSHA
13f0: 67 65 6e 74 45 6e 63 6f 64 65 42 69 6e 61 72 79  gentEncodeBinary
1400: 54 6f 48 65 78 28 63 65 72 74 42 79 74 65 73 29  ToHex(certBytes)
1410: 29 3b 0a 0a 09 70 75 62 6c 69 63 4b 65 79 20 3d  );...publicKey =
1420: 20 63 65 72 74 4f 62 6a 2e 67 65 74 50 75 62 6c   certObj.getPubl
1430: 69 63 4b 65 79 28 29 3b 0a 0a 09 73 77 69 74 63  icKey();...switc
1440: 68 20 28 73 73 68 4b 65 79 54 79 70 65 29 20 7b  h (sshKeyType) {
1450: 0a 09 09 63 61 73 65 20 22 73 73 68 22 3a 0a 09  ...case "ssh":..
1460: 09 09 73 77 69 74 63 68 20 28 70 75 62 6c 69 63  ..switch (public
1470: 4b 65 79 2e 74 79 70 65 29 20 7b 0a 09 09 09 09  Key.type) {.....
1480: 63 61 73 65 20 22 52 53 41 22 3a 0a 09 09 09 09  case "RSA":.....
1490: 09 72 65 73 75 6c 74 4b 65 79 20 3d 20 63 61 63  .resultKey = cac
14a0: 6b 65 79 53 53 48 41 67 65 6e 74 45 6e 63 6f 64  keySSHAgentEncod
14b0: 65 53 74 72 69 6e 67 28 22 73 73 68 2d 72 73 61  eString("ssh-rsa
14c0: 22 29 3b 0a 09 09 09 09 09 72 65 73 75 6c 74 4b  ");......resultK
14d0: 65 79 20 3d 20 72 65 73 75 6c 74 4b 65 79 2e 63  ey = resultKey.c
14e0: 6f 6e 63 61 74 28 63 61 63 6b 65 79 53 53 48 41  oncat(cackeySSHA
14f0: 67 65 6e 74 45 6e 63 6f 64 65 42 69 67 49 6e 74  gentEncodeBigInt
1500: 28 70 75 62 6c 69 63 4b 65 79 2e 65 29 29 3b 0a  (publicKey.e));.
1510: 09 09 09 09 09 72 65 73 75 6c 74 4b 65 79 20 3d  .....resultKey =
1520: 20 72 65 73 75 6c 74 4b 65 79 2e 63 6f 6e 63 61   resultKey.conca
1530: 74 28 63 61 63 6b 65 79 53 53 48 41 67 65 6e 74  t(cackeySSHAgent
1540: 45 6e 63 6f 64 65 42 69 67 49 6e 74 28 70 75 62  EncodeBigInt(pub
1550: 6c 69 63 4b 65 79 2e 6e 29 29 3b 0a 09 09 09 09  licKey.n));.....
1560: 09 62 72 65 61 6b 3b 0a 09 09 09 09 64 65 66 61  .break;.....defa
1570: 75 6c 74 3a 0a 09 09 09 09 09 63 6f 6e 73 6f 6c  ult:......consol
1580: 65 2e 6c 6f 67 28 22 5b 63 61 63 6b 65 79 53 53  e.log("[cackeySS
1590: 48 5d 20 55 6e 73 75 70 70 6f 72 74 65 64 20 70  H] Unsupported p
15a0: 75 62 6c 69 63 20 6b 65 79 20 74 79 70 65 3a 22  ublic key type:"
15b0: 2c 20 73 73 68 4b 65 79 54 79 70 65 2c 20 22 2f  , sshKeyType, "/
15c0: 22 2c 20 70 75 62 6c 69 63 4b 65 79 2e 74 79 70  ", publicKey.typ
15d0: 65 2c 20 22 2d 2d 20 69 67 6e 6f 72 69 6e 67 2e  e, "-- ignoring.
15e0: 22 29 3b 0a 09 09 09 09 09 62 72 65 61 6b 3b 0a  ");......break;.
15f0: 09 09 09 7d 0a 09 09 09 62 72 65 61 6b 3b 0a 09  ...}....break;..
1600: 09 63 61 73 65 20 22 78 35 30 39 76 33 2d 73 69  .case "x509v3-si
1610: 67 6e 22 3a 0a 09 09 09 72 65 73 75 6c 74 4b 65  gn":....resultKe
1620: 79 20 3d 20 63 65 72 74 42 79 74 65 73 3b 0a 09  y = certBytes;..
1630: 09 09 62 72 65 61 6b 3b 0a 09 09 63 61 73 65 20  ..break;...case 
1640: 22 78 35 30 39 76 33 2d 73 73 68 22 3a 0a 09 09  "x509v3-ssh":...
1650: 09 73 77 69 74 63 68 20 28 70 75 62 6c 69 63 4b  .switch (publicK
1660: 65 79 2e 74 79 70 65 29 20 7b 0a 09 09 09 09 63  ey.type) {.....c
1670: 61 73 65 20 22 52 53 41 22 3a 0a 09 09 09 09 09  ase "RSA":......
1680: 72 65 73 75 6c 74 4b 65 79 20 3d 20 63 61 63 6b  resultKey = cack
1690: 65 79 53 53 48 41 67 65 6e 74 45 6e 63 6f 64 65  eySSHAgentEncode
16a0: 53 74 72 69 6e 67 28 22 78 35 30 39 76 33 2d 73  String("x509v3-s
16b0: 73 68 2d 72 73 61 22 29 3b 0a 0a 09 09 09 09 09  sh-rsa");.......
16c0: 2f 2a 0a 09 09 09 09 09 20 2a 20 41 72 72 61 79  /*...... * Array
16d0: 20 6f 66 20 63 65 72 74 69 66 69 63 61 74 65 73   of certificates
16e0: 0a 09 09 09 09 09 20 2a 2f 0a 09 09 09 09 09 72  ...... */......r
16f0: 65 73 75 6c 74 4b 65 79 20 3d 20 72 65 73 75 6c  esultKey = resul
1700: 74 4b 65 79 2e 63 6f 6e 63 61 74 28 63 61 63 6b  tKey.concat(cack
1710: 65 79 53 53 48 41 67 65 6e 74 45 6e 63 6f 64 65  eySSHAgentEncode
1720: 41 72 72 61 79 28 5b 0a 09 09 09 09 09 09 63 65  Array([.......ce
1730: 72 74 42 79 74 65 73 0a 09 09 09 09 09 5d 29 29  rtBytes......]))
1740: 3b 0a 0a 09 09 09 09 09 2f 2a 0a 09 09 09 09 09  ;......./*......
1750: 20 2a 20 41 72 72 61 79 20 6f 66 20 4f 43 53 50   * Array of OCSP
1760: 20 72 65 73 70 6f 6e 73 65 73 0a 09 09 09 09 09   responses......
1770: 20 2a 2f 0a 09 09 09 09 09 72 65 73 75 6c 74 4b   */......resultK
1780: 65 79 20 3d 20 72 65 73 75 6c 74 4b 65 79 2e 63  ey = resultKey.c
1790: 6f 6e 63 61 74 28 63 61 63 6b 65 79 53 53 48 41  oncat(cackeySSHA
17a0: 67 65 6e 74 45 6e 63 6f 64 65 41 72 72 61 79 28  gentEncodeArray(
17b0: 5b 5d 29 29 3b 0a 09 09 09 09 09 62 72 65 61 6b  []));......break
17c0: 3b 0a 09 09 09 09 64 65 66 61 75 6c 74 3a 0a 09  ;.....default:..
17d0: 09 09 09 09 63 6f 6e 73 6f 6c 65 2e 6c 6f 67 28  ....console.log(
17e0: 22 5b 63 61 63 6b 65 79 53 53 48 5d 20 55 6e 73  "[cackeySSH] Uns
17f0: 75 70 70 6f 72 74 65 64 20 70 75 62 6c 69 63 20  upported public 
1800: 6b 65 79 20 74 79 70 65 3a 22 2c 20 73 73 68 4b  key type:", sshK
1810: 65 79 54 79 70 65 2c 20 22 2f 22 2c 20 70 75 62  eyType, "/", pub
1820: 6c 69 63 4b 65 79 2e 74 79 70 65 2c 20 22 2d 2d  licKey.type, "--
1830: 20 69 67 6e 6f 72 69 6e 67 2e 22 29 3b 0a 09 09   ignoring.");...
1840: 09 09 09 62 72 65 61 6b 3b 0a 09 09 09 7d 0a 09  ...break;....}..
1850: 09 09 62 72 65 61 6b 3b 0a 09 09 64 65 66 61 75  ..break;...defau
1860: 6c 74 3a 0a 09 09 09 63 6f 6e 73 6f 6c 65 2e 6c  lt:....console.l
1870: 6f 67 28 22 5b 63 61 63 6b 65 79 53 53 48 5d 20  og("[cackeySSH] 
1880: 55 6e 73 75 70 70 6f 72 74 65 64 20 53 53 48 20  Unsupported SSH 
1890: 6b 65 79 20 74 79 70 65 3a 22 2c 20 73 73 68 4b  key type:", sshK
18a0: 65 79 54 79 70 65 2c 20 22 2d 2d 20 69 67 6e 6f  eyType, "-- igno
18b0: 72 69 6e 67 2e 22 29 3b 0a 09 09 09 62 72 65 61  ring.");....brea
18c0: 6b 3b 0a 09 7d 0a 0a 09 69 66 20 28 72 65 73 75  k;..}...if (resu
18d0: 6c 74 4b 65 79 29 20 7b 0a 09 09 76 61 72 20 63  ltKey) {...var c
18e0: 65 72 74 4c 61 62 65 6c 3b 0a 09 09 76 61 72 20  ertLabel;...var 
18f0: 63 65 72 74 53 41 4e 3b 0a 09 09 76 61 72 20 69  certSAN;...var i
1900: 67 6e 6f 72 65 45 78 63 65 70 74 69 6f 6e 3b 0a  gnoreException;.
1910: 0a 09 09 2f 2a 0a 09 09 20 2a 20 53 65 74 20 61  .../*... * Set a
1920: 20 64 65 66 61 75 6c 74 20 6c 61 62 65 6c 0a 09   default label..
1930: 09 20 2a 2f 0a 09 09 63 65 72 74 4c 61 62 65 6c  . */...certLabel
1940: 20 3d 20 63 65 72 74 4f 62 6a 2e 67 65 74 53 75   = certObj.getSu
1950: 62 6a 65 63 74 53 74 72 69 6e 67 28 29 3b 0a 0a  bjectString();..
1960: 09 09 2f 2a 0a 09 09 20 2a 20 54 72 79 20 74 6f  ../*... * Try to
1970: 20 66 69 6e 64 20 61 20 62 65 74 74 65 72 20 6c   find a better l
1980: 61 62 65 6c 20 66 72 6f 6d 20 74 68 65 20 63 65  abel from the ce
1990: 72 74 69 66 69 63 61 74 65 27 73 0a 09 09 20 2a  rtificate's... *
19a0: 20 53 75 62 6a 65 63 74 20 41 6c 74 65 72 6e 61   Subject Alterna
19b0: 74 69 76 65 20 4e 61 6d 65 20 28 53 41 4e 29 20  tive Name (SAN) 
19c0: 65 78 74 65 6e 73 69 6f 6e 73 0a 09 09 20 2a 2f  extensions... */
19d0: 0a 09 09 74 72 79 20 7b 0a 09 09 09 63 65 72 74  ...try {....cert
19e0: 53 41 4e 20 3d 20 63 65 72 74 4f 62 6a 2e 67 65  SAN = certObj.ge
19f0: 74 45 78 74 53 75 62 6a 65 63 74 41 6c 74 4e 61  tExtSubjectAltNa
1a00: 6d 65 32 28 29 3b 0a 09 09 09 63 65 72 74 53 41  me2();....certSA
1a10: 4e 2e 66 6f 72 45 61 63 68 28 66 75 6e 63 74 69  N.forEach(functi
1a20: 6f 6e 28 69 74 65 6d 50 61 69 72 29 20 7b 0a 09  on(itemPair) {..
1a30: 09 09 09 76 61 72 20 69 74 65 6d 54 79 70 65 2c  ...var itemType,
1a40: 20 69 74 65 6d 56 61 6c 75 65 3b 0a 0a 09 09 09   itemValue;.....
1a50: 09 69 74 65 6d 54 79 70 65 20 3d 20 69 74 65 6d  .itemType = item
1a60: 50 61 69 72 5b 30 5d 3b 0a 09 09 09 09 69 74 65  Pair[0];.....ite
1a70: 6d 56 61 6c 75 65 20 3d 20 69 74 65 6d 50 61 69  mValue = itemPai
1a80: 72 5b 31 5d 3b 0a 0a 09 09 09 09 69 66 20 28 69  r[1];......if (i
1a90: 74 65 6d 54 79 70 65 20 3d 3d 3d 20 22 4d 41 49  temType === "MAI
1aa0: 4c 22 29 20 7b 0a 09 09 09 09 09 63 65 72 74 4c  L") {......certL
1ab0: 61 62 65 6c 20 3d 20 69 74 65 6d 56 61 6c 75 65  abel = itemValue
1ac0: 3b 0a 09 09 09 09 7d 0a 09 09 09 7d 29 3b 0a 09  ;.....}....});..
1ad0: 09 7d 20 63 61 74 63 68 20 28 69 67 6e 6f 72 65  .} catch (ignore
1ae0: 45 78 63 65 70 74 69 6f 6e 29 20 7b 0a 09 09 7d  Exception) {...}
1af0: 0a 0a 09 09 72 65 73 75 6c 74 20 3d 20 7b 0a 09  ....result = {..
1b00: 09 09 6c 61 62 65 6c 3a 20 63 65 72 74 4c 61 62  ..label: certLab
1b10: 65 6c 2c 0a 09 09 09 70 75 62 6c 69 63 4b 65 79  el,....publicKey
1b20: 54 79 70 65 3a 20 70 75 62 6c 69 63 4b 65 79 2e  Type: publicKey.
1b30: 74 79 70 65 2c 0a 09 09 09 73 73 68 4b 65 79 54  type,....sshKeyT
1b40: 79 70 65 3a 20 73 73 68 4b 65 79 54 79 70 65 2c  ype: sshKeyType,
1b50: 0a 09 09 09 6b 65 79 3a 20 72 65 73 75 6c 74 4b  ....key: resultK
1b60: 65 79 0a 09 09 7d 3b 0a 09 7d 0a 0a 09 72 65 74  ey...};..}...ret
1b70: 75 72 6e 28 72 65 73 75 6c 74 29 3b 0a 7d 0a 0a  urn(result);.}..
1b80: 66 75 6e 63 74 69 6f 6e 20 63 61 63 6b 65 79 53  function cackeyS
1b90: 53 48 41 67 65 6e 74 44 65 63 6f 64 65 43 65 72  SHAgentDecodeCer
1ba0: 74 28 72 65 71 75 65 73 74 41 72 72 61 79 29 20  t(requestArray) 
1bb0: 7b 0a 09 76 61 72 20 74 79 70 65 3b 0a 09 76 61  {..var type;..va
1bc0: 72 20 64 65 63 6f 64 65 45 72 72 6f 72 3b 0a 09  r decodeError;..
1bd0: 76 61 72 20 70 75 62 6c 69 63 4b 65 79 54 79 70  var publicKeyTyp
1be0: 65 2c 20 70 75 62 6c 69 63 4b 65 79 42 6c 6f 62  e, publicKeyBlob
1bf0: 3b 0a 09 76 61 72 20 6f 75 74 70 75 74 3b 0a 0a  ;..var output;..
1c00: 09 74 72 79 20 7b 0a 09 09 74 79 70 65 20 3d 20  .try {...type = 
1c10: 63 61 63 6b 65 79 53 53 48 41 67 65 6e 74 44 65  cackeySSHAgentDe
1c20: 63 6f 64 65 53 74 72 69 6e 67 28 72 65 71 75 65  codeString(reque
1c30: 73 74 41 72 72 61 79 29 3b 0a 09 7d 20 63 61 74  stArray);..} cat
1c40: 63 68 20 28 64 65 63 6f 64 65 45 72 72 6f 72 29  ch (decodeError)
1c50: 20 7b 0a 09 09 2f 2a 0a 09 09 20 2a 20 78 35 30   {.../*... * x50
1c60: 39 76 33 2d 73 69 67 6e 2d 72 73 61 20 72 65 71  9v3-sign-rsa req
1c70: 75 65 73 74 73 20 61 72 65 20 75 6e 2d 70 72 65  uests are un-pre
1c80: 66 69 78 65 64 20 3a 2d 28 0a 09 09 20 2a 2f 0a  fixed :-(... */.
1c90: 09 09 74 79 70 65 20 3d 20 7b 7d 0a 09 09 74 79  ..type = {}...ty
1ca0: 70 65 2e 76 61 6c 75 65 20 3d 20 72 65 71 75 65  pe.value = reque
1cb0: 73 74 41 72 72 61 79 3b 0a 09 09 74 79 70 65 2e  stArray;...type.
1cc0: 6f 75 74 70 75 74 20 3d 20 5b 5d 3b 0a 09 7d 0a  output = [];..}.
1cd0: 0a 09 2f 2a 20 49 74 20 6d 69 67 68 74 20 62 65  ../* It might be
1ce0: 20 61 6e 20 78 35 30 39 76 33 2d 73 69 67 6e 2d   an x509v3-sign-
1cf0: 72 73 61 2c 20 77 68 69 63 68 20 69 73 20 75 6e  rsa, which is un
1d00: 70 72 65 66 69 78 65 64 20 2d 2d 20 74 72 79 20  prefixed -- try 
1d10: 74 6f 20 67 75 65 73 73 20 2a 2f 0a 09 69 66 20  to guess */..if 
1d20: 28 74 79 70 65 2e 76 61 6c 75 65 5b 30 5d 20 3d  (type.value[0] =
1d30: 3d 20 30 78 33 30 29 20 7b 0a 09 09 74 79 70 65  = 0x30) {...type
1d40: 20 3d 20 22 78 35 30 39 76 33 2d 73 69 67 6e 2d   = "x509v3-sign-
1d50: 72 73 61 22 3b 0a 09 7d 20 65 6c 73 65 20 7b 0a  rsa";..} else {.
1d60: 09 09 72 65 71 75 65 73 74 41 72 72 61 79 20 3d  ..requestArray =
1d70: 20 74 79 70 65 2e 6f 75 74 70 75 74 3b 0a 09 09   type.output;...
1d80: 74 79 70 65 20 3d 20 74 79 70 65 2e 76 61 6c 75  type = type.valu
1d90: 65 3b 0a 09 7d 0a 0a 09 73 77 69 74 63 68 20 28  e;..}...switch (
1da0: 74 79 70 65 29 20 7b 0a 09 09 63 61 73 65 20 22  type) {...case "
1db0: 73 73 68 2d 72 73 61 22 3a 0a 09 09 63 61 73 65  ssh-rsa":...case
1dc0: 20 22 78 35 30 39 76 33 2d 73 69 67 6e 2d 72 73   "x509v3-sign-rs
1dd0: 61 22 3a 0a 09 09 09 70 75 62 6c 69 63 4b 65 79  a":....publicKey
1de0: 54 79 70 65 20 3d 20 22 52 53 41 22 3b 0a 09 09  Type = "RSA";...
1df0: 09 70 75 62 6c 69 63 4b 65 79 42 6c 6f 62 20 3d  .publicKeyBlob =
1e00: 20 72 65 71 75 65 73 74 41 72 72 61 79 3b 0a 09   requestArray;..
1e10: 09 09 62 72 65 61 6b 3b 0a 09 09 63 61 73 65 20  ..break;...case 
1e20: 22 78 35 30 39 76 33 2d 73 73 68 2d 72 73 61 22  "x509v3-ssh-rsa"
1e30: 3a 0a 09 09 09 70 75 62 6c 69 63 4b 65 79 54 79  :....publicKeyTy
1e40: 70 65 20 3d 20 22 52 53 41 22 3b 0a 09 09 09 70  pe = "RSA";....p
1e50: 75 62 6c 69 63 4b 65 79 42 6c 6f 62 20 3d 20 63  ublicKeyBlob = c
1e60: 61 63 6b 65 79 53 53 48 41 67 65 6e 74 44 65 63  ackeySSHAgentDec
1e70: 6f 64 65 41 72 72 61 79 28 72 65 71 75 65 73 74  odeArray(request
1e80: 41 72 72 61 79 29 2e 76 61 6c 75 65 5b 30 5d 3b  Array).value[0];
1e90: 0a 09 09 09 62 72 65 61 6b 3b 0a 09 7d 0a 0a 09  ....break;..}...
1ea0: 6f 75 74 70 75 74 20 3d 20 7b 0a 09 09 70 75 62  output = {...pub
1eb0: 6c 69 63 4b 65 79 54 79 70 65 3a 20 70 75 62 6c  licKeyType: publ
1ec0: 69 63 4b 65 79 54 79 70 65 2c 0a 09 09 70 75 62  icKeyType,...pub
1ed0: 6c 69 63 4b 65 79 42 6c 6f 62 3a 20 70 75 62 6c  licKeyBlob: publ
1ee0: 69 63 4b 65 79 42 6c 6f 62 0a 09 7d 3b 0a 0a 09  icKeyBlob..};...
1ef0: 72 65 74 75 72 6e 28 6f 75 74 70 75 74 29 3b 0a  return(output);.
1f00: 7d 0a 0a 66 75 6e 63 74 69 6f 6e 20 63 61 63 6b  }..function cack
1f10: 65 79 53 53 48 41 67 65 6e 74 43 6f 6d 70 61 72  eySSHAgentCompar
1f20: 65 52 65 71 75 65 73 74 41 6e 64 4b 65 79 28 6b  eRequestAndKey(k
1f30: 65 79 31 2c 20 6b 65 79 32 29 20 7b 0a 09 76 61  ey1, key2) {..va
1f40: 72 20 69 67 6e 6f 72 65 64 45 72 72 6f 72 3b 0a  r ignoredError;.
1f50: 0a 09 74 72 79 20 7b 0a 09 09 6b 65 79 31 20 3d  ..try {...key1 =
1f60: 20 63 61 63 6b 65 79 53 53 48 41 67 65 6e 74 44   cackeySSHAgentD
1f70: 65 63 6f 64 65 43 65 72 74 28 6b 65 79 31 29 3b  ecodeCert(key1);
1f80: 0a 09 09 6b 65 79 32 20 3d 20 63 61 63 6b 65 79  ...key2 = cackey
1f90: 53 53 48 41 67 65 6e 74 44 65 63 6f 64 65 43 65  SSHAgentDecodeCe
1fa0: 72 74 28 6b 65 79 32 29 3b 0a 09 7d 20 63 61 74  rt(key2);..} cat
1fb0: 63 68 20 28 69 67 6e 6f 72 65 64 45 72 72 6f 72  ch (ignoredError
1fc0: 29 20 7b 0a 09 09 72 65 74 75 72 6e 28 66 61 6c  ) {...return(fal
1fd0: 73 65 29 3b 0a 09 7d 0a 0a 09 69 66 20 28 6b 65  se);..}...if (ke
1fe0: 79 31 2e 70 75 62 6c 69 63 4b 65 79 54 79 70 65  y1.publicKeyType
1ff0: 20 21 3d 3d 20 6b 65 79 32 2e 70 75 62 6c 69 63   !== key2.public
2000: 4b 65 79 54 79 70 65 29 20 7b 0a 09 09 72 65 74  KeyType) {...ret
2010: 75 72 6e 28 66 61 6c 73 65 29 3b 0a 09 7d 0a 0a  urn(false);..}..
2020: 09 69 66 20 28 6b 65 79 31 2e 70 75 62 6c 69 63  .if (key1.public
2030: 4b 65 79 42 6c 6f 62 2e 6a 6f 69 6e 28 22 2c 22  KeyBlob.join(","
2040: 29 20 3d 3d 3d 20 6b 65 79 32 2e 70 75 62 6c 69  ) === key2.publi
2050: 63 4b 65 79 42 6c 6f 62 2e 6a 6f 69 6e 28 22 2c  cKeyBlob.join(",
2060: 22 29 29 20 7b 0a 09 09 72 65 74 75 72 6e 28 74  ")) {...return(t
2070: 72 75 65 29 3b 0a 09 7d 0a 0a 09 72 65 74 75 72  rue);..}...retur
2080: 6e 28 66 61 6c 73 65 29 3b 0a 7d 0a 0a 2f 2a 0a  n(false);.}../*.
2090: 20 2a 20 43 6f 6d 6d 61 6e 64 20 48 61 6e 64 6c   * Command Handl
20a0: 65 72 73 0a 20 2a 2f 0a 61 73 79 6e 63 20 66 75  ers. */.async fu
20b0: 6e 63 74 69 6f 6e 20 63 61 63 6b 65 79 53 53 48  nction cackeySSH
20c0: 41 67 65 6e 74 43 6f 6d 6d 61 6e 64 52 65 71 75  AgentCommandRequ
20d0: 65 73 74 49 64 65 6e 74 69 74 79 28 72 65 71 75  estIdentity(requ
20e0: 65 73 74 29 20 7b 0a 09 76 61 72 20 72 65 73 70  est) {..var resp
20f0: 6f 6e 73 65 3b 0a 09 76 61 72 20 63 65 72 74 73  onse;..var certs
2100: 20 3d 20 5b 5d 3b 0a 09 76 61 72 20 6b 65 79 73   = [];..var keys
2110: 20 3d 20 5b 5d 3b 0a 0a 09 2f 2a 0a 09 20 2a 20   = [];.../*.. * 
2120: 47 65 74 20 61 20 6c 69 73 74 20 6f 66 20 63 65  Get a list of ce
2130: 72 74 69 66 69 63 61 74 65 73 0a 09 20 2a 2f 0a  rtificates.. */.
2140: 09 63 65 72 74 73 20 3d 20 61 77 61 69 74 20 63  .certs = await c
2150: 61 63 6b 65 79 53 53 48 41 67 65 6e 74 47 65 74  ackeySSHAgentGet
2160: 43 65 72 74 69 66 69 63 61 74 65 73 28 29 3b 0a  Certificates();.
2170: 0a 09 2f 2a 0a 09 20 2a 20 43 6f 6e 76 65 72 74  ../*.. * Convert
2180: 20 65 61 63 68 20 63 65 72 74 69 66 69 63 61 74   each certificat
2190: 65 20 74 6f 20 61 6e 20 53 53 48 20 6b 65 79 20  e to an SSH key 
21a0: 62 6c 6f 62 0a 09 20 2a 2f 0a 09 63 61 63 6b 65  blob.. */..cacke
21b0: 79 53 53 48 41 67 65 6e 74 47 65 74 53 53 48 4b  ySSHAgentGetSSHK
21c0: 65 79 54 79 70 65 73 28 29 2e 66 6f 72 45 61 63  eyTypes().forEac
21d0: 68 28 66 75 6e 63 74 69 6f 6e 28 73 73 68 4b 65  h(function(sshKe
21e0: 79 54 79 70 65 29 20 7b 0a 09 09 63 65 72 74 73  yType) {...certs
21f0: 2e 66 6f 72 45 61 63 68 28 66 75 6e 63 74 69 6f  .forEach(functio
2200: 6e 28 63 65 72 74 29 20 7b 0a 09 09 09 76 61 72  n(cert) {....var
2210: 20 6b 65 79 3b 0a 0a 09 09 09 6b 65 79 20 3d 20   key;.....key = 
2220: 63 61 63 6b 65 79 53 53 48 41 67 65 6e 74 45 6e  cackeySSHAgentEn
2230: 63 6f 64 65 43 65 72 74 54 6f 4b 65 79 41 6e 64  codeCertToKeyAnd
2240: 49 44 28 63 65 72 74 2e 63 65 72 74 69 66 69 63  ID(cert.certific
2250: 61 74 65 2c 20 73 73 68 4b 65 79 54 79 70 65 29  ate, sshKeyType)
2260: 3b 0a 0a 09 09 09 69 66 20 28 6b 65 79 29 20 7b  ;.....if (key) {
2270: 0a 09 09 09 09 6b 65 79 73 2e 70 75 73 68 28 6b  .....keys.push(k
2280: 65 79 29 3b 0a 09 09 09 7d 0a 09 09 7d 29 3b 0a  ey);....}...});.
2290: 09 7d 29 3b 0a 0a 09 2f 2a 0a 09 20 2a 20 45 6e  .});.../*.. * En
22a0: 63 6f 64 65 20 72 65 73 70 6f 6e 73 65 0a 09 20  code response.. 
22b0: 2a 2f 0a 09 72 65 73 70 6f 6e 73 65 20 3d 20 5b  */..response = [
22c0: 5d 3b 0a 0a 09 72 65 73 70 6f 6e 73 65 2e 70 75  ];...response.pu
22d0: 73 68 28 63 61 63 6b 65 79 53 53 48 41 67 65 6e  sh(cackeySSHAgen
22e0: 74 4d 65 73 73 61 67 65 2e 53 53 48 5f 41 47 45  tMessage.SSH_AGE
22f0: 4e 54 5f 49 44 45 4e 54 49 54 49 45 53 5f 41 4e  NT_IDENTITIES_AN
2300: 53 57 45 52 29 3b 0a 09 72 65 73 70 6f 6e 73 65  SWER);..response
2310: 20 3d 20 72 65 73 70 6f 6e 73 65 2e 63 6f 6e 63   = response.conc
2320: 61 74 28 63 61 63 6b 65 79 53 53 48 41 67 65 6e  at(cackeySSHAgen
2330: 74 45 6e 63 6f 64 65 49 6e 74 28 6b 65 79 73 2e  tEncodeInt(keys.
2340: 6c 65 6e 67 74 68 29 29 3b 0a 09 6b 65 79 73 2e  length));..keys.
2350: 66 6f 72 45 61 63 68 28 66 75 6e 63 74 69 6f 6e  forEach(function
2360: 28 6b 65 79 29 20 7b 0a 09 09 72 65 73 70 6f 6e  (key) {...respon
2370: 73 65 20 3d 20 72 65 73 70 6f 6e 73 65 2e 63 6f  se = response.co
2380: 6e 63 61 74 28 63 61 63 6b 65 79 53 53 48 41 67  ncat(cackeySSHAg
2390: 65 6e 74 45 6e 63 6f 64 65 4c 56 28 6b 65 79 2e  entEncodeLV(key.
23a0: 6b 65 79 29 29 3b 0a 09 09 72 65 73 70 6f 6e 73  key));...respons
23b0: 65 20 3d 20 72 65 73 70 6f 6e 73 65 2e 63 6f 6e  e = response.con
23c0: 63 61 74 28 63 61 63 6b 65 79 53 53 48 41 67 65  cat(cackeySSHAge
23d0: 6e 74 45 6e 63 6f 64 65 53 74 72 69 6e 67 28 6b  ntEncodeString(k
23e0: 65 79 2e 6c 61 62 65 6c 29 29 3b 0a 09 7d 29 3b  ey.label));..});
23f0: 0a 0a 09 72 65 74 75 72 6e 28 72 65 73 70 6f 6e  ...return(respon
2400: 73 65 29 3b 0a 7d 0a 0a 61 73 79 6e 63 20 66 75  se);.}..async fu
2410: 6e 63 74 69 6f 6e 20 63 61 63 6b 65 79 53 53 48  nction cackeySSH
2420: 41 67 65 6e 74 43 6f 6d 6d 61 6e 64 53 69 67 6e  AgentCommandSign
2430: 52 65 71 75 65 73 74 28 72 65 71 75 65 73 74 29  Request(request)
2440: 20 7b 0a 09 76 61 72 20 6b 65 79 49 6e 66 6f 2c   {..var keyInfo,
2450: 20 64 61 74 61 2c 20 66 6c 61 67 73 3b 0a 09 76   data, flags;..v
2460: 61 72 20 63 65 72 74 73 2c 20 63 65 72 74 54 6f  ar certs, certTo
2470: 55 73 65 2c 20 63 65 72 74 54 6f 55 73 65 54 79  Use, certToUseTy
2480: 70 65 3b 0a 09 76 61 72 20 68 61 73 68 4d 65 74  pe;..var hashMet
2490: 68 6f 64 2c 20 73 69 67 6e 65 64 44 61 74 61 2c  hod, signedData,
24a0: 20 73 69 67 6e 65 64 44 61 74 61 48 65 61 64 65   signedDataHeade
24b0: 72 2c 20 73 69 67 6e 52 65 71 75 65 73 74 3b 0a  r, signRequest;.
24c0: 09 76 61 72 20 64 65 63 72 79 70 74 65 64 44 61  .var decryptedDa
24d0: 74 61 2c 20 64 65 63 72 79 70 74 52 65 71 75 65  ta, decryptReque
24e0: 73 74 3b 0a 09 76 61 72 20 6f 70 65 72 61 74 69  st;..var operati
24f0: 6f 6e 2c 20 72 65 73 70 6f 6e 73 65 3b 0a 09 76  on, response;..v
2500: 61 72 20 66 6c 61 67 4d 65 61 6e 69 6e 67 20 3d  ar flagMeaning =
2510: 20 7b 0a 09 09 53 53 48 5f 41 47 45 4e 54 5f 52   {...SSH_AGENT_R
2520: 53 41 5f 53 48 41 32 5f 32 35 36 3a 20 32 2c 0a  SA_SHA2_256: 2,.
2530: 09 09 53 53 48 5f 41 47 45 4e 54 5f 52 53 41 5f  ..SSH_AGENT_RSA_
2540: 53 48 41 32 5f 35 31 32 3a 20 34 2c 0a 09 09 53  SHA2_512: 4,...S
2550: 53 48 5f 41 47 45 4e 54 5f 52 53 41 5f 52 41 57  SH_AGENT_RSA_RAW
2560: 3a 20 20 20 20 20 20 30 78 34 30 30 30 30 30 30  :      0x4000000
2570: 30 2c 0a 09 09 53 53 48 5f 41 47 45 4e 54 5f 52  0,...SSH_AGENT_R
2580: 53 41 5f 44 45 43 52 59 50 54 3a 20 20 30 78 38  SA_DECRYPT:  0x8
2590: 30 30 30 30 30 30 30 0a 09 7d 3b 0a 0a 09 2f 2a  0000000..};.../*
25a0: 0a 09 20 2a 20 44 65 66 61 75 6c 74 20 6d 6f 64  .. * Default mod
25b0: 65 20 69 73 20 73 69 67 6e 69 6e 67 0a 09 20 2a  e is signing.. *
25c0: 2f 0a 09 6f 70 65 72 61 74 69 6f 6e 20 3d 20 22  /..operation = "
25d0: 73 69 67 6e 22 3b 0a 0a 09 2f 2a 0a 09 20 2a 20  sign";.../*.. * 
25e0: 53 74 72 69 70 20 6f 66 66 20 74 68 65 20 63 6f  Strip off the co
25f0: 6d 6d 61 6e 64 0a 09 20 2a 2f 0a 09 72 65 71 75  mmand.. */..requ
2600: 65 73 74 20 3d 20 72 65 71 75 65 73 74 2e 73 6c  est = request.sl
2610: 69 63 65 28 31 29 3b 0a 0a 09 2f 2a 0a 09 20 2a  ice(1);.../*.. *
2620: 20 47 65 74 20 63 65 72 74 69 66 69 63 61 74 65   Get certificate
2630: 20 74 6f 20 73 69 67 6e 20 75 73 69 6e 67 0a 09   to sign using..
2640: 20 2a 2f 0a 09 6b 65 79 49 6e 66 6f 20 3d 20 63   */..keyInfo = c
2650: 61 63 6b 65 79 53 53 48 41 67 65 6e 74 44 65 63  ackeySSHAgentDec
2660: 6f 64 65 4c 56 28 72 65 71 75 65 73 74 29 3b 0a  odeLV(request);.
2670: 09 72 65 71 75 65 73 74 20 3d 20 6b 65 79 49 6e  .request = keyIn
2680: 66 6f 2e 6f 75 74 70 75 74 3b 0a 09 6b 65 79 49  fo.output;..keyI
2690: 6e 66 6f 20 3d 20 6b 65 79 49 6e 66 6f 2e 76 61  nfo = keyInfo.va
26a0: 6c 75 65 3b 0a 0a 09 2f 2a 0a 09 20 2a 20 47 65  lue;.../*.. * Ge
26b0: 74 20 74 68 65 20 64 61 74 61 20 74 6f 20 73 69  t the data to si
26c0: 67 6e 0a 09 20 2a 2f 0a 09 64 61 74 61 20 3d 20  gn.. */..data = 
26d0: 63 61 63 6b 65 79 53 53 48 41 67 65 6e 74 44 65  cackeySSHAgentDe
26e0: 63 6f 64 65 4c 56 28 72 65 71 75 65 73 74 29 3b  codeLV(request);
26f0: 0a 09 72 65 71 75 65 73 74 20 3d 20 64 61 74 61  ..request = data
2700: 2e 6f 75 74 70 75 74 3b 0a 09 64 61 74 61 20 3d  .output;..data =
2710: 20 64 61 74 61 2e 76 61 6c 75 65 3b 0a 0a 09 2f   data.value;.../
2720: 2a 0a 09 20 2a 20 47 65 74 20 74 68 65 20 66 6c  *.. * Get the fl
2730: 61 67 73 0a 09 20 2a 2f 0a 09 66 6c 61 67 73 20  ags.. */..flags 
2740: 3d 20 63 61 63 6b 65 79 53 53 48 41 67 65 6e 74  = cackeySSHAgent
2750: 44 65 63 6f 64 65 49 6e 74 28 72 65 71 75 65 73  DecodeInt(reques
2760: 74 29 3b 0a 09 72 65 71 75 65 73 74 20 3d 20 66  t);..request = f
2770: 6c 61 67 73 2e 6f 75 74 70 75 74 3b 0a 09 66 6c  lags.output;..fl
2780: 61 67 73 20 3d 20 66 6c 61 67 73 2e 76 61 6c 75  ags = flags.valu
2790: 65 3b 0a 0a 09 2f 2a 0a 09 20 2a 20 46 69 6e 64  e;.../*.. * Find
27a0: 20 74 68 65 20 63 65 72 74 69 66 69 63 61 74 65   the certificate
27b0: 20 74 68 61 74 20 6d 61 74 63 68 65 73 20 74 68   that matches th
27c0: 65 20 72 65 71 75 65 73 74 65 64 20 6b 65 79 0a  e requested key.
27d0: 09 20 2a 2f 0a 09 63 65 72 74 73 20 3d 20 61 77  . */..certs = aw
27e0: 61 69 74 20 63 61 63 6b 65 79 53 53 48 41 67 65  ait cackeySSHAge
27f0: 6e 74 47 65 74 43 65 72 74 69 66 69 63 61 74 65  ntGetCertificate
2800: 73 28 29 3b 0a 09 63 65 72 74 54 6f 55 73 65 20  s();..certToUse 
2810: 3d 20 6e 75 6c 6c 3b 0a 09 63 61 63 6b 65 79 53  = null;..cackeyS
2820: 53 48 41 67 65 6e 74 47 65 74 53 53 48 4b 65 79  SHAgentGetSSHKey
2830: 54 79 70 65 73 28 29 2e 66 6f 72 45 61 63 68 28  Types().forEach(
2840: 66 75 6e 63 74 69 6f 6e 28 73 73 68 4b 65 79 54  function(sshKeyT
2850: 79 70 65 29 20 7b 0a 09 09 63 65 72 74 73 2e 66  ype) {...certs.f
2860: 6f 72 45 61 63 68 28 66 75 6e 63 74 69 6f 6e 28  orEach(function(
2870: 63 65 72 74 29 20 7b 0a 09 09 09 76 61 72 20 6b  cert) {....var k
2880: 65 79 3b 0a 0a 09 09 09 69 66 20 28 63 65 72 74  ey;.....if (cert
2890: 54 6f 55 73 65 29 20 7b 0a 09 09 09 09 72 65 74  ToUse) {.....ret
28a0: 75 72 6e 3b 0a 09 09 09 7d 0a 0a 09 09 09 6b 65  urn;....}.....ke
28b0: 79 20 3d 20 63 61 63 6b 65 79 53 53 48 41 67 65  y = cackeySSHAge
28c0: 6e 74 45 6e 63 6f 64 65 43 65 72 74 54 6f 4b 65  ntEncodeCertToKe
28d0: 79 41 6e 64 49 44 28 63 65 72 74 2e 63 65 72 74  yAndID(cert.cert
28e0: 69 66 69 63 61 74 65 2c 20 73 73 68 4b 65 79 54  ificate, sshKeyT
28f0: 79 70 65 29 3b 0a 0a 09 09 09 69 66 20 28 63 61  ype);.....if (ca
2900: 63 6b 65 79 53 53 48 41 67 65 6e 74 43 6f 6d 70  ckeySSHAgentComp
2910: 61 72 65 52 65 71 75 65 73 74 41 6e 64 4b 65 79  areRequestAndKey
2920: 28 6b 65 79 2e 6b 65 79 2c 20 6b 65 79 49 6e 66  (key.key, keyInf
2930: 6f 29 29 20 7b 0a 09 09 09 09 63 65 72 74 54 6f  o)) {.....certTo
2940: 55 73 65 20 3d 20 63 65 72 74 3b 0a 09 09 09 09  Use = cert;.....
2950: 63 65 72 74 54 6f 55 73 65 54 79 70 65 20 3d 20  certToUseType = 
2960: 6b 65 79 2e 70 75 62 6c 69 63 4b 65 79 54 79 70  key.publicKeyTyp
2970: 65 3b 0a 09 09 09 7d 0a 09 09 7d 29 3b 0a 09 7d  e;....}...});..}
2980: 29 3b 0a 0a 09 2f 2a 0a 09 20 2a 20 49 66 20 6e  );.../*.. * If n
2990: 6f 20 63 65 72 74 69 66 69 63 61 74 65 20 69 73  o certificate is
29a0: 20 66 6f 75 6e 64 2c 20 72 65 74 75 72 6e 20 61   found, return a
29b0: 6e 20 65 72 72 6f 72 0a 09 20 2a 2f 0a 09 69 66  n error.. */..if
29c0: 20 28 21 63 65 72 74 54 6f 55 73 65 29 20 7b 0a   (!certToUse) {.
29d0: 09 09 63 6f 6e 73 6f 6c 65 2e 69 6e 66 6f 28 22  ..console.info("
29e0: 5b 63 61 63 6b 65 79 53 53 48 5d 20 55 6e 61 62  [cackeySSH] Unab
29f0: 6c 65 20 74 6f 20 66 69 6e 64 20 61 20 63 65 72  le to find a cer
2a00: 74 69 66 69 63 61 74 65 20 74 6f 20 6d 61 74 63  tificate to matc
2a10: 68 20 74 68 65 20 72 65 71 75 65 73 74 65 64 20  h the requested 
2a20: 6b 65 79 3a 22 2c 20 6b 65 79 49 6e 66 6f 29 3b  key:", keyInfo);
2a30: 0a 0a 09 09 72 65 74 75 72 6e 28 6e 75 6c 6c 29  ....return(null)
2a40: 3b 0a 09 7d 0a 0a 09 2f 2a 0a 09 20 2a 20 50 65  ;..}.../*.. * Pe
2a50: 72 66 6f 72 6d 20 68 61 73 68 69 6e 67 20 6f 66  rform hashing of
2a60: 20 74 68 65 20 64 61 74 61 20 61 73 20 73 70 65   the data as spe
2a70: 63 69 66 69 65 64 20 62 79 20 74 68 65 20 66 6c  cified by the fl
2a80: 61 67 73 0a 09 20 2a 2f 0a 09 73 77 69 74 63 68  ags.. */..switch
2a90: 20 28 63 65 72 74 54 6f 55 73 65 54 79 70 65 29   (certToUseType)
2aa0: 20 7b 0a 09 09 63 61 73 65 20 22 52 53 41 22 3a   {...case "RSA":
2ab0: 0a 09 09 09 69 66 20 28 28 66 6c 61 67 73 20 26  ....if ((flags &
2ac0: 20 66 6c 61 67 4d 65 61 6e 69 6e 67 2e 53 53 48   flagMeaning.SSH
2ad0: 5f 41 47 45 4e 54 5f 52 53 41 5f 53 48 41 32 5f  _AGENT_RSA_SHA2_
2ae0: 35 31 32 29 20 3d 3d 20 66 6c 61 67 4d 65 61 6e  512) == flagMean
2af0: 69 6e 67 2e 53 53 48 5f 41 47 45 4e 54 5f 52 53  ing.SSH_AGENT_RS
2b00: 41 5f 53 48 41 32 5f 35 31 32 29 20 7b 0a 09 09  A_SHA2_512) {...
2b10: 09 09 68 61 73 68 4d 65 74 68 6f 64 20 3d 20 22  ..hashMethod = "
2b20: 53 48 41 35 31 32 22 3b 0a 09 09 09 09 64 61 74  SHA512";.....dat
2b30: 61 20 3d 20 61 77 61 69 74 20 63 72 79 70 74 6f  a = await crypto
2b40: 2e 73 75 62 74 6c 65 2e 64 69 67 65 73 74 28 22  .subtle.digest("
2b50: 53 48 41 2d 35 31 32 22 2c 20 6e 65 77 20 55 69  SHA-512", new Ui
2b60: 6e 74 38 41 72 72 61 79 28 64 61 74 61 29 29 3b  nt8Array(data));
2b70: 0a 09 09 09 7d 20 65 6c 73 65 20 69 66 20 28 28  ....} else if ((
2b80: 66 6c 61 67 73 20 26 20 66 6c 61 67 4d 65 61 6e  flags & flagMean
2b90: 69 6e 67 2e 53 53 48 5f 41 47 45 4e 54 5f 52 53  ing.SSH_AGENT_RS
2ba0: 41 5f 53 48 41 32 5f 32 35 36 29 20 3d 3d 20 66  A_SHA2_256) == f
2bb0: 6c 61 67 4d 65 61 6e 69 6e 67 2e 53 53 48 5f 41  lagMeaning.SSH_A
2bc0: 47 45 4e 54 5f 52 53 41 5f 53 48 41 32 5f 32 35  GENT_RSA_SHA2_25
2bd0: 36 29 20 7b 0a 09 09 09 09 68 61 73 68 4d 65 74  6) {.....hashMet
2be0: 68 6f 64 20 3d 20 22 53 48 41 32 35 36 22 3b 0a  hod = "SHA256";.
2bf0: 09 09 09 09 64 61 74 61 20 3d 20 61 77 61 69 74  ....data = await
2c00: 20 63 72 79 70 74 6f 2e 73 75 62 74 6c 65 2e 64   crypto.subtle.d
2c10: 69 67 65 73 74 28 22 53 48 41 2d 32 35 36 22 2c  igest("SHA-256",
2c20: 20 6e 65 77 20 55 69 6e 74 38 41 72 72 61 79 28   new Uint8Array(
2c30: 64 61 74 61 29 29 3b 0a 09 09 09 7d 20 65 6c 73  data));....} els
2c40: 65 20 69 66 20 28 66 6c 61 67 73 20 3d 3d 20 28  e if (flags == (
2c50: 66 6c 61 67 4d 65 61 6e 69 6e 67 2e 53 53 48 5f  flagMeaning.SSH_
2c60: 41 47 45 4e 54 5f 52 53 41 5f 52 41 57 20 7c 20  AGENT_RSA_RAW | 
2c70: 66 6c 61 67 4d 65 61 6e 69 6e 67 2e 53 53 48 5f  flagMeaning.SSH_
2c80: 41 47 45 4e 54 5f 52 53 41 5f 44 45 43 52 59 50  AGENT_RSA_DECRYP
2c90: 54 29 29 20 7b 0a 09 09 09 09 6f 70 65 72 61 74  T)) {.....operat
2ca0: 69 6f 6e 20 3d 20 22 64 65 63 72 79 70 74 22 3b  ion = "decrypt";
2cb0: 0a 09 09 09 09 64 61 74 61 20 3d 20 6e 65 77 20  .....data = new 
2cc0: 55 69 6e 74 38 41 72 72 61 79 28 64 61 74 61 29  Uint8Array(data)
2cd0: 3b 0a 09 09 09 7d 20 65 6c 73 65 20 69 66 20 28  ;....} else if (
2ce0: 66 6c 61 67 73 20 3d 3d 20 66 6c 61 67 4d 65 61  flags == flagMea
2cf0: 6e 69 6e 67 2e 53 53 48 5f 41 47 45 4e 54 5f 52  ning.SSH_AGENT_R
2d00: 53 41 5f 52 41 57 29 20 7b 0a 09 09 09 09 68 61  SA_RAW) {.....ha
2d10: 73 68 4d 65 74 68 6f 64 20 3d 20 22 52 41 57 22  shMethod = "RAW"
2d20: 3b 0a 09 09 09 09 64 61 74 61 20 3d 20 6e 65 77  ;.....data = new
2d30: 20 55 69 6e 74 38 41 72 72 61 79 28 64 61 74 61   Uint8Array(data
2d40: 29 3b 0a 09 09 09 7d 20 65 6c 73 65 20 69 66 20  );....} else if 
2d50: 28 66 6c 61 67 73 20 3d 3d 20 30 29 20 7b 0a 09  (flags == 0) {..
2d60: 09 09 09 68 61 73 68 4d 65 74 68 6f 64 20 3d 20  ...hashMethod = 
2d70: 22 53 48 41 31 22 3b 0a 09 09 09 09 64 61 74 61  "SHA1";.....data
2d80: 20 3d 20 61 77 61 69 74 20 63 72 79 70 74 6f 2e   = await crypto.
2d90: 73 75 62 74 6c 65 2e 64 69 67 65 73 74 28 22 53  subtle.digest("S
2da0: 48 41 2d 31 22 2c 20 6e 65 77 20 55 69 6e 74 38  HA-1", new Uint8
2db0: 41 72 72 61 79 28 64 61 74 61 29 29 3b 0a 09 09  Array(data));...
2dc0: 09 7d 20 65 6c 73 65 20 7b 0a 09 09 09 09 63 6f  .} else {.....co
2dd0: 6e 73 6f 6c 65 2e 69 6e 66 6f 28 22 5b 63 61 63  nsole.info("[cac
2de0: 6b 65 79 53 53 48 5d 20 53 69 67 6e 20 72 65 71  keySSH] Sign req
2df0: 75 65 73 74 20 77 69 74 68 20 66 6c 61 67 73 20  uest with flags 
2e00: 73 65 74 20 74 6f 22 2c 20 66 6c 61 67 73 2c 20  set to", flags, 
2e10: 22 77 68 69 63 68 20 69 73 20 75 6e 73 75 70 70  "which is unsupp
2e20: 6f 72 74 65 64 2c 20 66 61 69 6c 69 6e 67 20 74  orted, failing t
2e30: 68 65 20 72 65 71 75 65 73 74 2e 22 29 3b 0a 0a  he request.");..
2e40: 09 09 09 09 72 65 74 75 72 6e 28 6e 75 6c 6c 29  ....return(null)
2e50: 3b 0a 09 09 09 7d 0a 0a 09 09 09 73 77 69 74 63  ;....}.....switc
2e60: 68 20 28 68 61 73 68 4d 65 74 68 6f 64 29 20 7b  h (hashMethod) {
2e70: 0a 09 09 09 09 63 61 73 65 20 22 52 41 57 22 3a  .....case "RAW":
2e80: 0a 09 09 09 09 09 73 69 67 6e 65 64 44 61 74 61  ......signedData
2e90: 48 65 61 64 65 72 20 3d 20 63 61 63 6b 65 79 53  Header = cackeyS
2ea0: 53 48 41 67 65 6e 74 45 6e 63 6f 64 65 53 74 72  SHAgentEncodeStr
2eb0: 69 6e 67 28 22 72 73 61 22 29 3b 0a 09 09 09 09  ing("rsa");.....
2ec0: 09 62 72 65 61 6b 3b 0a 09 09 09 09 63 61 73 65  .break;.....case
2ed0: 20 22 53 48 41 31 22 3a 0a 09 09 09 09 09 73 69   "SHA1":......si
2ee0: 67 6e 65 64 44 61 74 61 48 65 61 64 65 72 20 3d  gnedDataHeader =
2ef0: 20 63 61 63 6b 65 79 53 53 48 41 67 65 6e 74 45   cackeySSHAgentE
2f00: 6e 63 6f 64 65 53 74 72 69 6e 67 28 22 73 73 68  ncodeString("ssh
2f10: 2d 72 73 61 22 29 3b 0a 09 09 09 09 09 62 72 65  -rsa");......bre
2f20: 61 6b 3b 0a 09 09 09 09 63 61 73 65 20 22 53 48  ak;.....case "SH
2f30: 41 32 35 36 22 3a 0a 09 09 09 09 09 73 69 67 6e  A256":......sign
2f40: 65 64 44 61 74 61 48 65 61 64 65 72 20 3d 20 63  edDataHeader = c
2f50: 61 63 6b 65 79 53 53 48 41 67 65 6e 74 45 6e 63  ackeySSHAgentEnc
2f60: 6f 64 65 53 74 72 69 6e 67 28 22 72 73 61 2d 73  odeString("rsa-s
2f70: 68 61 32 2d 32 35 36 22 29 3b 0a 09 09 09 09 09  ha2-256");......
2f80: 62 72 65 61 6b 3b 0a 09 09 09 09 63 61 73 65 20  break;.....case 
2f90: 22 53 48 41 35 31 32 22 3a 0a 09 09 09 09 09 73  "SHA512":......s
2fa0: 69 67 6e 65 64 44 61 74 61 48 65 61 64 65 72 20  ignedDataHeader 
2fb0: 3d 20 63 61 63 6b 65 79 53 53 48 41 67 65 6e 74  = cackeySSHAgent
2fc0: 45 6e 63 6f 64 65 53 74 72 69 6e 67 28 22 72 73  EncodeString("rs
2fd0: 61 2d 73 68 61 32 2d 35 31 32 22 29 3b 0a 09 09  a-sha2-512");...
2fe0: 09 09 09 62 72 65 61 6b 3b 0a 09 09 09 09 64 65  ...break;.....de
2ff0: 66 61 75 6c 74 3a 0a 09 09 09 09 09 63 6f 6e 73  fault:......cons
3000: 6f 6c 65 2e 69 6e 66 6f 28 22 5b 63 61 63 6b 65  ole.info("[cacke
3010: 79 53 53 48 5d 20 55 6e 73 75 70 70 6f 72 74 65  ySSH] Unsupporte
3020: 64 20 68 61 73 68 69 6e 67 20 6d 65 74 68 6f 64  d hashing method
3030: 20 66 6f 72 20 52 53 41 3a 22 2c 20 68 61 73 68   for RSA:", hash
3040: 4d 65 74 68 6f 64 2c 20 22 66 61 69 6c 69 6e 67  Method, "failing
3050: 20 74 68 65 20 72 65 71 75 65 73 74 2e 22 29 3b   the request.");
3060: 0a 0a 09 09 09 09 09 72 65 74 75 72 6e 28 6e 75  .......return(nu
3070: 6c 6c 29 3b 0a 09 09 09 09 09 62 72 65 61 6b 3b  ll);......break;
3080: 0a 09 09 09 7d 0a 09 09 09 62 72 65 61 6b 3b 0a  ....}....break;.
3090: 09 09 64 65 66 61 75 6c 74 3a 0a 09 09 09 63 6f  ..default:....co
30a0: 6e 73 6f 6c 65 2e 69 6e 66 6f 28 22 5b 63 61 63  nsole.info("[cac
30b0: 6b 65 79 53 53 48 5d 20 55 6e 73 75 70 70 6f 72  keySSH] Unsuppor
30c0: 74 65 64 20 70 75 62 6c 69 63 20 6b 65 79 20 74  ted public key t
30d0: 79 70 65 3a 22 2c 20 63 65 72 74 54 6f 55 73 65  ype:", certToUse
30e0: 54 79 70 65 2c 20 22 66 61 69 6c 69 6e 67 20 74  Type, "failing t
30f0: 68 65 20 72 65 71 75 65 73 74 2e 22 29 3b 0a 0a  he request.");..
3100: 09 09 09 72 65 74 75 72 6e 28 6e 75 6c 6c 29 3b  ...return(null);
3110: 0a 09 09 09 62 72 65 61 6b 3b 0a 09 7d 0a 0a 09  ....break;..}...
3120: 2f 2a 0a 09 20 2a 20 53 69 67 6e 20 6f 72 20 64  /*.. * Sign or d
3130: 65 63 72 79 70 74 20 74 68 65 20 64 61 74 61 0a  ecrypt the data.
3140: 09 20 2a 2f 0a 09 73 77 69 74 63 68 20 28 6f 70  . */..switch (op
3150: 65 72 61 74 69 6f 6e 29 20 7b 0a 09 09 63 61 73  eration) {...cas
3160: 65 20 22 73 69 67 6e 22 3a 0a 09 09 09 73 69 67  e "sign":....sig
3170: 6e 52 65 71 75 65 73 74 20 3d 20 7b 0a 09 09 09  nRequest = {....
3180: 09 68 61 73 68 3a 20 68 61 73 68 4d 65 74 68 6f  .hash: hashMetho
3190: 64 2c 0a 09 09 09 09 63 65 72 74 69 66 69 63 61  d,.....certifica
31a0: 74 65 3a 20 63 65 72 74 54 6f 55 73 65 2e 63 65  te: certToUse.ce
31b0: 72 74 69 66 69 63 61 74 65 2c 0a 09 09 09 09 64  rtificate,.....d
31c0: 69 67 65 73 74 3a 20 6e 65 77 20 55 69 6e 74 38  igest: new Uint8
31d0: 41 72 72 61 79 28 64 61 74 61 29 0a 09 09 09 7d  Array(data)....}
31e0: 3b 0a 0a 09 09 09 69 66 20 28 67 6f 6f 67 2e 44  ;.....if (goog.D
31f0: 45 42 55 47 29 20 7b 0a 09 09 09 09 63 6f 6e 73  EBUG) {.....cons
3200: 6f 6c 65 2e 6c 6f 67 28 22 5b 63 61 63 6b 65 79  ole.log("[cackey
3210: 53 53 48 5d 20 52 65 71 75 65 73 74 69 6e 67 20  SSH] Requesting 
3220: 43 41 43 4b 65 79 20 73 69 67 6e 20 6d 65 73 73  CACKey sign mess
3230: 61 67 65 3a 22 2c 20 73 69 67 6e 52 65 71 75 65  age:", signReque
3240: 73 74 29 3b 0a 09 09 09 7d 0a 0a 09 09 09 73 69  st);....}.....si
3250: 67 6e 65 64 44 61 74 61 20 3d 20 61 77 61 69 74  gnedData = await
3260: 20 63 61 63 6b 65 79 53 69 67 6e 4d 65 73 73 61   cackeySignMessa
3270: 67 65 28 73 69 67 6e 52 65 71 75 65 73 74 29 3b  ge(signRequest);
3280: 0a 09 09 09 73 69 67 6e 65 64 44 61 74 61 20 3d  ....signedData =
3290: 20 41 72 72 61 79 2e 66 72 6f 6d 28 6e 65 77 20   Array.from(new 
32a0: 55 69 6e 74 38 41 72 72 61 79 28 73 69 67 6e 65  Uint8Array(signe
32b0: 64 44 61 74 61 29 29 3b 0a 09 09 09 62 72 65 61  dData));....brea
32c0: 6b 3b 0a 09 09 63 61 73 65 20 22 64 65 63 72 79  k;...case "decry
32d0: 70 74 22 3a 0a 09 09 09 2f 2a 20 58 58 58 3a 54  pt":..../* XXX:T
32e0: 4f 44 4f 3a 20 49 6e 63 6f 6d 70 6c 65 74 65 20  ODO: Incomplete 
32f0: 21 20 2a 2f 0a 09 09 09 64 65 63 72 79 70 74 52  ! */....decryptR
3300: 65 71 75 65 73 74 20 3d 20 7b 0a 09 09 09 09 64  equest = {.....d
3310: 61 74 61 3a 20 64 61 74 61 0a 09 09 09 7d 0a 09  ata: data....}..
3320: 09 09 62 72 65 61 6b 3b 0a 09 7d 0a 0a 09 2f 2a  ..break;..}.../*
3330: 0a 09 20 2a 20 45 6e 63 6f 64 65 20 73 69 67 6e  .. * Encode sign
3340: 61 74 75 72 65 0a 09 20 2a 2f 0a 09 73 69 67 6e  ature.. */..sign
3350: 65 64 44 61 74 61 20 3d 20 73 69 67 6e 65 64 44  edData = signedD
3360: 61 74 61 48 65 61 64 65 72 2e 63 6f 6e 63 61 74  ataHeader.concat
3370: 28 63 61 63 6b 65 79 53 53 48 41 67 65 6e 74 45  (cackeySSHAgentE
3380: 6e 63 6f 64 65 4c 56 28 73 69 67 6e 65 64 44 61  ncodeLV(signedDa
3390: 74 61 29 29 3b 0a 0a 09 2f 2a 0a 09 20 2a 20 45  ta));.../*.. * E
33a0: 6e 63 6f 64 65 20 72 65 73 70 6f 6e 73 65 0a 09  ncode response..
33b0: 20 2a 2f 0a 09 72 65 73 70 6f 6e 73 65 20 3d 20   */..response = 
33c0: 5b 5d 3b 0a 0a 09 72 65 73 70 6f 6e 73 65 2e 70  [];...response.p
33d0: 75 73 68 28 63 61 63 6b 65 79 53 53 48 41 67 65  ush(cackeySSHAge
33e0: 6e 74 4d 65 73 73 61 67 65 2e 53 53 48 5f 41 47  ntMessage.SSH_AG
33f0: 45 4e 54 5f 53 49 47 4e 5f 52 45 53 50 4f 4e 53  ENT_SIGN_RESPONS
3400: 45 29 3b 0a 09 72 65 73 70 6f 6e 73 65 20 3d 20  E);..response = 
3410: 72 65 73 70 6f 6e 73 65 2e 63 6f 6e 63 61 74 28  response.concat(
3420: 63 61 63 6b 65 79 53 53 48 41 67 65 6e 74 45 6e  cackeySSHAgentEn
3430: 63 6f 64 65 4c 56 28 73 69 67 6e 65 64 44 61 74  codeLV(signedDat
3440: 61 29 29 3b 0a 0a 09 72 65 74 75 72 6e 28 72 65  a));...return(re
3450: 73 70 6f 6e 73 65 29 3b 0a 7d 0a 0a 2f 2a 0a 20  sponse);.}../*. 
3460: 2a 20 53 65 73 73 69 6f 6e 20 68 61 6e 64 6c 69  * Session handli
3470: 6e 67 0a 20 2a 2f 0a 61 73 79 6e 63 20 66 75 6e  ng. */.async fun
3480: 63 74 69 6f 6e 20 63 61 63 6b 65 79 53 53 48 41  ction cackeySSHA
3490: 67 65 6e 74 48 61 6e 64 6c 65 4d 65 73 73 61 67  gentHandleMessag
34a0: 65 28 73 6f 63 6b 65 74 2c 20 72 65 71 75 65 73  e(socket, reques
34b0: 74 29 20 7b 0a 09 76 61 72 20 73 73 68 52 65 71  t) {..var sshReq
34c0: 75 65 73 74 49 44 2c 20 73 73 68 52 65 71 75 65  uestID, sshReque
34d0: 73 74 2c 20 72 65 73 70 6f 6e 73 65 2c 20 73 73  st, response, ss
34e0: 68 52 65 73 70 6f 6e 73 65 3b 0a 09 76 61 72 20  hResponse;..var 
34f0: 73 73 68 48 61 6e 64 6c 65 72 45 72 72 6f 72 3b  sshHandlerError;
3500: 0a 09 76 61 72 20 70 6f 73 74 4d 65 73 73 61 67  ..var postMessag
3510: 65 45 78 63 65 70 74 69 6f 6e 3b 0a 0a 09 69 66  eException;...if
3520: 20 28 21 72 65 71 75 65 73 74 2e 74 79 70 65 20   (!request.type 
3530: 7c 7c 20 72 65 71 75 65 73 74 2e 74 79 70 65 20  || request.type 
3540: 21 3d 3d 20 22 61 75 74 68 2d 61 67 65 6e 74 40  !== "auth-agent@
3550: 6f 70 65 6e 73 73 68 2e 63 6f 6d 22 29 20 7b 0a  openssh.com") {.
3560: 09 09 72 65 74 75 72 6e 3b 0a 09 7d 0a 0a 09 69  ..return;..}...i
3570: 66 20 28 21 72 65 71 75 65 73 74 2e 64 61 74 61  f (!request.data
3580: 20 7c 7c 20 72 65 71 75 65 73 74 2e 64 61 74 61   || request.data
3590: 2e 6c 65 6e 67 74 68 20 3c 20 31 29 20 7b 0a 09  .length < 1) {..
35a0: 09 72 65 74 75 72 6e 3b 0a 09 7d 0a 0a 09 73 73  .return;..}...ss
35b0: 68 52 65 71 75 65 73 74 49 44 20 3d 20 72 65 71  hRequestID = req
35c0: 75 65 73 74 2e 64 61 74 61 5b 30 5d 3b 0a 09 73  uest.data[0];..s
35d0: 73 68 52 65 71 75 65 73 74 20 3d 20 7b 7d 3b 0a  shRequest = {};.
35e0: 09 69 66 20 28 73 73 68 52 65 71 75 65 73 74 49  .if (sshRequestI
35f0: 44 20 3c 20 63 61 63 6b 65 79 53 53 48 41 67 65  D < cackeySSHAge
3600: 6e 74 43 6f 6d 6d 61 6e 64 73 2e 6c 65 6e 67 74  ntCommands.lengt
3610: 68 29 20 7b 0a 09 09 73 73 68 52 65 71 75 65 73  h) {...sshReques
3620: 74 20 3d 20 63 61 63 6b 65 79 53 53 48 41 67 65  t = cackeySSHAge
3630: 6e 74 43 6f 6d 6d 61 6e 64 73 5b 73 73 68 52 65  ntCommands[sshRe
3640: 71 75 65 73 74 49 44 5d 3b 0a 09 7d 0a 0a 09 72  questID];..}...r
3650: 65 73 70 6f 6e 73 65 20 3d 20 6e 75 6c 6c 3b 0a  esponse = null;.
3660: 09 69 66 20 28 21 73 73 68 52 65 71 75 65 73 74  .if (!sshRequest
3670: 2e 6e 61 6d 65 29 20 7b 0a 09 09 69 66 20 28 67  .name) {...if (g
3680: 6f 6f 67 2e 44 45 42 55 47 29 20 7b 0a 09 09 09  oog.DEBUG) {....
3690: 63 6f 6e 73 6f 6c 65 2e 6c 6f 67 28 22 5b 63 61  console.log("[ca
36a0: 63 6b 65 79 53 53 48 5d 20 55 6e 73 75 70 70 6f  ckeySSH] Unsuppo
36b0: 72 74 65 64 20 72 65 71 75 65 73 74 3a 20 22 2c  rted request: ",
36c0: 20 72 65 71 75 65 73 74 2c 20 22 3b 20 66 72 6f   request, "; fro
36d0: 6d 3a 20 22 2c 20 73 6f 63 6b 65 74 2e 73 65 6e  m: ", socket.sen
36e0: 64 65 72 2e 69 64 29 3b 0a 09 09 7d 0a 09 7d 20  der.id);...}..} 
36f0: 65 6c 73 65 20 7b 0a 09 09 69 66 20 28 67 6f 6f  else {...if (goo
3700: 67 2e 44 45 42 55 47 29 20 7b 0a 09 09 09 63 6f  g.DEBUG) {....co
3710: 6e 73 6f 6c 65 2e 6c 6f 67 28 22 5b 63 61 63 6b  nsole.log("[cack
3720: 65 79 53 53 48 5d 20 52 65 71 75 65 73 74 3a 20  eySSH] Request: 
3730: 22 2c 20 73 73 68 52 65 71 75 65 73 74 2e 6e 61  ", sshRequest.na
3740: 6d 65 2c 20 22 3b 20 66 72 6f 6d 3a 20 22 2c 20  me, "; from: ", 
3750: 73 6f 63 6b 65 74 2e 73 65 6e 64 65 72 2e 69 64  socket.sender.id
3760: 29 3b 0a 09 09 7d 0a 0a 09 09 74 72 79 20 7b 0a  );...}....try {.
3770: 09 09 09 72 65 73 70 6f 6e 73 65 20 3d 20 61 77  ...response = aw
3780: 61 69 74 20 73 73 68 52 65 71 75 65 73 74 2e 68  ait sshRequest.h
3790: 61 6e 64 6c 65 72 28 72 65 71 75 65 73 74 2e 64  andler(request.d
37a0: 61 74 61 29 3b 0a 09 09 7d 20 63 61 74 63 68 20  ata);...} catch 
37b0: 28 73 73 68 48 61 6e 64 6c 65 72 45 72 72 6f 72  (sshHandlerError
37c0: 29 20 7b 0a 09 09 09 72 65 73 70 6f 6e 73 65 20  ) {....response 
37d0: 3d 20 6e 75 6c 6c 3b 0a 0a 09 09 09 63 6f 6e 73  = null;.....cons
37e0: 6f 6c 65 2e 65 72 72 6f 72 28 22 5b 63 61 63 6b  ole.error("[cack
37f0: 65 79 53 53 48 5d 20 52 65 71 75 65 73 74 3a 22  eySSH] Request:"
3800: 2c 20 73 73 68 52 65 71 75 65 73 74 2e 6e 61 6d  , sshRequest.nam
3810: 65 2c 20 22 28 22 2c 20 72 65 71 75 65 73 74 2c  e, "(", request,
3820: 20 22 29 20 45 52 52 4f 52 3a 22 2c 20 73 73 68   ") ERROR:", ssh
3830: 48 61 6e 64 6c 65 72 45 72 72 6f 72 29 3b 0a 09  HandlerError);..
3840: 09 7d 0a 09 7d 0a 0a 09 69 66 20 28 21 72 65 73  .}..}...if (!res
3850: 70 6f 6e 73 65 29 20 7b 0a 09 09 72 65 73 70 6f  ponse) {...respo
3860: 6e 73 65 20 3d 20 5b 63 61 63 6b 65 79 53 53 48  nse = [cackeySSH
3870: 41 67 65 6e 74 4d 65 73 73 61 67 65 2e 53 53 48  AgentMessage.SSH
3880: 5f 41 47 45 4e 54 5f 46 41 49 4c 55 52 45 5d 3b  _AGENT_FAILURE];
3890: 0a 09 7d 0a 0a 09 73 73 68 52 65 73 70 6f 6e 73  ..}...sshRespons
38a0: 65 20 3d 20 7b 0a 09 09 74 79 70 65 3a 20 22 61  e = {...type: "a
38b0: 75 74 68 2d 61 67 65 6e 74 40 6f 70 65 6e 73 73  uth-agent@openss
38c0: 68 2e 63 6f 6d 22 2c 0a 09 09 64 61 74 61 3a 20  h.com",...data: 
38d0: 72 65 73 70 6f 6e 73 65 0a 09 7d 3b 0a 0a 09 69  response..};...i
38e0: 66 20 28 67 6f 6f 67 2e 44 45 42 55 47 29 20 7b  f (goog.DEBUG) {
38f0: 0a 09 09 63 6f 6e 73 6f 6c 65 2e 6c 6f 67 28 22  ...console.log("
3900: 5b 63 61 63 6b 65 79 53 53 48 5d 20 52 65 73 70  [cackeySSH] Resp
3910: 6f 6e 73 65 3a 20 22 2c 20 73 73 68 52 65 73 70  onse: ", sshResp
3920: 6f 6e 73 65 29 3b 0a 09 7d 0a 0a 09 74 72 79 20  onse);..}...try 
3930: 7b 0a 09 09 73 6f 63 6b 65 74 2e 70 6f 73 74 4d  {...socket.postM
3940: 65 73 73 61 67 65 28 73 73 68 52 65 73 70 6f 6e  essage(sshRespon
3950: 73 65 29 3b 0a 09 7d 20 63 61 74 63 68 20 28 70  se);..} catch (p
3960: 6f 73 74 4d 65 73 73 61 67 65 45 78 63 65 70 74  ostMessageExcept
3970: 69 6f 6e 29 20 7b 0a 09 09 69 66 20 28 67 6f 6f  ion) {...if (goo
3980: 67 2e 44 45 42 55 47 29 20 7b 0a 09 09 09 63 6f  g.DEBUG) {....co
3990: 6e 73 6f 6c 65 2e 6c 6f 67 28 22 5b 63 61 63 6b  nsole.log("[cack
39a0: 65 79 53 53 48 5d 20 46 61 69 6c 65 64 20 74 6f  eySSH] Failed to
39b0: 20 73 65 6e 64 20 72 65 73 70 6f 6e 73 65 22 2c   send response",
39c0: 20 70 6f 73 74 4d 65 73 73 61 67 65 45 78 63 65   postMessageExce
39d0: 70 74 69 6f 6e 29 3b 0a 09 09 7d 0a 09 7d 0a 0a  ption);...}..}..
39e0: 09 72 65 74 75 72 6e 3b 0a 7d 0a 0a 66 75 6e 63  .return;.}..func
39f0: 74 69 6f 6e 20 63 61 63 6b 65 79 53 53 48 41 67  tion cackeySSHAg
3a00: 65 6e 74 41 63 63 65 70 74 43 6f 6e 6e 65 63 74  entAcceptConnect
3a10: 69 6f 6e 28 73 6f 63 6b 65 74 29 20 7b 0a 09 69  ion(socket) {..i
3a20: 66 20 28 21 73 6f 63 6b 65 74 29 20 7b 0a 09 09  f (!socket) {...
3a30: 72 65 74 75 72 6e 3b 0a 09 7d 0a 0a 09 2f 2a 0a  return;..}.../*.
3a40: 09 20 2a 20 4f 6e 6c 79 20 61 63 63 65 70 74 20  . * Only accept 
3a50: 63 6f 6e 6e 65 63 74 69 6f 6e 73 20 66 72 6f 6d  connections from
3a60: 20 61 70 70 72 6f 76 65 64 20 61 70 70 73 0a 09   approved apps..
3a70: 20 2a 2f 0a 09 69 66 20 28 21 73 6f 63 6b 65 74   */..if (!socket
3a80: 2e 73 65 6e 64 65 72 20 7c 7c 20 21 73 6f 63 6b  .sender || !sock
3a90: 65 74 2e 73 65 6e 64 65 72 2e 69 64 20 7c 7c 20  et.sender.id || 
3aa0: 21 63 61 63 6b 65 79 53 53 48 41 67 65 6e 74 41  !cackeySSHAgentA
3ab0: 70 70 72 6f 76 65 64 41 70 70 73 2e 69 6e 63 6c  pprovedApps.incl
3ac0: 75 64 65 73 28 73 6f 63 6b 65 74 2e 73 65 6e 64  udes(socket.send
3ad0: 65 72 2e 69 64 29 29 20 7b 0a 09 09 63 6f 6e 73  er.id)) {...cons
3ae0: 6f 6c 65 2e 6c 6f 67 28 22 5b 63 61 63 6b 65 79  ole.log("[cackey
3af0: 53 53 48 5d 20 49 67 6e 6f 72 69 6e 67 20 75 6e  SSH] Ignoring un
3b00: 61 70 70 72 6f 76 65 64 20 61 70 70 3a 20 22 2c  approved app: ",
3b10: 20 73 6f 63 6b 65 74 2e 73 65 6e 64 65 72 29 3b   socket.sender);
3b20: 0a 0a 09 09 72 65 74 75 72 6e 3b 0a 09 7d 0a 0a  ....return;..}..
3b30: 09 63 6f 6e 73 6f 6c 65 2e 6c 6f 67 28 22 5b 63  .console.log("[c
3b40: 61 63 6b 65 79 53 53 48 5d 20 41 63 63 65 70 74  ackeySSH] Accept
3b50: 65 64 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 66 72  ed connection fr
3b60: 6f 6d 3a 20 22 2c 20 73 6f 63 6b 65 74 2e 73 65  om: ", socket.se
3b70: 6e 64 65 72 2e 69 64 29 3b 0a 09 73 6f 63 6b 65  nder.id);..socke
3b80: 74 2e 6f 6e 4d 65 73 73 61 67 65 2e 61 64 64 4c  t.onMessage.addL
3b90: 69 73 74 65 6e 65 72 28 66 75 6e 63 74 69 6f 6e  istener(function
3ba0: 28 72 65 71 75 65 73 74 29 20 7b 0a 09 09 63 61  (request) {...ca
3bb0: 63 6b 65 79 53 53 48 41 67 65 6e 74 48 61 6e 64  ckeySSHAgentHand
3bc0: 6c 65 4d 65 73 73 61 67 65 28 73 6f 63 6b 65 74  leMessage(socket
3bd0: 2c 20 72 65 71 75 65 73 74 29 3b 0a 09 7d 29 3b  , request);..});
3be0: 0a 7d 0a 0a 66 75 6e 63 74 69 6f 6e 20 63 61 63  .}..function cac
3bf0: 6b 65 79 53 53 48 41 67 65 6e 74 49 6e 69 74 28  keySSHAgentInit(
3c00: 29 20 7b 0a 09 63 68 72 6f 6d 65 2e 72 75 6e 74  ) {..chrome.runt
3c10: 69 6d 65 2e 6f 6e 43 6f 6e 6e 65 63 74 45 78 74  ime.onConnectExt
3c20: 65 72 6e 61 6c 2e 61 64 64 4c 69 73 74 65 6e 65  ernal.addListene
3c30: 72 28 63 61 63 6b 65 79 53 53 48 41 67 65 6e 74  r(cackeySSHAgent
3c40: 41 63 63 65 70 74 43 6f 6e 6e 65 63 74 69 6f 6e  AcceptConnection
3c50: 29 3b 0a 7d 0a 0a 66 75 6e 63 74 69 6f 6e 20 63  );.}..function c
3c60: 61 63 6b 65 79 53 53 48 41 67 65 6e 74 55 6e 69  ackeySSHAgentUni
3c70: 6e 69 74 28 29 20 7b 0a 09 63 68 72 6f 6d 65 2e  nit() {..chrome.
3c80: 72 75 6e 74 69 6d 65 2e 6f 6e 43 6f 6e 6e 65 63  runtime.onConnec
3c90: 74 45 78 74 65 72 6e 61 6c 2e 72 65 6d 6f 76 65  tExternal.remove
3ca0: 4c 69 73 74 65 6e 65 72 28 63 61 63 6b 65 79 53  Listener(cackeyS
3cb0: 53 48 41 67 65 6e 74 41 63 63 65 70 74 43 6f 6e  SHAgentAcceptCon
3cc0: 6e 65 63 74 69 6f 6e 29 3b 0a 7d 0a 0a 63 61 63  nection);.}..cac
3cd0: 6b 65 79 53 53 48 41 67 65 6e 74 43 6f 6d 6d 61  keySSHAgentComma
3ce0: 6e 64 73 20 3d 20 5b 0a 09 7b 20 2f 2a 20 30 3a  nds = [..{ /* 0:
3cf0: 20 4e 6f 74 20 69 6d 70 6c 65 6d 65 6e 74 65 64   Not implemented
3d00: 20 2a 2f 20 7d 2c 0a 09 7b 20 2f 2a 20 31 3a 20   */ },..{ /* 1: 
3d10: 4e 6f 74 20 69 6d 70 6c 65 6d 65 6e 74 65 64 20  Not implemented 
3d20: 2a 2f 20 7d 2c 0a 09 7b 20 2f 2a 20 32 3a 20 4e  */ },..{ /* 2: N
3d30: 6f 74 20 69 6d 70 6c 65 6d 65 6e 74 65 64 20 2a  ot implemented *
3d40: 2f 20 7d 2c 0a 09 7b 20 2f 2a 20 33 3a 20 4e 6f  / },..{ /* 3: No
3d50: 74 20 69 6d 70 6c 65 6d 65 6e 74 65 64 20 2a 2f  t implemented */
3d60: 20 7d 2c 0a 09 7b 20 2f 2a 20 34 3a 20 4e 6f 74   },..{ /* 4: Not
3d70: 20 69 6d 70 6c 65 6d 65 6e 74 65 64 20 2a 2f 20   implemented */ 
3d80: 7d 2c 0a 09 7b 20 2f 2a 20 35 3a 20 4e 6f 74 20  },..{ /* 5: Not 
3d90: 69 6d 70 6c 65 6d 65 6e 74 65 64 20 2a 2f 20 7d  implemented */ }
3da0: 2c 0a 09 7b 20 2f 2a 20 36 3a 20 4e 6f 74 20 69  ,..{ /* 6: Not i
3db0: 6d 70 6c 65 6d 65 6e 74 65 64 20 2a 2f 20 7d 2c  mplemented */ },
3dc0: 0a 09 7b 20 2f 2a 20 37 3a 20 4e 6f 74 20 69 6d  ..{ /* 7: Not im
3dd0: 70 6c 65 6d 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a  plemented */ },.
3de0: 09 7b 20 2f 2a 20 38 3a 20 4e 6f 74 20 69 6d 70  .{ /* 8: Not imp
3df0: 6c 65 6d 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09  lemented */ },..
3e00: 7b 20 2f 2a 20 39 3a 20 4e 6f 74 20 69 6d 70 6c  { /* 9: Not impl
3e10: 65 6d 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09 7b  emented */ },..{
3e20: 20 2f 2a 20 31 30 3a 20 4e 6f 74 20 69 6d 70 6c   /* 10: Not impl
3e30: 65 6d 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09 7b  emented */ },..{
3e40: 0a 09 09 6e 61 6d 65 3a 20 22 72 65 71 75 65 73  ...name: "reques
3e50: 74 49 64 65 6e 74 69 74 69 65 73 22 2c 0a 09 09  tIdentities",...
3e60: 68 61 6e 64 6c 65 72 3a 20 63 61 63 6b 65 79 53  handler: cackeyS
3e70: 53 48 41 67 65 6e 74 43 6f 6d 6d 61 6e 64 52 65  SHAgentCommandRe
3e80: 71 75 65 73 74 49 64 65 6e 74 69 74 79 0a 09 7d  questIdentity..}
3e90: 2c 0a 09 7b 20 2f 2a 20 31 32 3a 20 4e 6f 74 20  ,..{ /* 12: Not 
3ea0: 69 6d 70 6c 65 6d 65 6e 74 65 64 20 2a 2f 20 7d  implemented */ }
3eb0: 2c 0a 09 7b 0a 09 09 6e 61 6d 65 3a 20 22 73 69  ,..{...name: "si
3ec0: 67 6e 52 65 71 75 65 73 74 22 2c 0a 09 09 68 61  gnRequest",...ha
3ed0: 6e 64 6c 65 72 3a 20 63 61 63 6b 65 79 53 53 48  ndler: cackeySSH
3ee0: 41 67 65 6e 74 43 6f 6d 6d 61 6e 64 53 69 67 6e  AgentCommandSign
3ef0: 52 65 71 75 65 73 74 0a 09 7d 2c 0a 09 7b 20 2f  Request..},..{ /
3f00: 2a 20 31 34 3a 20 4e 6f 74 20 69 6d 70 6c 65 6d  * 14: Not implem
3f10: 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09 7b 20 2f  ented */ },..{ /
3f20: 2a 20 31 35 3a 20 4e 6f 74 20 69 6d 70 6c 65 6d  * 15: Not implem
3f30: 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09 7b 20 2f  ented */ },..{ /
3f40: 2a 20 31 36 3a 20 4e 6f 74 20 69 6d 70 6c 65 6d  * 16: Not implem
3f50: 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09 7b 20 2f  ented */ },..{ /
3f60: 2a 20 31 37 3a 20 4e 6f 74 20 69 6d 70 6c 65 6d  * 17: Not implem
3f70: 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09 7b 20 2f  ented */ },..{ /
3f80: 2a 20 31 38 3a 20 4e 6f 74 20 69 6d 70 6c 65 6d  * 18: Not implem
3f90: 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09 7b 20 2f  ented */ },..{ /
3fa0: 2a 20 31 39 3a 20 4e 6f 74 20 69 6d 70 6c 65 6d  * 19: Not implem
3fb0: 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09 7b 20 2f  ented */ },..{ /
3fc0: 2a 20 32 30 3a 20 4e 6f 74 20 69 6d 70 6c 65 6d  * 20: Not implem
3fd0: 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09 7b 20 2f  ented */ },..{ /
3fe0: 2a 20 32 31 3a 20 4e 6f 74 20 69 6d 70 6c 65 6d  * 21: Not implem
3ff0: 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09 7b 20 2f  ented */ },..{ /
4000: 2a 20 32 32 3a 20 4e 6f 74 20 69 6d 70 6c 65 6d  * 22: Not implem
4010: 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09 7b 20 2f  ented */ },..{ /
4020: 2a 20 32 33 3a 20 4e 6f 74 20 69 6d 70 6c 65 6d  * 23: Not implem
4030: 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09 7b 20 2f  ented */ },..{ /
4040: 2a 20 32 34 3a 20 4e 6f 74 20 69 6d 70 6c 65 6d  * 24: Not implem
4050: 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09 7b 20 2f  ented */ },..{ /
4060: 2a 20 32 35 3a 20 4e 6f 74 20 69 6d 70 6c 65 6d  * 25: Not implem
4070: 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09 7b 20 2f  ented */ },..{ /
4080: 2a 20 32 36 3a 20 4e 6f 74 20 69 6d 70 6c 65 6d  * 26: Not implem
4090: 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09 7b 20 2f  ented */ },..{ /
40a0: 2a 20 32 37 3a 20 4e 6f 74 20 69 6d 70 6c 65 6d  * 27: Not implem
40b0: 65 6e 74 65 64 20 2a 2f 20 7d 2c 0a 09 7b 20 2f  ented */ },..{ /
40c0: 2a 20 32 38 3a 20 4e 6f 74 20 69 6d 70 6c 65 6d  * 28: Not implem
40d0: 65 6e 74 65 64 20 2a 2f 20 7d 0a 5d 3b 0a 0a 63  ented */ }.];..c
40e0: 61 63 6b 65 79 53 53 48 41 67 65 6e 74 4d 65 73  ackeySSHAgentMes
40f0: 73 61 67 65 20 3d 20 7b 0a 09 53 53 48 5f 41 47  sage = {..SSH_AG
4100: 45 4e 54 5f 46 41 49 4c 55 52 45 3a 20 35 2c 0a  ENT_FAILURE: 5,.
4110: 09 53 53 48 5f 41 47 45 4e 54 5f 53 55 43 43 45  .SSH_AGENT_SUCCE
4120: 53 53 3a 20 36 2c 0a 09 53 53 48 5f 41 47 45 4e  SS: 6,..SSH_AGEN
4130: 54 5f 45 58 54 45 4e 53 49 4f 4e 5f 46 41 49 4c  T_EXTENSION_FAIL
4140: 55 52 45 3a 20 32 38 2c 0a 09 53 53 48 5f 41 47  URE: 28,..SSH_AG
4150: 45 4e 54 5f 49 44 45 4e 54 49 54 49 45 53 5f 41  ENT_IDENTITIES_A
4160: 4e 53 57 45 52 3a 20 31 32 2c 0a 09 53 53 48 5f  NSWER: 12,..SSH_
4170: 41 47 45 4e 54 5f 53 49 47 4e 5f 52 45 53 50 4f  AGENT_SIGN_RESPO
4180: 4e 53 45 3a 20 31 34 0a 7d 3b 0a 0a 63 61 63 6b  NSE: 14.};..cack
4190: 65 79 53 53 48 41 67 65 6e 74 49 6e 69 74 28 29  eySSHAgentInit()
41a0: 3b 0a                                            ;.