aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Makefile7
-rw-r--r--icon-128.pngbin0 -> 8549 bytes
-rw-r--r--importLDIF.appcache5
-rw-r--r--[l---------]libs/parseLDIF.js296
-rw-r--r--manifest.webapp24
-rw-r--r--tux-rolodex-Ity.gifbin0 -> 68028 bytes
6 files changed, 331 insertions, 1 deletions
diff --git a/Makefile b/Makefile
new file mode 100644
index 0000000..3ab74fa
--- /dev/null
+++ b/Makefile
@@ -0,0 +1,7 @@
+FILES=icon-128.png importAddrBook.js importLDIF.appcache index.html \
+ libs/parseLDIF.js manifest.webapp
+
+all: importAddrBook.zip
+
+importAddrBook.zip: $(FILES)
+ zip -9vT $@ $(FILES)
diff --git a/icon-128.png b/icon-128.png
new file mode 100644
index 0000000..836f545
--- /dev/null
+++ b/icon-128.png
Binary files differ
diff --git a/importLDIF.appcache b/importLDIF.appcache
new file mode 100644
index 0000000..c7a953f
--- /dev/null
+++ b/importLDIF.appcache
@@ -0,0 +1,5 @@
+CACHE MANIFEST
+# v1 - 2013-05-14
+importAddrBook.js
+index.html
+libs/parseLDIF.js
diff --git a/libs/parseLDIF.js b/libs/parseLDIF.js
index 0df7340..e060f54 120000..100644
--- a/libs/parseLDIF.js
+++ b/libs/parseLDIF.js
@@ -1 +1,295 @@
-parseLDIF/parseLDIF.js \ No newline at end of file
+// Compatibility shims
+if (!String.prototype.trim) {
+ String.prototype.trim = function () {
+ return this.replace(/^\s+|\s+$/g,'');
+ };
+}
+
+if (!String.prototype.trimRight) {
+ String.prototype.trimRight = function () {
+ return this.replace(/\s+$/,'');
+ };
+}
+
+if (!Array.isArray) {
+ Array.isArray = function (vArg) {
+ return Object.prototype.toString.call(vArg) === "[object Array]";
+ };
+}
+
+const debugState = false;
+
+/**
+*
+* Base64 encode / decode
+* http://www.webtoolkit.info/
+* From http://stackoverflow.com/questions/246801\
+* /how-can-you-encode-to-base64-using-javascript
+*
+**/
+var Base64 = {
+
+ // private property
+ _keyStr : "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",
+
+ // public method for encoding
+ encode : function (input) {
+ var output = "";
+ var chr1, chr2, chr3, enc1, enc2, enc3, enc4;
+ var i = 0;
+
+ input = Base64._utf8_encode(input);
+
+ while (i < input.length) {
+
+ chr1 = input.charCodeAt(i++);
+ chr2 = input.charCodeAt(i++);
+ chr3 = input.charCodeAt(i++);
+
+ enc1 = chr1 >> 2;
+ enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
+ enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
+ enc4 = chr3 & 63;
+
+ if (isNaN(chr2)) {
+ enc3 = enc4 = 64;
+ } else if (isNaN(chr3)) {
+ enc4 = 64;
+ }
+
+ output = output +
+ this._keyStr.charAt(enc1) + this._keyStr.charAt(enc2) +
+ this._keyStr.charAt(enc3) + this._keyStr.charAt(enc4);
+
+ }
+
+ return output;
+ },
+
+ // public method for decoding
+ decode : function (input) {
+ var output = "";
+ var chr1, chr2, chr3;
+ var enc1, enc2, enc3, enc4;
+ var i = 0;
+
+ input = input.replace(/[^A-Za-z0-9\+\/\=]/g, "");
+
+ while (i < input.length) {
+
+ enc1 = this._keyStr.indexOf(input.charAt(i++));
+ enc2 = this._keyStr.indexOf(input.charAt(i++));
+ enc3 = this._keyStr.indexOf(input.charAt(i++));
+ enc4 = this._keyStr.indexOf(input.charAt(i++));
+
+ chr1 = (enc1 << 2) | (enc2 >> 4);
+ chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
+ chr3 = ((enc3 & 3) << 6) | enc4;
+
+ output = output + String.fromCharCode(chr1);
+
+ if (enc3 != 64) {
+ output = output + String.fromCharCode(chr2);
+ }
+ if (enc4 != 64) {
+ output = output + String.fromCharCode(chr3);
+ }
+
+ }
+
+ output = Base64._utf8_decode(output);
+
+ return output;
+
+ },
+
+ // private method for UTF-8 encoding
+ _utf8_encode : function (string) {
+ string = string.replace(/\r\n/g,"\n");
+ var utftext = "";
+
+ for (var n = 0; n < string.length; n++) {
+
+ var c = string.charCodeAt(n);
+
+ if (c < 128) {
+ utftext += String.fromCharCode(c);
+ }
+ else if((c > 127) && (c < 2048)) {
+ utftext += String.fromCharCode((c >> 6) | 192);
+ utftext += String.fromCharCode((c & 63) | 128);
+ }
+ else {
+ utftext += String.fromCharCode((c >> 12) | 224);
+ utftext += String.fromCharCode(((c >> 6) & 63) | 128);
+ utftext += String.fromCharCode((c & 63) | 128);
+ }
+
+ }
+
+ return utftext;
+ },
+
+ // private method for UTF-8 decoding
+ _utf8_decode : function (utftext) {
+ var string = "";
+ var i = 0;
+ var c = c1 = c2 = 0;
+
+ while ( i < utftext.length ) {
+
+ c = utftext.charCodeAt(i);
+
+ if (c < 128) {
+ string += String.fromCharCode(c);
+ i++;
+ }
+ else if((c > 191) && (c < 224)) {
+ c2 = utftext.charCodeAt(i+1);
+ string += String.fromCharCode(((c & 31) << 6) | (c2 & 63));
+ i += 2;
+ }
+ else {
+ c2 = utftext.charCodeAt(i+1);
+ c3 = utftext.charCodeAt(i+2);
+ string += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63));
+ i += 3;
+ }
+
+ }
+
+ return string;
+ }
+
+}
+
+const usefulFields = ["birthyear", "c", "cn", "description",
+ "facsimiletelephonenumber", "givenName", "homePhone", "l", "mail",
+ "mobile", "mozillaHomeCountryName", "mozillaHomeLocalityName",
+ "mozillaHomePostalCode", "mozillaHomeState", "mozillaHomeStreet",
+ "mozillaHomeUrl", "mozillaNickname", "o", "sn", "st", "street",
+ "telephoneNumber", "title", "objectclass"
+ ];
+
+function debug(str) {
+ if (debugState) {
+ print(str);
+ }
+}
+
+/**
+ * parse LDIF string into JavaScript Object
+ *
+ * @inStr String
+ * @returns Object
+ *
+ * @todo
+ * Tries to follow RFC2849, but
+ * - doesn’t even consider change requests, only complete values
+ * - doesn’t include version: field (seems to be ignored by
+ * Thunderbird as well).
+ * - ignores multi-value attributes completely
+ * - ignores < links
+ */
+function parseLDIF(inStr) {
+ var record = {},
+ key = "",
+ value = null,
+ splitLine = [],
+ colon_idx = 0,
+ out_records = [];
+
+ function handleAdding(key, value) {
+ value = value ? value.trim() : "";
+
+ // base64 encoded value
+ if (value[0] === ":") {
+ value = Base64.decode(value.slice(1).trim());
+ }
+
+ if (key && (usefulFields.indexOf(key) != -1) &&
+ value.length > 0) {
+ if (key in this) {
+ if (Array.isArray(this[key])) {
+ this[key].push(value);
+ }
+ else {
+ this[key] = new Array(this[key]);
+ this[key].push(value);
+ }
+ }
+ else {
+ this[key] = value;
+ }
+ }
+
+ key = "";
+ value = null;
+ }
+
+ record.add = handleAdding;
+
+ inStr.forEach(function (line) {
+ if (line != undefined) {
+ line = line.trim();
+
+ if (line.length == 0) {
+ // > 1, because we have always .add property
+ if (Object.keys(record).length > 1) {
+ record.add(key, value);
+ delete record.add;
+
+ if (record.objectclass &&
+ (record.objectclass === "person" ||
+ record.objectclass.indexOf("person") !== -1)) {
+ delete record.objectclass;
+ out_records.push(record);
+ }
+ }
+ record = {};
+ record.add = handleAdding;
+ key = "";
+ value = null;
+ }
+ else {
+ // comment line
+ if (line[0] === "#") {
+ return ;
+ }
+ else {
+ colon_idx = line.indexOf(":");
+ line = line.trim();
+
+ // Line continuation
+ // This is how it works in THunderbird exported LDIF
+ // files, but not what RFC describes ... the first character
+ // of continuing entry should be space, and the first line
+ // of value should never be empty. Hopefully, this solution
+ // should be at least compatible for reading of RFC LDIF
+ // files (so it doesn’t hurt)
+ if (colon_idx == -1) {
+ // multiline value
+ if (line[0] === " ") {
+ line = line.slice(1);
+ }
+ value += line;
+ }
+ else {
+ record.add(key, value);
+
+ key = line.slice(0, colon_idx);
+ value = line.slice(colon_idx + 1);
+ }
+
+ }
+ }
+ }
+ });
+
+ return out_records;
+}
+
+if (arguments && arguments.length == 1) {
+ var lines = readFile(arguments[0]).replace(/\r\n/g,"\n");
+ print(parseLDIF(lines.split("\n")).toSource());
+}
diff --git a/manifest.webapp b/manifest.webapp
new file mode 100644
index 0000000..acc2063
--- /dev/null
+++ b/manifest.webapp
@@ -0,0 +1,24 @@
+{
+ "version": "0.0.1",
+ "name": "importLDIF",
+ "description": "Import LDIF file from the remote URL to Firefox OS Contacts application",
+ "icons": {
+ "128": "/icon-128.png"
+ },
+ "developer": {
+ "name": "Matěj Cepl",
+ "url": "http://matej.ceplovi.cz"
+ },
+ "permissions": {
+ "contacts": {
+ "access": "readwrite",
+ "description": "Required for adding imported contacts to the system addressbook."
+ },
+ "systemXHR": {
+ "description": "Required for access to randomly located LDIF files on the Internet"
+ }
+ },
+ "installs_allowed_from": [
+ "*"
+ ]
+}
diff --git a/tux-rolodex-Ity.gif b/tux-rolodex-Ity.gif
new file mode 100644
index 0000000..4cdd310
--- /dev/null
+++ b/tux-rolodex-Ity.gif
Binary files differ