0000: 2f 2a 0a 20 2a 20 47 6f 6f 67 6c 65 27 73 20 50 /*. * Google's P
0010: 43 53 43 20 6c 69 62 72 61 72 79 20 72 65 71 75 CSC library requ
0020: 69 72 65 73 20 75 73 20 74 6f 20 77 72 69 74 65 ires us to write
0030: 20 6f 75 72 20 6d 6f 64 75 6c 65 20 69 6e 20 43 our module in C
0040: 2b 2b 20 74 6f 20 69 6e 69 74 69 61 6c 69 7a 65 ++ to initialize
0050: 0a 20 2a 20 69 74 2e 20 20 54 68 69 73 20 63 6f . * it. This co
0060: 6d 70 6f 6e 65 6e 74 20 68 61 6e 64 6c 65 73 20 mponent handles
0070: 74 68 65 20 69 6e 69 74 69 61 6c 69 7a 61 74 69 the initializati
0080: 6f 6e 20 6f 66 20 6f 75 72 20 6d 6f 64 75 6c 65 on of our module
0090: 20 61 6e 64 20 68 61 6e 64 6c 65 73 0a 20 2a 20 and handles. *
00a0: 69 6e 63 6f 6d 69 6e 67 20 6d 65 73 73 61 67 65 incoming message
00b0: 73 2c 20 70 61 73 73 69 6e 67 20 74 68 65 6d 20 s, passing them
00c0: 65 69 74 68 65 72 20 74 6f 20 6f 75 72 20 6c 69 either to our li
00d0: 62 72 61 72 79 20 28 63 61 63 6b 65 79 2d 63 68 brary (cackey-ch
00e0: 72 6f 6d 65 29 20 6f 72 0a 20 2a 20 74 6f 20 74 rome) or. * to t
00f0: 68 65 20 50 43 53 43 2d 4e 61 43 6c 20 6c 69 62 he PCSC-NaCl lib
0100: 72 61 72 79 20 66 72 6f 6d 20 47 6f 6f 67 6c 65 rary from Google
0110: 20 61 73 20 61 70 70 72 6f 70 72 69 61 74 65 2e as appropriate.
0120: 0a 20 2a 2f 0a 0a 23 69 6e 63 6c 75 64 65 20 3c . */..#include <
0130: 74 68 72 65 61 64 3e 0a 23 69 6e 63 6c 75 64 65 thread>.#include
0140: 20 3c 70 70 61 70 69 2f 63 70 70 2f 69 6e 73 74 <ppapi/cpp/inst
0150: 61 6e 63 65 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 ance.h>.#include
0160: 20 3c 70 70 61 70 69 2f 63 70 70 2f 6d 6f 64 75 <ppapi/cpp/modu
0170: 6c 65 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c le.h>.#include <
0180: 70 70 61 70 69 2f 63 70 70 2f 63 6f 72 65 2e 68 ppapi/cpp/core.h
0190: 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 70 70 61 70 >.#include <ppap
01a0: 69 2f 63 70 70 2f 76 61 72 2e 68 3e 0a 23 69 6e i/cpp/var.h>.#in
01b0: 63 6c 75 64 65 20 3c 70 70 61 70 69 2f 63 70 70 clude <ppapi/cpp
01c0: 2f 76 61 72 5f 64 69 63 74 69 6f 6e 61 72 79 2e /var_dictionary.
01d0: 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 70 70 61 h>.#include <ppa
01e0: 70 69 2f 63 70 70 2f 76 61 72 5f 61 72 72 61 79 pi/cpp/var_array
01f0: 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 70 70 .h>.#include <pp
0200: 61 70 69 2f 63 70 70 2f 76 61 72 5f 61 72 72 61 api/cpp/var_arra
0210: 79 5f 62 75 66 66 65 72 2e 68 3e 0a 0a 23 69 6e y_buffer.h>..#in
0220: 63 6c 75 64 65 20 22 70 63 73 63 2d 6e 61 63 6c clude "pcsc-nacl
0230: 2e 68 22 0a 23 69 6e 63 6c 75 64 65 20 22 63 61 .h".#include "ca
0240: 63 6b 65 79 2d 63 68 72 6f 6d 65 2e 68 22 0a 0a ckey-chrome.h"..
0250: 63 6c 61 73 73 20 43 41 43 4b 65 79 49 6e 73 74 class CACKeyInst
0260: 61 6e 63 65 20 3a 20 70 75 62 6c 69 63 20 70 70 ance : public pp
0270: 3a 3a 49 6e 73 74 61 6e 63 65 20 7b 0a 09 70 72 ::Instance {..pr
0280: 69 76 61 74 65 3a 0a 09 09 76 6f 69 64 20 70 63 ivate:...void pc
0290: 73 63 4e 61 43 6c 49 6e 69 74 57 72 61 70 70 65 scNaClInitWrappe
02a0: 72 28 70 70 3a 3a 43 6f 72 65 20 2a 63 6f 72 65 r(pp::Core *core
02b0: 29 20 7b 0a 09 09 09 70 63 73 63 4e 61 43 6c 49 ) {....pcscNaClI
02c0: 6e 69 74 28 74 68 69 73 2c 20 63 6f 72 65 29 3b nit(this, core);
02d0: 0a 09 09 7d 0a 09 70 75 62 6c 69 63 3a 0a 09 09 ...}..public:...
02e0: 65 78 70 6c 69 63 69 74 20 43 41 43 4b 65 79 49 explicit CACKeyI
02f0: 6e 73 74 61 6e 63 65 28 50 50 5f 49 6e 73 74 61 nstance(PP_Insta
0300: 6e 63 65 20 69 6e 73 74 61 6e 63 65 2c 20 70 70 nce instance, pp
0310: 3a 3a 43 6f 72 65 20 2a 63 6f 72 65 29 20 3a 20 ::Core *core) :
0320: 70 70 3a 3a 49 6e 73 74 61 6e 63 65 28 69 6e 73 pp::Instance(ins
0330: 74 61 6e 63 65 29 20 7b 0a 09 09 09 73 74 64 3a tance) {....std:
0340: 3a 74 68 72 65 61 64 28 26 43 41 43 4b 65 79 49 :thread(&CACKeyI
0350: 6e 73 74 61 6e 63 65 3a 3a 70 63 73 63 4e 61 43 nstance::pcscNaC
0360: 6c 49 6e 69 74 57 72 61 70 70 65 72 2c 20 74 68 lInitWrapper, th
0370: 69 73 2c 20 63 6f 72 65 29 2e 64 65 74 61 63 68 is, core).detach
0380: 28 29 3b 0a 09 09 7d 0a 0a 09 09 76 69 72 74 75 ();...}....virtu
0390: 61 6c 20 7e 43 41 43 4b 65 79 49 6e 73 74 61 6e al ~CACKeyInstan
03a0: 63 65 28 29 20 7b 7d 0a 0a 09 09 76 69 72 74 75 ce() {}....virtu
03b0: 61 6c 20 76 6f 69 64 20 48 61 6e 64 6c 65 4d 65 al void HandleMe
03c0: 73 73 61 67 65 54 68 72 65 61 64 28 70 70 3a 3a ssageThread(pp::
03d0: 56 61 72 44 69 63 74 69 6f 6e 61 72 79 20 2a 6d VarDictionary *m
03e0: 65 73 73 61 67 65 29 20 7b 0a 09 09 09 63 61 63 essage) {....cac
03f0: 6b 65 79 5f 63 68 72 6f 6d 65 5f 72 65 74 75 72 key_chrome_retur
0400: 6e 54 79 70 65 20 73 69 67 6e 52 65 74 3b 0a 09 nType signRet;..
0410: 09 09 63 68 61 72 20 2a 70 69 6e 50 72 6f 6d 70 ..char *pinPromp
0420: 74 3b 0a 09 09 09 63 6f 6e 73 74 20 63 68 61 72 t;....const char
0430: 20 2a 70 69 6e 3b 0a 09 09 09 75 6e 73 69 67 6e *pin;....unsign
0440: 65 64 20 63 68 61 72 20 62 75 66 66 65 72 5b 38 ed char buffer[8
0450: 31 39 32 5d 3b 0a 09 09 09 73 74 72 75 63 74 20 192];....struct
0460: 63 61 63 6b 65 79 5f 63 65 72 74 69 66 69 63 61 cackey_certifica
0470: 74 65 20 2a 63 65 72 74 69 66 69 63 61 74 65 73 te *certificates
0480: 2c 20 69 6e 63 6f 6d 69 6e 67 43 65 72 74 69 66 , incomingCertif
0490: 69 63 61 74 65 43 41 43 4b 65 79 3b 0a 09 09 09 icateCACKey;....
04a0: 70 70 3a 3a 56 61 72 44 69 63 74 69 6f 6e 61 72 pp::VarDictionar
04b0: 79 20 2a 72 65 70 6c 79 3b 0a 09 09 09 70 70 3a y *reply;....pp:
04c0: 3a 56 61 72 41 72 72 61 79 20 63 65 72 74 69 66 :VarArray certif
04d0: 69 63 61 74 65 73 50 50 41 72 72 61 79 3b 0a 09 icatesPPArray;..
04e0: 09 09 70 70 3a 3a 56 61 72 41 72 72 61 79 42 75 ..pp::VarArrayBu
04f0: 66 66 65 72 20 2a 63 65 72 74 69 66 69 63 61 74 ffer *certificat
0500: 65 43 6f 6e 74 65 6e 74 73 2c 20 2a 69 6e 63 6f eContents, *inco
0510: 6d 69 6e 67 43 65 72 74 69 66 69 63 61 74 65 43 mingCertificateC
0520: 6f 6e 74 65 6e 74 73 2c 20 2a 69 6e 63 6f 6d 69 ontents, *incomi
0530: 6e 67 44 61 74 61 2c 20 2a 6f 75 74 67 6f 69 6e ngData, *outgoin
0540: 67 44 61 74 61 3b 0a 09 09 09 70 70 3a 3a 56 61 gData;....pp::Va
0550: 72 20 63 6f 6d 6d 61 6e 64 3b 0a 09 09 09 63 6f r command;....co
0560: 6e 73 74 20 70 70 3a 3a 56 61 72 20 2a 6d 65 73 nst pp::Var *mes
0570: 73 61 67 65 41 73 56 61 72 20 3d 20 4e 55 4c 4c sageAsVar = NULL
0580: 2c 20 2a 6f 75 74 67 6f 69 6e 67 44 61 74 61 41 , *outgoingDataA
0590: 73 56 61 72 20 3d 20 4e 55 4c 4c 3b 0a 09 09 09 sVar = NULL;....
05a0: 69 6e 74 20 6e 75 6d 43 65 72 74 69 66 69 63 61 int numCertifica
05b0: 74 65 73 2c 20 69 3b 0a 09 09 09 75 6e 73 69 67 tes, i;....unsig
05c0: 6e 65 64 20 6c 6f 6e 67 20 6f 75 74 67 6f 69 6e ned long outgoin
05d0: 67 44 61 74 61 4c 65 6e 67 74 68 3b 0a 0a 09 09 gDataLength;....
05e0: 09 2f 2a 0a 09 09 09 20 2a 20 45 78 74 72 61 63 ./*.... * Extrac
05f0: 74 20 74 68 65 20 63 6f 6d 6d 61 6e 64 0a 09 09 t the command...
0600: 09 20 2a 2f 0a 09 09 09 63 6f 6d 6d 61 6e 64 20 . */....command
0610: 3d 20 6d 65 73 73 61 67 65 2d 3e 47 65 74 28 22 = message->Get("
0620: 63 6f 6d 6d 61 6e 64 22 29 3b 0a 0a 09 09 09 2f command");...../
0630: 2a 0a 09 09 09 20 2a 20 44 6f 20 74 68 65 20 74 *.... * Do the t
0640: 68 69 6e 67 20 77 65 20 61 72 65 20 62 65 69 6e hing we are bein
0650: 67 20 61 73 6b 65 64 20 74 6f 20 64 6f 0a 09 09 g asked to do...
0660: 09 20 2a 2f 0a 09 09 09 72 65 70 6c 79 20 3d 20 . */....reply =
0670: 6e 65 77 20 70 70 3a 3a 56 61 72 44 69 63 74 69 new pp::VarDicti
0680: 6f 6e 61 72 79 28 29 3b 0a 0a 09 09 09 69 66 20 onary();.....if
0690: 28 63 6f 6d 6d 61 6e 64 2e 41 73 53 74 72 69 6e (command.AsStrin
06a0: 67 28 29 20 3d 3d 20 22 6c 69 73 74 63 65 72 74 g() == "listcert
06b0: 69 66 69 63 61 74 65 73 22 29 20 7b 0a 09 09 09 ificates") {....
06c0: 09 6e 75 6d 43 65 72 74 69 66 69 63 61 74 65 73 .numCertificates
06d0: 20 3d 20 63 61 63 6b 65 79 5f 63 68 72 6f 6d 65 = cackey_chrome
06e0: 5f 6c 69 73 74 43 65 72 74 69 66 69 63 61 74 65 _listCertificate
06f0: 73 28 26 63 65 72 74 69 66 69 63 61 74 65 73 29 s(&certificates)
0700: 3b 0a 0a 09 09 09 09 63 65 72 74 69 66 69 63 61 ;......certifica
0710: 74 65 73 50 50 41 72 72 61 79 2e 53 65 74 4c 65 tesPPArray.SetLe
0720: 6e 67 74 68 28 6e 75 6d 43 65 72 74 69 66 69 63 ngth(numCertific
0730: 61 74 65 73 29 3b 0a 0a 09 09 09 09 66 6f 72 20 ates);......for
0740: 28 69 20 3d 20 30 3b 20 69 20 3c 20 6e 75 6d 43 (i = 0; i < numC
0750: 65 72 74 69 66 69 63 61 74 65 73 3b 20 69 2b 2b ertificates; i++
0760: 29 20 7b 0a 09 09 09 09 09 63 65 72 74 69 66 69 ) {......certifi
0770: 63 61 74 65 43 6f 6e 74 65 6e 74 73 20 3d 20 6e cateContents = n
0780: 65 77 20 70 70 3a 3a 56 61 72 41 72 72 61 79 42 ew pp::VarArrayB
0790: 75 66 66 65 72 28 63 65 72 74 69 66 69 63 61 74 uffer(certificat
07a0: 65 73 5b 69 5d 2e 63 65 72 74 69 66 69 63 61 74 es[i].certificat
07b0: 65 5f 6c 65 6e 29 3b 0a 0a 09 09 09 09 09 6d 65 e_len);.......me
07c0: 6d 63 70 79 28 63 65 72 74 69 66 69 63 61 74 65 mcpy(certificate
07d0: 43 6f 6e 74 65 6e 74 73 2d 3e 4d 61 70 28 29 2c Contents->Map(),
07e0: 20 63 65 72 74 69 66 69 63 61 74 65 73 5b 69 5d certificates[i]
07f0: 2e 63 65 72 74 69 66 69 63 61 74 65 2c 20 63 65 .certificate, ce
0800: 72 74 69 66 69 63 61 74 65 73 5b 69 5d 2e 63 65 rtificates[i].ce
0810: 72 74 69 66 69 63 61 74 65 5f 6c 65 6e 29 3b 0a rtificate_len);.
0820: 0a 09 09 09 09 09 63 65 72 74 69 66 69 63 61 74 ......certificat
0830: 65 43 6f 6e 74 65 6e 74 73 2d 3e 55 6e 6d 61 70 eContents->Unmap
0840: 28 29 3b 0a 0a 09 09 09 09 09 63 65 72 74 69 66 ();.......certif
0850: 69 63 61 74 65 73 50 50 41 72 72 61 79 2e 53 65 icatesPPArray.Se
0860: 74 28 69 2c 20 2a 63 65 72 74 69 66 69 63 61 74 t(i, *certificat
0870: 65 43 6f 6e 74 65 6e 74 73 29 3b 0a 0a 09 09 09 eContents);.....
0880: 09 09 64 65 6c 65 74 65 20 63 65 72 74 69 66 69 ..delete certifi
0890: 63 61 74 65 43 6f 6e 74 65 6e 74 73 3b 0a 09 09 cateContents;...
08a0: 09 09 7d 0a 0a 09 09 09 09 63 61 63 6b 65 79 5f ..}......cackey_
08b0: 63 68 72 6f 6d 65 5f 66 72 65 65 43 65 72 74 69 chrome_freeCerti
08c0: 66 69 63 61 74 65 73 28 63 65 72 74 69 66 69 63 ficates(certific
08d0: 61 74 65 73 2c 20 6e 75 6d 43 65 72 74 69 66 69 ates, numCertifi
08e0: 63 61 74 65 73 29 3b 0a 0a 09 09 09 09 72 65 70 cates);......rep
08f0: 6c 79 2d 3e 53 65 74 28 22 73 74 61 74 75 73 22 ly->Set("status"
0900: 2c 20 22 73 75 63 63 65 73 73 22 29 3b 0a 09 09 , "success");...
0910: 09 09 72 65 70 6c 79 2d 3e 53 65 74 28 22 63 65 ..reply->Set("ce
0920: 72 74 69 66 69 63 61 74 65 73 22 2c 20 63 65 72 rtificates", cer
0930: 74 69 66 69 63 61 74 65 73 50 50 41 72 72 61 79 tificatesPPArray
0940: 29 3b 0a 09 09 09 7d 20 65 6c 73 65 20 69 66 20 );....} else if
0950: 28 63 6f 6d 6d 61 6e 64 2e 41 73 53 74 72 69 6e (command.AsStrin
0960: 67 28 29 20 3d 3d 20 22 73 69 67 6e 22 29 20 7b g() == "sign") {
0970: 0a 09 09 09 09 69 66 20 28 21 6d 65 73 73 61 67 .....if (!messag
0980: 65 2d 3e 48 61 73 4b 65 79 28 22 63 65 72 74 69 e->HasKey("certi
0990: 66 69 63 61 74 65 22 29 29 20 7b 0a 09 09 09 09 ficate")) {.....
09a0: 09 72 65 70 6c 79 2d 3e 53 65 74 28 22 73 74 61 .reply->Set("sta
09b0: 74 75 73 22 2c 20 22 65 72 72 6f 72 22 29 3b 0a tus", "error");.
09c0: 09 09 09 09 09 72 65 70 6c 79 2d 3e 53 65 74 28 .....reply->Set(
09d0: 22 65 72 72 6f 72 22 2c 20 22 43 65 72 74 69 66 "error", "Certif
09e0: 69 63 61 74 65 20 6e 6f 74 20 73 75 70 70 6c 69 icate not suppli
09f0: 65 64 22 29 3b 0a 09 09 09 09 7d 20 65 6c 73 65 ed");.....} else
0a00: 20 69 66 20 28 21 6d 65 73 73 61 67 65 2d 3e 48 if (!message->H
0a10: 61 73 4b 65 79 28 22 64 61 74 61 22 29 29 20 7b asKey("data")) {
0a20: 0a 09 09 09 09 09 72 65 70 6c 79 2d 3e 53 65 74 ......reply->Set
0a30: 28 22 73 74 61 74 75 73 22 2c 20 22 65 72 72 6f ("status", "erro
0a40: 72 22 29 3b 0a 09 09 09 09 09 72 65 70 6c 79 2d r");......reply-
0a50: 3e 53 65 74 28 22 65 72 72 6f 72 22 2c 20 22 44 >Set("error", "D
0a60: 61 74 61 20 6e 6f 74 20 73 75 70 70 6c 69 65 64 ata not supplied
0a70: 22 29 3b 0a 09 09 09 09 7d 20 65 6c 73 65 20 7b ");.....} else {
0a80: 0a 09 09 09 09 09 69 6e 63 6f 6d 69 6e 67 43 65 ......incomingCe
0a90: 72 74 69 66 69 63 61 74 65 43 6f 6e 74 65 6e 74 rtificateContent
0aa0: 73 20 3d 20 6e 65 77 20 70 70 3a 3a 56 61 72 41 s = new pp::VarA
0ab0: 72 72 61 79 42 75 66 66 65 72 28 6d 65 73 73 61 rrayBuffer(messa
0ac0: 67 65 2d 3e 47 65 74 28 22 63 65 72 74 69 66 69 ge->Get("certifi
0ad0: 63 61 74 65 22 29 29 3b 0a 09 09 09 09 09 69 6e cate"));......in
0ae0: 63 6f 6d 69 6e 67 44 61 74 61 20 3d 20 6e 65 77 comingData = new
0af0: 20 70 70 3a 3a 56 61 72 41 72 72 61 79 42 75 66 pp::VarArrayBuf
0b00: 66 65 72 28 6d 65 73 73 61 67 65 2d 3e 47 65 74 fer(message->Get
0b10: 28 22 64 61 74 61 22 29 29 3b 0a 0a 09 09 09 09 ("data"));......
0b20: 09 69 66 20 28 6d 65 73 73 61 67 65 2d 3e 48 61 .if (message->Ha
0b30: 73 4b 65 79 28 22 70 69 6e 22 29 29 20 7b 0a 09 sKey("pin")) {..
0b40: 09 09 09 09 09 70 69 6e 20 3d 20 6d 65 73 73 61 .....pin = messa
0b50: 67 65 2d 3e 47 65 74 28 22 70 69 6e 22 29 2e 41 ge->Get("pin").A
0b60: 73 53 74 72 69 6e 67 28 29 2e 63 5f 73 74 72 28 sString().c_str(
0b70: 29 3b 0a 09 09 09 09 09 7d 20 65 6c 73 65 20 7b );......} else {
0b80: 0a 09 09 09 09 09 09 70 69 6e 20 3d 20 4e 55 4c .......pin = NUL
0b90: 4c 3b 0a 09 09 09 09 09 7d 0a 0a 09 09 09 09 09 L;......}.......
0ba0: 69 6e 63 6f 6d 69 6e 67 43 65 72 74 69 66 69 63 incomingCertific
0bb0: 61 74 65 43 41 43 4b 65 79 2e 63 65 72 74 69 66 ateCACKey.certif
0bc0: 69 63 61 74 65 20 3d 20 69 6e 63 6f 6d 69 6e 67 icate = incoming
0bd0: 43 65 72 74 69 66 69 63 61 74 65 43 6f 6e 74 65 CertificateConte
0be0: 6e 74 73 2d 3e 4d 61 70 28 29 3b 09 09 09 09 09 nts->Map();.....
0bf0: 0a 09 09 09 09 09 69 6e 63 6f 6d 69 6e 67 43 65 ......incomingCe
0c00: 72 74 69 66 69 63 61 74 65 43 41 43 4b 65 79 2e rtificateCACKey.
0c10: 63 65 72 74 69 66 69 63 61 74 65 5f 6c 65 6e 20 certificate_len
0c20: 3d 20 69 6e 63 6f 6d 69 6e 67 43 65 72 74 69 66 = incomingCertif
0c30: 69 63 61 74 65 43 6f 6e 74 65 6e 74 73 2d 3e 42 icateContents->B
0c40: 79 74 65 4c 65 6e 67 74 68 28 29 3b 09 09 09 09 yteLength();....
0c50: 09 0a 0a 09 09 09 09 09 6f 75 74 67 6f 69 6e 67 ........outgoing
0c60: 44 61 74 61 4c 65 6e 67 74 68 20 3d 20 73 69 7a DataLength = siz
0c70: 65 6f 66 28 62 75 66 66 65 72 29 3b 0a 0a 09 09 eof(buffer);....
0c80: 09 09 09 73 69 67 6e 52 65 74 20 3d 20 63 61 63 ...signRet = cac
0c90: 6b 65 79 5f 63 68 72 6f 6d 65 5f 73 69 67 6e 4d key_chrome_signM
0ca0: 65 73 73 61 67 65 28 26 69 6e 63 6f 6d 69 6e 67 essage(&incoming
0cb0: 43 65 72 74 69 66 69 63 61 74 65 43 41 43 4b 65 CertificateCACKe
0cc0: 79 2c 0a 09 09 09 09 09 09 69 6e 63 6f 6d 69 6e y,.......incomin
0cd0: 67 44 61 74 61 2d 3e 4d 61 70 28 29 2c 20 69 6e gData->Map(), in
0ce0: 63 6f 6d 69 6e 67 44 61 74 61 2d 3e 42 79 74 65 comingData->Byte
0cf0: 4c 65 6e 67 74 68 28 29 2c 0a 09 09 09 09 09 09 Length(),.......
0d00: 62 75 66 66 65 72 2c 20 26 6f 75 74 67 6f 69 6e buffer, &outgoin
0d10: 67 44 61 74 61 4c 65 6e 67 74 68 2c 0a 09 09 09 gDataLength,....
0d20: 09 09 09 26 70 69 6e 50 72 6f 6d 70 74 2c 20 70 ...&pinPrompt, p
0d30: 69 6e 0a 09 09 09 09 09 29 3b 0a 0a 09 09 09 09 in......);......
0d40: 09 69 6e 63 6f 6d 69 6e 67 43 65 72 74 69 66 69 .incomingCertifi
0d50: 63 61 74 65 43 6f 6e 74 65 6e 74 73 2d 3e 55 6e cateContents->Un
0d60: 6d 61 70 28 29 3b 0a 09 09 09 09 09 69 6e 63 6f map();......inco
0d70: 6d 69 6e 67 44 61 74 61 2d 3e 55 6e 6d 61 70 28 mingData->Unmap(
0d80: 29 3b 0a 0a 09 09 09 09 09 64 65 6c 65 74 65 20 );.......delete
0d90: 69 6e 63 6f 6d 69 6e 67 43 65 72 74 69 66 69 63 incomingCertific
0da0: 61 74 65 43 6f 6e 74 65 6e 74 73 3b 0a 09 09 09 ateContents;....
0db0: 09 09 64 65 6c 65 74 65 20 69 6e 63 6f 6d 69 6e ..delete incomin
0dc0: 67 44 61 74 61 3b 0a 0a 09 09 09 09 09 73 77 69 gData;.......swi
0dd0: 74 63 68 20 28 73 69 67 6e 52 65 74 29 20 7b 0a tch (signRet) {.
0de0: 09 09 09 09 09 09 63 61 73 65 20 43 41 43 4b 45 ......case CACKE
0df0: 59 5f 43 48 52 4f 4d 45 5f 4f 4b 3a 0a 09 09 09 Y_CHROME_OK:....
0e00: 09 09 09 09 6f 75 74 67 6f 69 6e 67 44 61 74 61 ....outgoingData
0e10: 20 3d 20 6e 65 77 20 70 70 3a 3a 56 61 72 41 72 = new pp::VarAr
0e20: 72 61 79 42 75 66 66 65 72 28 6f 75 74 67 6f 69 rayBuffer(outgoi
0e30: 6e 67 44 61 74 61 4c 65 6e 67 74 68 29 3b 0a 0a ngDataLength);..
0e40: 09 09 09 09 09 09 09 6d 65 6d 63 70 79 28 6f 75 .......memcpy(ou
0e50: 74 67 6f 69 6e 67 44 61 74 61 2d 3e 4d 61 70 28 tgoingData->Map(
0e60: 29 2c 20 62 75 66 66 65 72 2c 20 6f 75 74 67 6f ), buffer, outgo
0e70: 69 6e 67 44 61 74 61 4c 65 6e 67 74 68 29 3b 0a ingDataLength);.
0e80: 0a 09 09 09 09 09 09 09 6f 75 74 67 6f 69 6e 67 ........outgoing
0e90: 44 61 74 61 2d 3e 55 6e 6d 61 70 28 29 3b 0a 0a Data->Unmap();..
0ea0: 09 09 09 09 09 09 09 6f 75 74 67 6f 69 6e 67 44 .......outgoingD
0eb0: 61 74 61 41 73 56 61 72 20 3d 20 6e 65 77 20 70 ataAsVar = new p
0ec0: 70 3a 3a 56 61 72 28 6f 75 74 67 6f 69 6e 67 44 p::Var(outgoingD
0ed0: 61 74 61 2d 3e 70 70 5f 76 61 72 28 29 29 3b 0a ata->pp_var());.
0ee0: 0a 09 09 09 09 09 09 09 64 65 6c 65 74 65 20 6f ........delete o
0ef0: 75 74 67 6f 69 6e 67 44 61 74 61 3b 0a 0a 09 09 utgoingData;....
0f00: 09 09 09 09 09 72 65 70 6c 79 2d 3e 53 65 74 28 .....reply->Set(
0f10: 22 73 74 61 74 75 73 22 2c 20 22 73 75 63 63 65 "status", "succe
0f20: 73 73 22 29 3b 0a 09 09 09 09 09 09 09 72 65 70 ss");........rep
0f30: 6c 79 2d 3e 53 65 74 28 22 73 69 67 6e 65 64 44 ly->Set("signedD
0f40: 61 74 61 22 2c 20 6f 75 74 67 6f 69 6e 67 44 61 ata", outgoingDa
0f50: 74 61 41 73 56 61 72 29 3b 0a 0a 09 09 09 09 09 taAsVar);.......
0f60: 09 09 64 65 6c 65 74 65 20 6f 75 74 67 6f 69 6e ..delete outgoin
0f70: 67 44 61 74 61 41 73 56 61 72 3b 0a 0a 09 09 09 gDataAsVar;.....
0f80: 09 09 09 09 62 72 65 61 6b 3b 0a 09 09 09 09 09 ....break;......
0f90: 09 63 61 73 65 20 43 41 43 4b 45 59 5f 43 48 52 .case CACKEY_CHR
0fa0: 4f 4d 45 5f 45 52 52 4f 52 3a 0a 09 09 09 09 09 OME_ERROR:......
0fb0: 09 09 72 65 70 6c 79 2d 3e 53 65 74 28 22 73 74 ..reply->Set("st
0fc0: 61 74 75 73 22 2c 20 22 65 72 72 6f 72 22 29 3b atus", "error");
0fd0: 0a 09 09 09 09 09 09 09 72 65 70 6c 79 2d 3e 53 ........reply->S
0fe0: 65 74 28 22 65 72 72 6f 72 22 2c 20 22 55 6e 61 et("error", "Una
0ff0: 62 6c 65 20 74 6f 20 73 69 67 6e 20 64 61 74 61 ble to sign data
1000: 22 29 3b 0a 09 09 09 09 09 09 09 62 72 65 61 6b ");........break
1010: 3b 0a 09 09 09 09 09 09 63 61 73 65 20 43 41 43 ;.......case CAC
1020: 4b 45 59 5f 43 48 52 4f 4d 45 5f 4e 45 45 44 4c KEY_CHROME_NEEDL
1030: 4f 47 49 4e 3a 0a 09 09 09 09 09 09 63 61 73 65 OGIN:.......case
1040: 20 43 41 43 4b 45 59 5f 43 48 52 4f 4d 45 5f 4e CACKEY_CHROME_N
1050: 45 45 44 50 52 4f 54 45 43 54 45 44 4c 4f 47 49 EEDPROTECTEDLOGI
1060: 4e 3a 0a 09 09 09 09 09 09 09 6d 65 73 73 61 67 N:........messag
1070: 65 41 73 56 61 72 20 3d 20 6e 65 77 20 70 70 3a eAsVar = new pp:
1080: 3a 56 61 72 28 6d 65 73 73 61 67 65 2d 3e 70 70 :Var(message->pp
1090: 5f 76 61 72 28 29 29 3b 0a 0a 09 09 09 09 09 09 _var());........
10a0: 09 72 65 70 6c 79 2d 3e 53 65 74 28 22 73 74 61 .reply->Set("sta
10b0: 74 75 73 22 2c 20 22 72 65 74 72 79 22 29 3b 0a tus", "retry");.
10c0: 09 09 09 09 09 09 09 72 65 70 6c 79 2d 3e 53 65 .......reply->Se
10d0: 74 28 22 6f 72 69 67 69 6e 61 6c 72 65 71 75 65 t("originalreque
10e0: 73 74 22 2c 20 6d 65 73 73 61 67 65 41 73 56 61 st", messageAsVa
10f0: 72 29 3b 0a 09 09 09 09 09 09 09 72 65 70 6c 79 r);........reply
1100: 2d 3e 53 65 74 28 22 70 69 6e 70 72 6f 6d 70 74 ->Set("pinprompt
1110: 22 2c 20 70 69 6e 50 72 6f 6d 70 74 29 3b 0a 0a ", pinPrompt);..
1120: 09 09 09 09 09 09 09 64 65 6c 65 74 65 20 6d 65 .......delete me
1130: 73 73 61 67 65 41 73 56 61 72 3b 0a 0a 09 09 09 ssageAsVar;.....
1140: 09 09 09 09 62 72 65 61 6b 3b 0a 09 09 09 09 09 ....break;......
1150: 7d 0a 0a 09 09 09 09 09 69 66 20 28 70 69 6e 50 }.......if (pinP
1160: 72 6f 6d 70 74 20 21 3d 20 4e 55 4c 4c 29 20 7b rompt != NULL) {
1170: 0a 09 09 09 09 09 09 66 72 65 65 28 70 69 6e 50 .......free(pinP
1180: 72 6f 6d 70 74 29 3b 0a 09 09 09 09 09 7d 0a 09 rompt);......}..
1190: 09 09 09 7d 0a 09 09 09 7d 20 65 6c 73 65 20 7b ...}....} else {
11a0: 0a 09 09 09 09 72 65 70 6c 79 2d 3e 53 65 74 28 .....reply->Set(
11b0: 22 73 74 61 74 75 73 22 2c 20 22 65 72 72 6f 72 "status", "error
11c0: 22 29 3b 0a 09 09 09 09 72 65 70 6c 79 2d 3e 53 ");.....reply->S
11d0: 65 74 28 22 65 72 72 6f 72 22 2c 20 22 49 6e 76 et("error", "Inv
11e0: 61 6c 69 64 20 63 6f 6d 6d 61 6e 64 22 29 3b 0a alid command");.
11f0: 09 09 09 7d 0a 0a 09 09 09 2f 2a 0a 09 09 09 20 ...}...../*....
1200: 2a 20 49 66 20 61 20 6d 65 73 73 61 67 65 20 49 * If a message I
1210: 44 20 77 61 73 20 73 65 6e 74 20 69 6e 20 74 68 D was sent in th
1220: 65 20 72 65 71 75 65 73 74 2c 20 69 6e 63 6c 75 e request, inclu
1230: 64 65 20 69 74 20 69 6e 20 74 68 65 20 72 65 70 de it in the rep
1240: 6c 79 0a 09 09 09 20 2a 2f 0a 09 09 09 69 66 20 ly.... */....if
1250: 28 6d 65 73 73 61 67 65 2d 3e 48 61 73 4b 65 79 (message->HasKey
1260: 28 22 69 64 22 29 29 20 7b 0a 09 09 09 09 72 65 ("id")) {.....re
1270: 70 6c 79 2d 3e 53 65 74 28 22 69 64 22 2c 20 6d ply->Set("id", m
1280: 65 73 73 61 67 65 2d 3e 47 65 74 28 22 69 64 22 essage->Get("id"
1290: 29 29 3b 0a 09 09 09 7d 0a 0a 09 09 09 2f 2a 0a ));....}...../*.
12a0: 09 09 09 20 2a 20 49 6e 64 69 63 61 74 65 20 77 ... * Indicate w
12b0: 68 6f 20 6f 75 72 20 6d 65 73 73 61 67 65 20 69 ho our message i
12c0: 73 20 66 6f 72 0a 09 09 09 20 2a 2f 0a 09 09 09 s for.... */....
12d0: 72 65 70 6c 79 2d 3e 53 65 74 28 22 74 61 72 67 reply->Set("targ
12e0: 65 74 22 2c 20 22 63 61 63 6b 65 79 22 29 3b 0a et", "cackey");.
12f0: 09 09 09 72 65 70 6c 79 2d 3e 53 65 74 28 22 63 ...reply->Set("c
1300: 6f 6d 6d 61 6e 64 22 2c 20 63 6f 6d 6d 61 6e 64 ommand", command
1310: 29 3b 0a 0a 09 09 09 2f 2a 0a 09 09 09 20 2a 20 );...../*.... *
1320: 53 65 6e 64 20 74 68 65 20 72 65 70 6c 79 20 62 Send the reply b
1330: 61 63 6b 20 74 6f 20 74 68 65 20 72 65 71 75 65 ack to the reque
1340: 73 74 6f 72 2c 20 68 6f 70 65 66 75 6c 6c 79 20 stor, hopefully
1350: 74 68 65 79 20 61 72 65 20 77 61 69 74 69 6e 67 they are waiting
1360: 20 66 6f 72 20 74 68 69 73 20 6d 65 73 73 61 67 for this messag
1370: 65 0a 09 09 09 20 2a 2f 0a 09 09 09 50 6f 73 74 e.... */....Post
1380: 4d 65 73 73 61 67 65 28 2a 72 65 70 6c 79 29 3b Message(*reply);
1390: 0a 0a 09 09 09 64 65 6c 65 74 65 20 72 65 70 6c .....delete repl
13a0: 79 3b 0a 0a 09 09 09 64 65 6c 65 74 65 20 6d 65 y;.....delete me
13b0: 73 73 61 67 65 3b 0a 0a 09 09 09 72 65 74 75 72 ssage;.....retur
13c0: 6e 3b 0a 09 09 7d 0a 0a 09 09 76 69 72 74 75 61 n;...}....virtua
13d0: 6c 20 76 6f 69 64 20 48 61 6e 64 6c 65 4d 65 73 l void HandleMes
13e0: 73 61 67 65 28 63 6f 6e 73 74 20 70 70 3a 3a 56 sage(const pp::V
13f0: 61 72 26 20 6d 65 73 73 61 67 65 50 6c 61 69 6e ar& messagePlain
1400: 29 20 7b 0a 09 09 09 70 70 3a 3a 56 61 72 44 69 ) {....pp::VarDi
1410: 63 74 69 6f 6e 61 72 79 20 2a 6d 65 73 73 61 67 ctionary *messag
1420: 65 3b 0a 09 09 09 70 70 3a 3a 56 61 72 20 74 61 e;....pp::Var ta
1430: 72 67 65 74 3b 0a 0a 09 09 09 2f 2a 0a 09 09 09 rget;...../*....
1440: 20 2a 20 54 68 65 20 69 6e 63 6f 6d 69 6e 67 20 * The incoming
1450: 6d 65 73 73 61 67 65 20 6d 75 73 74 20 62 65 20 message must be
1460: 61 20 64 69 63 74 69 6f 6e 61 72 79 0a 09 09 09 a dictionary....
1470: 20 2a 2f 0a 09 09 09 69 66 20 28 21 6d 65 73 73 */....if (!mess
1480: 61 67 65 50 6c 61 69 6e 2e 69 73 5f 64 69 63 74 agePlain.is_dict
1490: 69 6f 6e 61 72 79 28 29 29 20 7b 0a 09 09 09 09 ionary()) {.....
14a0: 70 63 73 63 4e 61 43 6c 48 61 6e 64 6c 65 4d 65 pcscNaClHandleMe
14b0: 73 73 61 67 65 28 6d 65 73 73 61 67 65 50 6c 61 ssage(messagePla
14c0: 69 6e 29 3b 0a 0a 09 09 09 09 72 65 74 75 72 6e in);......return
14d0: 3b 0a 09 09 09 7d 0a 0a 09 09 09 2f 2a 0a 09 09 ;....}...../*...
14e0: 09 20 2a 20 50 72 6f 63 65 73 73 20 74 68 65 20 . * Process the
14f0: 61 70 70 72 6f 70 72 69 61 74 65 20 63 6f 6d 6d appropriate comm
1500: 61 6e 64 20 66 72 6f 6d 20 74 68 65 20 69 6e 63 and from the inc
1510: 6f 6d 69 6e 67 20 6d 65 73 73 61 67 65 0a 09 09 oming message...
1520: 09 20 2a 2f 0a 09 09 09 6d 65 73 73 61 67 65 20 . */....message
1530: 3d 20 6e 65 77 20 70 70 3a 3a 56 61 72 44 69 63 = new pp::VarDic
1540: 74 69 6f 6e 61 72 79 28 6d 65 73 73 61 67 65 50 tionary(messageP
1550: 6c 61 69 6e 29 3b 0a 0a 09 09 09 2f 2a 0a 09 09 lain);...../*...
1560: 09 20 2a 20 56 65 72 69 66 79 20 74 68 61 74 20 . * Verify that
1570: 74 68 69 73 20 6d 65 73 73 61 67 65 20 69 73 20 this message is
1580: 64 65 73 74 69 6e 65 64 20 66 6f 72 20 75 73 0a destined for us.
1590: 09 09 09 20 2a 2f 0a 09 09 09 69 66 20 28 21 6d ... */....if (!m
15a0: 65 73 73 61 67 65 2d 3e 48 61 73 4b 65 79 28 22 essage->HasKey("
15b0: 74 61 72 67 65 74 22 29 29 20 7b 0a 09 09 09 09 target")) {.....
15c0: 64 65 6c 65 74 65 20 6d 65 73 73 61 67 65 3b 0a delete message;.
15d0: 0a 09 09 09 09 2f 2a 20 57 65 20 64 6f 6e 27 74 ...../* We don't
15e0: 20 68 61 6e 64 6c 65 20 74 68 69 73 20 6d 65 73 handle this mes
15f0: 73 61 67 65 2c 20 73 65 65 20 69 66 20 50 43 53 sage, see if PCS
1600: 43 2d 4e 61 43 6c 20 64 6f 65 73 20 2a 2f 0a 09 C-NaCl does */..
1610: 09 09 09 70 63 73 63 4e 61 43 6c 48 61 6e 64 6c ...pcscNaClHandl
1620: 65 4d 65 73 73 61 67 65 28 6d 65 73 73 61 67 65 eMessage(message
1630: 50 6c 61 69 6e 29 3b 0a 0a 09 09 09 09 72 65 74 Plain);......ret
1640: 75 72 6e 3b 0a 09 09 09 7d 0a 0a 09 09 09 74 61 urn;....}.....ta
1650: 72 67 65 74 20 3d 20 6d 65 73 73 61 67 65 2d 3e rget = message->
1660: 47 65 74 28 22 74 61 72 67 65 74 22 29 3b 0a 09 Get("target");..
1670: 09 09 69 66 20 28 74 61 72 67 65 74 2e 41 73 53 ..if (target.AsS
1680: 74 72 69 6e 67 28 29 20 21 3d 20 22 63 61 63 6b tring() != "cack
1690: 65 79 22 29 20 7b 0a 09 09 09 09 64 65 6c 65 74 ey") {.....delet
16a0: 65 20 6d 65 73 73 61 67 65 3b 0a 0a 09 09 09 09 e message;......
16b0: 2f 2a 20 57 65 20 64 6f 6e 27 74 20 68 61 6e 64 /* We don't hand
16c0: 6c 65 20 74 68 69 73 20 6d 65 73 73 61 67 65 2c le this message,
16d0: 20 73 65 65 20 69 66 20 50 43 53 43 2d 4e 61 43 see if PCSC-NaC
16e0: 6c 20 64 6f 65 73 20 2a 2f 0a 09 09 09 09 70 63 l does */.....pc
16f0: 73 63 4e 61 43 6c 48 61 6e 64 6c 65 4d 65 73 73 scNaClHandleMess
1700: 61 67 65 28 6d 65 73 73 61 67 65 50 6c 61 69 6e age(messagePlain
1710: 29 3b 0a 0a 09 09 09 09 72 65 74 75 72 6e 3b 0a );......return;.
1720: 09 09 09 7d 0a 0a 09 09 09 2f 2a 0a 09 09 09 20 ...}...../*....
1730: 2a 20 44 65 74 65 72 6d 69 6e 65 20 77 68 61 74 * Determine what
1740: 20 77 65 20 61 72 65 20 62 65 69 6e 67 20 61 73 we are being as
1750: 6b 65 64 20 74 6f 20 64 6f 0a 09 09 09 20 2a 2f ked to do.... */
1760: 0a 09 09 09 69 66 20 28 21 6d 65 73 73 61 67 65 ....if (!message
1770: 2d 3e 48 61 73 4b 65 79 28 22 63 6f 6d 6d 61 6e ->HasKey("comman
1780: 64 22 29 29 20 7b 0a 09 09 09 09 64 65 6c 65 74 d")) {.....delet
1790: 65 20 6d 65 73 73 61 67 65 3b 0a 0a 09 09 09 09 e message;......
17a0: 2f 2a 20 57 65 20 64 6f 6e 27 74 20 68 61 6e 64 /* We don't hand
17b0: 6c 65 20 74 68 69 73 20 6d 65 73 73 61 67 65 2c le this message,
17c0: 20 73 65 65 20 69 66 20 50 43 53 43 2d 4e 61 43 see if PCSC-NaC
17d0: 6c 20 64 6f 65 73 20 2a 2f 0a 09 09 09 09 70 63 l does */.....pc
17e0: 73 63 4e 61 43 6c 48 61 6e 64 6c 65 4d 65 73 73 scNaClHandleMess
17f0: 61 67 65 28 6d 65 73 73 61 67 65 50 6c 61 69 6e age(messagePlain
1800: 29 3b 0a 0a 09 09 09 09 72 65 74 75 72 6e 3b 0a );......return;.
1810: 09 09 09 7d 0a 0a 09 09 09 2f 2a 0a 09 09 09 20 ...}...../*....
1820: 2a 20 50 72 6f 63 65 73 73 20 74 68 65 20 72 65 * Process the re
1830: 71 75 65 73 74 20 69 6e 20 61 6e 6f 74 68 65 72 quest in another
1840: 20 74 68 72 65 61 64 0a 09 09 09 20 2a 2f 0a 09 thread.... */..
1850: 09 09 73 74 64 3a 3a 74 68 72 65 61 64 28 26 43 ..std::thread(&C
1860: 41 43 4b 65 79 49 6e 73 74 61 6e 63 65 3a 3a 48 ACKeyInstance::H
1870: 61 6e 64 6c 65 4d 65 73 73 61 67 65 54 68 72 65 andleMessageThre
1880: 61 64 2c 20 74 68 69 73 2c 20 6d 65 73 73 61 67 ad, this, messag
1890: 65 29 2e 64 65 74 61 63 68 28 29 3b 0a 0a 09 09 e).detach();....
18a0: 09 72 65 74 75 72 6e 3b 0a 09 09 7d 0a 7d 3b 0a .return;...}.};.
18b0: 0a 63 6c 61 73 73 20 43 41 43 4b 65 79 4d 6f 64 .class CACKeyMod
18c0: 75 6c 65 20 3a 20 70 75 62 6c 69 63 20 70 70 3a ule : public pp:
18d0: 3a 4d 6f 64 75 6c 65 20 7b 0a 09 70 75 62 6c 69 :Module {..publi
18e0: 63 3a 0a 09 09 43 41 43 4b 65 79 4d 6f 64 75 6c c:...CACKeyModul
18f0: 65 28 29 20 3a 20 70 70 3a 3a 4d 6f 64 75 6c 65 e() : pp::Module
1900: 28 29 20 7b 7d 0a 09 09 76 69 72 74 75 61 6c 20 () {}...virtual
1910: 7e 43 41 43 4b 65 79 4d 6f 64 75 6c 65 28 29 20 ~CACKeyModule()
1920: 7b 7d 0a 0a 09 09 76 69 72 74 75 61 6c 20 70 70 {}....virtual pp
1930: 3a 3a 49 6e 73 74 61 6e 63 65 20 2a 43 72 65 61 ::Instance *Crea
1940: 74 65 49 6e 73 74 61 6e 63 65 28 50 50 5f 49 6e teInstance(PP_In
1950: 73 74 61 6e 63 65 20 69 6e 73 74 61 6e 63 65 29 stance instance)
1960: 20 7b 0a 09 09 09 72 65 74 75 72 6e 28 6e 65 77 {....return(new
1970: 20 43 41 43 4b 65 79 49 6e 73 74 61 6e 63 65 28 CACKeyInstance(
1980: 69 6e 73 74 61 6e 63 65 2c 20 63 6f 72 65 28 29 instance, core()
1990: 29 29 3b 0a 09 09 7d 0a 7d 3b 0a 0a 6e 61 6d 65 ));...}.};..name
19a0: 73 70 61 63 65 20 70 70 20 7b 0a 09 4d 6f 64 75 space pp {..Modu
19b0: 6c 65 20 2a 43 72 65 61 74 65 4d 6f 64 75 6c 65 le *CreateModule
19c0: 28 29 20 7b 0a 09 09 72 65 74 75 72 6e 28 6e 65 () {...return(ne
19d0: 77 20 43 41 43 4b 65 79 4d 6f 64 75 6c 65 28 29 w CACKeyModule()
19e0: 29 3b 0a 09 7d 0a 7d 0a );..}.}.