-rw-r--r-- | content/flickr.js | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/content/flickr.js b/content/flickr.js index b8360c1..e09d5f0 100644 --- a/content/flickr.js +++ b/content/flickr.js | |||
@@ -68,64 +68,65 @@ Photo.prototype = { | |||
68 | t = n.getElementsByTagName('owner').item(0); | 68 | t = n.getElementsByTagName('owner').item(0); |
69 | if(t) { | 69 | if(t) { |
70 | this.owner.nsid=t.getAttribute('nsid'); | 70 | this.owner.nsid=t.getAttribute('nsid'); |
71 | this.owner.username=t.getAttribute('username'); | 71 | this.owner.username=t.getAttribute('username'); |
72 | this.owner.realname=t.getAttribute('realname'); | 72 | this.owner.realname=t.getAttribute('realname'); |
73 | this.owner.location=t.getAttribute.location; | 73 | this.owner.location=t.getAttribute.location; |
74 | } | 74 | } |
75 | t = n.getElementsByTagName('description').item(0); | 75 | t = n.getElementsByTagName('description').item(0); |
76 | if(t && t.firstChild) { | 76 | if(t && t.firstChild) { |
77 | this.description = t.firstChild.nodeValue; | 77 | this.description = t.firstChild.nodeValue; |
78 | } | 78 | } |
79 | // TODO: visibility/@ispublic visibility/@isfriend visibility/@isfamily | 79 | // TODO: visibility/@ispublic visibility/@isfriend visibility/@isfamily |
80 | // TODO: dates/@posted dates/@taken dates/@takengranularity dates/@lastupdate | 80 | // TODO: dates/@posted dates/@taken dates/@takengranularity dates/@lastupdate |
81 | // TODO: permissions/@permcomment permsiions/@permaddmeta | 81 | // TODO: permissions/@permcomment permsiions/@permaddmeta |
82 | // TODO: editability/@canaddcomment editability/@canaddmeta | 82 | // TODO: editability/@canaddcomment editability/@canaddmeta |
83 | // TODO: comments | 83 | // TODO: comments |
84 | // TODO: notes/note/@id notes/note/@author notes/note/@authorname | 84 | // TODO: notes/note/@id notes/note/@author notes/note/@authorname |
85 | // TODO: notes/note/@x notes/note/@y notes/note/@w notes/note/@h | 85 | // TODO: notes/note/@x notes/note/@y notes/note/@w notes/note/@h |
86 | // TODO: notes/note | 86 | // TODO: notes/note |
87 | // TODO: tags/tag/@id tags/tag/@author tags/tag/@raw tags/tag | 87 | // TODO: tags/tag/@id tags/tag/@author tags/tag/@raw tags/tag |
88 | // TODO: urls/url/@type urls/url | 88 | // TODO: urls/url/@type urls/url |
89 | } | 89 | } |
90 | }; | 90 | }; |
91 | 91 | ||
92 | function Flickr() { } | 92 | function Flickr() { } |
93 | Flickr.prototype = { | 93 | Flickr.prototype = { |
94 | 94 | ||
95 | rest_url: 'http://www.flickr.com/services/rest/', | 95 | rest_url: 'http://www.flickr.com/services/rest/', |
96 | auth_url: 'http://flickr.com/services/auth/', | 96 | auth_url: 'http://flickr.com/services/auth/', |
97 | photo_url: 'http://static.flickr.com/', | 97 | photo_url: 'http://static.flickr.com/', |
98 | photos_url: 'http://www.flickr.com/photos/', | 98 | photos_url: 'http://www.flickr.com/photos/', |
99 | upload_url: 'http://www.flickr.com/services/upload/', | 99 | upload_url: 'http://www.flickr.com/services/upload/', |
100 | uploader_edit_url: 'http://www.flickr.com/tools/uploader_edit.gne', | ||
100 | 101 | ||
101 | api_sig: function(paramstr) { | 102 | api_sig: function(paramstr) { |
102 | return MD5(toutf8(this.api_shs+paramstr)); | 103 | return MD5(toutf8(this.api_shs+paramstr)); |
103 | }, | 104 | }, |
104 | api_call_url: function(params,url) { | 105 | api_call_url: function(params,url) { |
105 | params.api_key = this.api_key; | 106 | params.api_key = this.api_key; |
106 | var pp = new Array(); | 107 | var pp = new Array(); |
107 | for(var p in params) { | 108 | for(var p in params) { |
108 | pp.push(p); | 109 | pp.push(p); |
109 | } | 110 | } |
110 | var pstr = ''; | 111 | var pstr = ''; |
111 | var rv = (url?url:this.rest_url)+'?'; | 112 | var rv = (url?url:this.rest_url)+'?'; |
112 | for(var p in pp.sort()) { | 113 | for(var p in pp.sort()) { |
113 | var pn = pp[p]; | 114 | var pn = pp[p]; |
114 | pstr += pn+params[pn]; | 115 | pstr += pn+params[pn]; |
115 | rv += pn+'='+params[pn]+'&'; | 116 | rv += pn+'='+params[pn]+'&'; |
116 | } | 117 | } |
117 | rv += 'api_sig='+this.api_sig(pstr); | 118 | rv += 'api_sig='+this.api_sig(pstr); |
118 | return rv; | 119 | return rv; |
119 | }, | 120 | }, |
120 | api_call: function(params, on_success, on_failure) { | 121 | api_call: function(params, on_success, on_failure) { |
121 | if(params.auth_token == 'default') | 122 | if(params.auth_token == 'default') |
122 | params.auth_token = this.token; | 123 | params.auth_token = this.token; |
123 | var x = new XMLHttpRequest(); | 124 | var x = new XMLHttpRequest(); |
124 | x.open("GET",this.api_call_url(params)); | 125 | x.open("GET",this.api_call_url(params)); |
125 | x.onreadystatechange=function() { | 126 | x.onreadystatechange=function() { |
126 | if(x.readyState!=4) return false; | 127 | if(x.readyState!=4) return false; |
127 | if(x.status==200) { | 128 | if(x.status==200) { |
128 | var stat = x.responseXML.firstChild.getAttribute('stat'); | 129 | var stat = x.responseXML.firstChild.getAttribute('stat'); |
129 | if(stat=='ok') { | 130 | if(stat=='ok') { |
130 | if(on_success) on_success(x); | 131 | if(on_success) on_success(x); |
131 | }else{ | 132 | }else{ |
@@ -246,64 +247,68 @@ Flickr.prototype = { | |||
246 | return rv; | 247 | return rv; |
247 | }, | 248 | }, |
248 | get_image_url: function(o,sfx) { | 249 | get_image_url: function(o,sfx) { |
249 | return this.get_photo_url( | 250 | return this.get_photo_url( |
250 | o.server, | 251 | o.server, |
251 | (o instanceof Photoset)? o.primary : o.id, | 252 | (o instanceof Photoset)? o.primary : o.id, |
252 | o.secret, | 253 | o.secret, |
253 | sfx, | 254 | sfx, |
254 | (sfx=='o')?o.originalformat:null | 255 | (sfx=='o')?o.originalformat:null |
255 | ); | 256 | ); |
256 | }, | 257 | }, |
257 | get_photo_page_url: function(p) { | 258 | get_photo_page_url: function(p) { |
258 | if(p instanceof Photo) { | 259 | if(p instanceof Photo) { |
259 | // TODO: track photoset and user owner id from there? | 260 | // TODO: track photoset and user owner id from there? |
260 | // The approach below is sheerly wrong. | 261 | // The approach below is sheerly wrong. |
261 | var o = this.user.nsid; | 262 | var o = this.user.nsid; |
262 | if(p.owner && p.owner.nsid) o = p.owner.nsid; | 263 | if(p.owner && p.owner.nsid) o = p.owner.nsid; |
263 | var rv = this.photos_url + o +'/' + p.id; | 264 | var rv = this.photos_url + o +'/' + p.id; |
264 | return rv; | 265 | return rv; |
265 | }else // TODO: take owner into account? | 266 | }else // TODO: take owner into account? |
266 | return this.photos_url + this.user.nsid + '/' + p; | 267 | return this.photos_url + this.user.nsid + '/' + p; |
267 | }, | 268 | }, |
268 | make_photo_url: function(p,sfx) { | 269 | make_photo_url: function(p,sfx) { |
269 | if(sfx=='p') | 270 | if(sfx=='p') |
270 | return this.get_photo_page_url(p); | 271 | return this.get_photo_page_url(p); |
271 | else | 272 | else |
272 | return this.get_image_url(p,sfx); | 273 | return this.get_image_url(p,sfx); |
273 | }, | 274 | }, |
274 | make_photoset_url: function(ps) { | 275 | make_photoset_url: function(ps) { |
275 | // TODO: allow for using someone else's photoset? | 276 | // TODO: allow for using someone else's photoset? |
276 | return this.photos_url+this.user.nsid+'/sets/'+ps.id; | 277 | return this.photos_url+this.user.nsid+'/sets/'+ps.id; |
277 | }, | 278 | }, |
279 | make_uploader_edit_url: function(pid) { | ||
280 | // TODO: handle arrays | ||
281 | return this.uploader_edit_url+'?ids='+pid; | ||
282 | }, | ||
278 | 283 | ||
279 | upload_file: function(f,fa,on_success,on_failure) { | 284 | upload_file: function(f,fa,on_success,on_failure) { |
280 | try { | 285 | try { |
281 | var fi = Components.classes["@mozilla.org/file/local;1"] | 286 | var fi = Components.classes["@mozilla.org/file/local;1"] |
282 | .createInstance(Components.interfaces.nsILocalFile); | 287 | .createInstance(Components.interfaces.nsILocalFile); |
283 | fi.initWithPath( f ); | 288 | fi.initWithPath( f ); |
284 | var st = Components.classes["@mozilla.org/network/file-input-stream;1"] | 289 | var st = Components.classes["@mozilla.org/network/file-input-stream;1"] |
285 | .createInstance(Components.interfaces.nsIFileInputStream); | 290 | .createInstance(Components.interfaces.nsIFileInputStream); |
286 | st.init(fi,0x01,00004,null); | 291 | st.init(fi,0x01,00004,null); |
287 | var bis = Components.classes["@mozilla.org/binaryinputstream;1"] | 292 | var bis = Components.classes["@mozilla.org/binaryinputstream;1"] |
288 | .createInstance(Components.interfaces.nsIBinaryInputStream); | 293 | .createInstance(Components.interfaces.nsIBinaryInputStream); |
289 | bis.setInputStream(st); | 294 | bis.setInputStream(st); |
290 | 295 | ||
291 | // allocate and initialize temp storage string | 296 | // allocate and initialize temp storage string |
292 | var pbs = Components.classes["@mozilla.org/storagestream;1"] | 297 | var pbs = Components.classes["@mozilla.org/storagestream;1"] |
293 | .createInstance(Components.interfaces.nsIStorageStream); | 298 | .createInstance(Components.interfaces.nsIStorageStream); |
294 | pbs.init(1024,10000000,null); | 299 | pbs.init(1024,10000000,null); |
295 | // create output stream | 300 | // create output stream |
296 | var pbos = pbs.getOutputStream(0); | 301 | var pbos = pbs.getOutputStream(0); |
297 | // and a binaryoutputstream interface | 302 | // and a binaryoutputstream interface |
298 | var pbbos = Components.classes["@mozilla.org/binaryoutputstream;1"] | 303 | var pbbos = Components.classes["@mozilla.org/binaryoutputstream;1"] |
299 | .createInstance(Components.interfaces.nsIBinaryOutputStream); | 304 | .createInstance(Components.interfaces.nsIBinaryOutputStream); |
300 | pbbos.setOutputStream(pbos); | 305 | pbbos.setOutputStream(pbos); |
301 | 306 | ||
302 | /* create POST body */ | 307 | /* create POST body */ |
303 | var boundarytoken = 'kadaroloongazaduviaxamma'; | 308 | var boundarytoken = 'kadaroloongazaduviaxamma'; |
304 | var boundary = '--'+boundarytoken; | 309 | var boundary = '--'+boundarytoken; |
305 | var b = ''; | 310 | var b = ''; |
306 | 311 | ||
307 | var parms = { api_key: this.api_key, auth_token: this.token }; | 312 | var parms = { api_key: this.api_key, auth_token: this.token }; |
308 | for(var p in fa) parms[p] = fa[p]; | 313 | for(var p in fa) parms[p] = fa[p]; |
309 | var pns = new Array(); | 314 | var pns = new Array(); |