Adding FaceInstance

FaceInstance object added ( used to register faces)

Publish-data.html
Request-data.html

(replacing indes.html)
diff --git a/js/FaceInstance.js b/js/FaceInstance.js
new file mode 100644
index 0000000..6a709fe
--- /dev/null
+++ b/js/FaceInstance.js
@@ -0,0 +1,152 @@
+
+
+
+var FaceInstance  = function FaceInstance(
+	    _Action,
+		_PublisherPublicKeyDigest,
+		_FaceID,
+		_IPProto,
+		_Host,
+		_Port,
+		_MulticastInterface,
+		_MulticastTTL,
+		_FreshnessSeconds,){
+		
+	
+	this.Action = _Action,
+	this.PublisherPublicKeyDigest = _PublisherPublicKeyDigest,
+	this.FaceID = _FaceID,
+	this.IPProto = _IPProto,
+	this.Host = _Host,
+	this.Port = _Port,
+	this.MulticastInterface =_MulticastInterface,
+	this.MulticastTTL =_MulticastTTL,
+	this.FreshnessSeconds = _FreshnessSeconds,
+	
+	
+	//Action           ::= ("newface" | "destroyface" | "queryface")
+	//PublisherPublicKeyDigest ::= SHA-256 digest
+	//FaceID           ::= nonNegativeInteger
+	//IPProto          ::= nonNegativeInteger [IANA protocol number, 6=TCP, 17=UDP]
+	//Host             ::= textual representation of numeric IPv4 or IPv6 address
+	//Port             ::= nonNegativeInteger [1..65535]
+	//MulticastInterface ::= textual representation of numeric IPv4 or IPv6 address
+	//MulticastTTL     ::= nonNegativeInteger [1..255]
+	//FreshnessSeconds ::= nonNegativeInteger
+
+};
+
+/**
+ * Used by NetworkObject to decode the object from a network stream.
+ * @see org.ccnx.ccn.impl.encoding.XMLEncodable
+ */
+FaceInstance.prototype.decode(//XMLDecoder 
+	decoder) {
+
+	decoder.readStartElement(this.getElementLabel());
+	
+	if (decoder.peekStartElement(CCNProtocolDTags.Action)) {
+		
+		this.Action = decoder.readUTF8Element(CCNProtocolDTags.Action);
+		
+	}
+	if (decoder.peekStartElement(CCNProtocolDTags.PublisherPublicKeyDigest)) {
+		
+		this.PublisherPublicKeyDigest = new PublisherPublicKeyDigest();
+		this.PublisherPublicKeyDigest.decode(decoder);
+		
+	}
+	if (decoder.peekStartElement(CCNProtocolDTags.FaceID)) {
+		
+		this.FaceID = decoder.readIntegerElement(CCNProtocolDTags.FaceID);
+		
+	}
+	if (decoder.peekStartElement(CCNProtocolDTags.IPProto)) {
+		
+		//int
+		var pI = decoder.readIntegerElement(CCNProtocolDTags.IPProto);
+		
+		this.IPProto = null;
+		
+		if (NetworkProtocol.TCP.value().intValue() == pI) {
+			
+			this.IPProto = NetworkProtocol.TCP;
+			
+		} else if (NetworkProtocol.UDP.value().intValue() == pI) {
+			
+			this.IPProto = NetworkProtocol.UDP;
+			
+		} else {
+			
+			throw new Exception("FaceInstance.decoder.  Invalid " + 
+					CCNProtocolDTags.tagToString(CCNProtocolDTags.IPProto) + " field: " + pI);
+			
+		}
+	}
+	
+	if (decoder.peekStartElement(CCNProtocolDTags.Host)) {
+		
+		this.Host = decoder.readUTF8Element(CCNProtocolDTags.Host);
+		
+	}
+	
+	if (decoder.peekStartElement(CCNProtocolDTags.Port)) {
+		this.Port = decoder.readIntegerElement(CCNProtocolDTags.Port); 
+	}
+	
+	if (decoder.peekStartElement(CCNProtocolDTags.MulticastInterface)) {
+		this.MulticastInterface = decoder.readUTF8Element(CCNProtocolDTags.MulticastInterface); 
+	}
+	
+	if (decoder.peekStartElement(CCNProtocolDTags.MulticastTTL)) {
+		this.MulticastTTL = decoder.readIntegerElement(CCNProtocolDTags.MulticastTTL); 
+	}
+	
+	if (decoder.peekStartElement(CCNProtocolDTags.FreshnessSeconds)) {
+		this.FreshnessSeconds = decoder.readIntegerElement(CCNProtocolDTags.FreshnessSeconds); 
+	}
+	
+	decoder.readEndElement();
+}
+
+/**
+ * Used by NetworkObject to encode the object to a network stream.
+ * @see org.ccnx.ccn.impl.encoding.XMLEncodable
+ */
+public void encode(XMLEncoder encoder) throws ContentEncodingException {
+	if (!validate()) {
+		throw new ContentEncodingException("Cannot encode " + this.getClass().getName() + ": field values missing.");
+	}
+	encoder.writeStartElement(getElementLabel());
+	if (null != _action && _action.length() != 0)
+		encoder.writeElement(CCNProtocolDTags.Action, _action);	
+	if (null != _ccndID) {
+		_ccndID.encode(encoder);
+	}
+	if (null != _faceID) {
+		encoder.writeElement(CCNProtocolDTags.FaceID, _faceID);
+	}
+	if (null != _ipProto) {
+		encoder.writeElement(CCNProtocolDTags.IPProto, _ipProto.value());
+	}
+	if (null != _host && _host.length() != 0) {
+		encoder.writeElement(CCNProtocolDTags.Host, _host);	
+	}
+	if (null != _port) {
+		encoder.writeElement(CCNProtocolDTags.Port, _port);
+	}
+	if (null != _multicastInterface && _multicastInterface.length() != 0) {
+		encoder.writeElement(CCNProtocolDTags.MulticastInterface, _multicastInterface);
+	}
+	if (null != _multicastTTL) {
+		encoder.writeElement(CCNProtocolDTags.MulticastTTL, _multicastTTL);
+	}
+	if (null != _lifetime) {
+		encoder.writeElement(CCNProtocolDTags.FreshnessSeconds, _lifetime);
+	}
+	encoder.writeEndElement();   			
+}
+
+
+FaceInstance.prototype.getElementLabel= function(){return CCNProtocolDTags.FaceInstance;};
+
diff --git a/js/index.html b/js/publish-data.html
similarity index 81%
copy from js/index.html
copy to js/publish-data.html
index 04e402e..84fb9ac 100644
--- a/js/index.html
+++ b/js/publish-data.html
@@ -51,18 +51,24 @@
 

 			var ContentName = document.getElementById('contentname').value;

 		

+			var Content = document.getElementById('content').value;

+			

+			

+			

 			///////////////////////////////////////

 		    //createRoute('localhost', 9695);

 

-		    createRoute('131.179.141.15', 9695);

+		    //createRoute('131.179.141.15', 9695);

 		    //createRoute('borges.metwi.ucla.edu', 9695);

 		    

 			//content object

-			var co = queryPrefix( ContentName );

+			//var co = queryPrefix( ContentName );

+			

+			

 			

 			///////////////////////////////////////

 			

-			var output ="";

+			/*var output ="";

 			

 			if(co==-1)

 				output+= "NO CONTENT FOUND"

@@ -106,9 +112,11 @@
 					output+= "<br />";

 	

 				}

-			}

+			}*/

 			

-			document.getElementById('result').innerHTML = output;

+			//document.getElementById('result').innerHTML = output;

+			document.getElementById('result').innerHTML = 'Content \'' + Content + '\' was published with content name \'' + ContentName +'\'';

+

 		}

 	

 		</script>

@@ -116,9 +124,19 @@
 </head>

 <body >

 	<form>

-		Please Enter a Content Name:<br /><input id="contentname" type="text" name="CONTENTNAME" value="/PARC/abc" /> <br />

+

+		Please Enter a Content Name:<br />

+		

+		<input id="contentname" type="text" name="CONTENTNAME" value="/PARC/abc" /> 

+		

+		Please Enter the Content:<br />

+		

+		<textarea id="content" cols="40" rows="5" name="CONTENT" value="SUCCESS"  >SUCCESS!</textarea> 

+		

+		

+		<br />

 	</form>

-	<button onclick="run()">Run!</button>

+	<button onclick="run()">Publish</button>

 	<div >

 		<applet id="JavaSocketBridge" archive="JavaSocketBridge.jar" code="JavaSocketBridge.class" width="0" height="0">

 		</applet>

diff --git a/js/index.html b/js/request-data.html
similarity index 98%
rename from js/index.html
rename to js/request-data.html
index 04e402e..f00510a 100644
--- a/js/index.html
+++ b/js/request-data.html
@@ -118,7 +118,7 @@
 	<form>

 		Please Enter a Content Name:<br /><input id="contentname" type="text" name="CONTENTNAME" value="/PARC/abc" /> <br />

 	</form>

-	<button onclick="run()">Run!</button>

+	<button onclick="run()">Request Data!</button>

 	<div >

 		<applet id="JavaSocketBridge" archive="JavaSocketBridge.jar" code="JavaSocketBridge.class" width="0" height="0">

 		</applet>