blob: f8f4d69c3d86a8b3ce6b5d230a5b031f1f1013a8 [file] [log] [blame]
Meki Cherkaouif441d3a2012-04-22 15:17:52 -07001/*
2 * @author: ucla-cs
3 * This class represents Signature Objects
4 */
5
6
7var Signature = function Signature(_Witness,_Signature,_DigestAlgorithm) {
8
9 this.Witness = _Witness;//byte [] _witness;
10 this.Signature = _Signature;//byte [] _signature;
11 this.DigestAlgorithm = _DigestAlgorithm//String _digestAlgorithm;
12};
13
Meki Cherkaouif3d8f692012-05-18 15:44:28 -070014var generateSignature = function(contentName,content,signedinfo){
15
16 var enc = new BinaryXMLEncoder();
17 contentName.encode(enc);
18 var hex1 = toHex(enc.getReducedOstream());
19
20 var enc = new BinaryXMLEncoder();
21 content.encode(enc);
22 var hex2 = toHex(enc.getReducedOstream());
23
24 var enc = new BinaryXMLEncoder();
25 signedinfo.encode(enc);
26 var hex3 = toHex(enc.getReducedOstream());
27
28 var hex = hex1+hex2+hex3;
29
30 //globalKeyManager.sig
31
32};
Meki Cherkaouif441d3a2012-04-22 15:17:52 -070033
34Signature.prototype.decode =function( decoder) {
35 decoder.readStartElement(this.getElementLabel());
Meki Cherkaouif3d8f692012-05-18 15:44:28 -070036
37 if(LOG>4)console.log('STARTED DECODING SIGNATURE ');
38
Meki Cherkaouif441d3a2012-04-22 15:17:52 -070039 if (decoder.peekStartElement(CCNProtocolDTags.DigestAlgorithm)) {
Meki Cherkaouif3d8f692012-05-18 15:44:28 -070040
41 if(LOG>4)console.log('DIGIEST ALGORITHM FOUND');
Meki Cherkaouif441d3a2012-04-22 15:17:52 -070042 this.DigestAlgorithm = decoder.readUTF8Element(CCNProtocolDTags.DigestAlgorithm);
43 }
44 if (decoder.peekStartElement(CCNProtocolDTags.Witness)) {
Meki Cherkaouif3d8f692012-05-18 15:44:28 -070045 if(LOG>4)console.log('WITNESS FOUND FOUND');
Meki Cherkaouif441d3a2012-04-22 15:17:52 -070046 this.Witness = decoder.readBinaryElement(CCNProtocolDTags.Witness);
47 }
Meki Cherkaouif3d8f692012-05-18 15:44:28 -070048
49 //FORCE TO READ A SIGNATURE
50
51 //if (decoder.peekStartElement(CCNProtocolDTags.SignatureBits)) {
52 //if(LOG>4)console.log('SIGNATURE FOUND ');
53 this.Signature = decoder.readBinaryElement(CCNProtocolDTags.SignatureBits);
54
55 //}
56
Meki Cherkaouif441d3a2012-04-22 15:17:52 -070057 decoder.readEndElement();
58
59};
60
61
62Signature.prototype.encode= function( encoder){
63
64 if (!this.validate()) {
65 throw new Exception("Cannot encode: field values missing.");
66 }
67
68 encoder.writeStartElement(this.getElementLabel());
69
70 if ((null != this.DigestAlgorithm) && (!this.DigestAlgorithm.equals(CCNDigestHelper.DEFAULT_DIGEST_ALGORITHM))) {
71 encoder.writeElement(CCNProtocolDTags.DigestAlgorithm, OIDLookup.getDigestOID(this.DigestAlgorithm));
72 }
73
74 if (null != this.Witness) {
75 // needs to handle null witness
76 encoder.writeElement(CCNProtocolDTags.Witness, this.Witness);
77 }
78
79 encoder.writeElement(CCNProtocolDTags.SignatureBits, this.Signature);
80
81 encoder.writeEndElement();
82};
83
84Signature.prototype.getElementLabel = function() { return CCNProtocolDTags.Signature; };
85
86
87Signature.prototype.validate = function() {
88 return null != this.Signature;
89};
90