diff options
Diffstat (limited to 'includes/js/dojox/_sql/demos/customers/customers.html')
| -rw-r--r-- | includes/js/dojox/_sql/demos/customers/customers.html | 292 | 
1 files changed, 292 insertions, 0 deletions
| diff --git a/includes/js/dojox/_sql/demos/customers/customers.html b/includes/js/dojox/_sql/demos/customers/customers.html new file mode 100644 index 0000000..a4c0c03 --- /dev/null +++ b/includes/js/dojox/_sql/demos/customers/customers.html @@ -0,0 +1,292 @@ +<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> + +<html> +	<head> +	    <script type="text/javascript"  +	            src="../../../../dojo/dojo.js" djConfig="isDebug: false"></script> +		<script type="text/javascript" src="../../../../dojox/off/offline.js"></script> +		 +		<style type="text/css"> +			body{ +				padding: 2em; +			} +			 +			#dataTable{ +				margin-top: 2em; +			} +			 +			button{ +				margin-left: 1em; +			} +			 +			th, tr, td{ +				text-align: left; +			} +			 +			table{ +				text-align: center; +				clear: both; +			} +			 +			#cryptoContainer{ +				float: left; +				width: 60%; +			} +			 +			#numRowsContainer{ +				float: right; +				width: 40%; +			} +			 +			#numRowsContainer input{ +				margin-left: 1.5em; +				width: 5em; +			} +			 +			.table-columns{ +				font-weight: bold; +			} +		</style> +		 +		<script> +			dojo.require("dojox.sql"); +			 +			dojo.connect(window, "onload", function(){ +				// draw our customer table on the screen +				createTable(); +				 +				// create our customer table in the database +				dojox.sql("DROP TABLE IF EXISTS CUSTOMERS"); +				dojox.sql("CREATE TABLE CUSTOMERS (" +								+ "last_name TEXT, " +								+ "first_name TEXT, " +								+ "social_security TEXT" +								+ ")" +							); +			}); +			 +			function createTable(){	 +				// get number of rows to create +				var NUM_ROWS = document.getElementById("numRows").value; +				if(!NUM_ROWS){ +					alert("Please enter the number of " +							+ "customer rows the table should have"); +					return; +				}  +				 +				var table = document.getElementById("dataTable"); +				if(table){ +					table.parentNode.removeChild(table); +				} +				 +				table = document.createElement("table"); +				table.setAttribute("id", "dataTable"); +				table.setAttribute("border", 1); +				 +				// if we don't use IE's craptacular proprietary table methods +				// we get strange display glitches +				var tr = (dojo.isIE) ? table.insertRow() : document.createElement("tr"); +				tr.className = "table-columns"; +				var th = (dojo.isIE) ? tr.insertCell() : document.createElement("th"); +				th.appendChild(document.createTextNode("Last Name")); +				if(!dojo.isIE){ +					tr.appendChild(th); +				} +				th = (dojo.isIE) ? tr.insertCell() : document.createElement("th"); +				th.appendChild(document.createTextNode("First Name")); +				if(!dojo.isIE){ +					tr.appendChild(th); +				} +				th = (dojo.isIE) ? tr.insertCell() : document.createElement("th"); +				th.appendChild(document.createTextNode("Social Security")); +				if(!dojo.isIE){ +					tr.appendChild(th); +					 +					table.appendChild(tr); +				} +				 +				for(var i = 1; i <= NUM_ROWS; i++){ +					tr = (dojo.isIE) ? table.insertRow() : document.createElement("tr"); +					tr.className = "data-item"; +					 +					var elem = (dojo.isIE) ? tr.insertCell() : document.createElement("td"); +					elem.className = "last-name"; +					var lastName = "Doe" + i; +					elem.appendChild(document.createTextNode(lastName)); +					if(!dojo.isIE){ +						tr.appendChild(elem); +					} +					 +					elem = (dojo.isIE) ? tr.insertCell() : document.createElement("td"); +					elem.className = "first-name"; +					var firstName = "John" + i; +					elem.appendChild(document.createTextNode(firstName)); +					if(!dojo.isIE){ +						tr.appendChild(elem); +					} +					 +					elem = elem = (dojo.isIE) ? tr.insertCell() : document.createElement("td"); +					elem.className = "social-security"; +					var ss = 513121500 + i; +					ss = new String(ss); +					ss = ss.slice(0, 3) + "-" + ss.slice(3, 5) + "-" + ss.slice(5); +					elem.appendChild(document.createTextNode(ss)); +					if(!dojo.isIE){ +						tr.appendChild(elem); +					 +						table.appendChild(tr); +					} +				} +				 +				document.body.appendChild(table); +				 +				// reset button state +				dojo.byId("encrypt").disabled = false; +				dojo.byId("decrypt").disabled = true; +			} +			 +			function readTable(){ +				var data = []; +				var rows = dojo.query(".data-item"); +				dojo.forEach(rows, function(row){ +					var td = row.getElementsByTagName("td"); +					 +					var lastName = td[0].childNodes[0].nodeValue; +					var firstName = td[1].childNodes[0].nodeValue; +					var ssNumber = td[2].childNodes[0].nodeValue; + +					data.push({lastName: lastName, firstName: firstName, ssNumber: ssNumber, +								toString: function(){ +									return "{lastName: " + lastName  +												+ ", firstName: " + firstName +												+ ", ssNumber: " + ssNumber +												+ "}"; +								}}); +				}); +				 +				return data; +			} +			 +			function setData(data){ +				var rows = document.getElementsByTagName("tr"); +				for(var i = 1; i < rows.length; i++){ +					var customer = data[i - 1]; +					var td = rows[i].getElementsByTagName("td"); +					td[2].childNodes[0].nodeValue = customer.social_security; +				} +			} +			 +			function encrypt(){ +				// disable our buttons +				dojo.byId("encrypt").disabled = true; +				dojo.byId("decrypt").disabled = true; +				 +				var data = readTable(); +				 +				var password = document.getElementById("password").value; +				 +				// delete any old data +				dojox.sql("DELETE FROM CUSTOMERS"); +				 +				// insert new data +				insertCustomers(data, 0, password); +			} +			 +			function insertCustomers(data, i, password){ +				var nextIndex = i + 1; +				 +				if(i >= data.length){ +					var savedRows = dojox.sql("SELECT * FROM CUSTOMERS"); +					setData(savedRows); +					return; +				} +				dojox.sql("INSERT INTO CUSTOMERS VALUES (?, ?, ENCRYPT(?))", +							data[i].lastName, data[i].firstName, +							data[i].ssNumber, +							password, +							function(results, error, errorMsg){ +								// enable our buttons +								dojo.byId("encrypt").disabled = true; +								dojo.byId("decrypt").disabled = false; +								 +								if(error == true){ +									alert(errorMsg); +									return; +								} +								 +								insertCustomers(data, nextIndex, password); +							} +						); +			} +			 +			function decrypt(){ +				// disable our buttons +				dojo.byId("encrypt").disabled = true; +				dojo.byId("decrypt").disabled = true; +				 +				var password = document.getElementById("password").value; +				 +				dojox.sql("SELECT last_name, first_name, DECRYPT(social_security) FROM CUSTOMERS", +							password, +							function(results, error, errorMsg){ +								// enable our buttons +								dojo.byId("encrypt").disabled = false; +								dojo.byId("decrypt").disabled = true; +								 +								if(error == true){ +									alert(errorMsg); +									return; +								} +								 +								setData(results); +							} +						); +			} +		</script> +	</head> +	 +	<body> +		<h1>Dojo SQL Cryptography</h1> +		 +		<h2>Instructions</h2> +		 +		<p>This demo shows Dojo Offline's SQL encryption technologies. In the table below, we have a +			sample SQL table that has three columns of data: a last name, a first name, and +			a social security number. We don't want to store the social security numbers +			in the clear, just in case they are downloaded for offline use to a laptop and the +			laptop is stolen.</p> +		 +		<p>To use this demo, enter a password and press the ENCRYPT button to see the Social Security column encrypt. Enter +			the same password and press DECRYPT to see it decrypt. If you enter an incorrect password and +			press DECRYPT, the Social Security column will remain encrypted and only show gibberish.</p> +			 +		<p>Under the covers we use 256-bit AES encryption and your password to derive the crypto key; we use +			a facility in Google Gears to do the cryptography in such a way that the browser does not lock up +			during processing. Dojo Offline ties this cryptography into Dojo SQL, providing convenient ENCRYPT() +			and DECRYPT() SQL keywords you can use to easily have this functionality in your +			own offline applications. To learn how you can use this feature  +			<a href="http://docs.google.com/View?docid=dhkhksk4_8gdp9gr#crypto" target="_blank">see here</a>.</p> +		 +		<div id="cryptoContainer"> +			<label for="password"> +				Password: +			</label> +		 +			<input type="input" name="password" id="password" value="sample_password"> +		 +			<button id="encrypt" onclick="window.setTimeout(encrypt, 1)">Encrypt</button> +		 +			<button id="decrypt" onclick="window.setTimeout(decrypt, 1)" disabled="true">Decrypt</button> +		</div> +		 +		<div id="numRowsContainer"> +			<label for="numRows"> +				Number of Customer Rows in Table: +			</label> +		 +			<input id="numRows" type="input" value="30"> +			 +			<button onclick="createTable()">Update</button> +		</div> +	</body> +</html>
\ No newline at end of file | 
