Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- ;Requires API key ! See more at https://www.omdbapi.com/apikey.aspx
- ;%%%%%%%%%%%%%%%%%%%%%%%%%%%%
- ;script !imdb Script
- ;version 23.May.2017
- ;author mruno
- ;email mruno@ircN.org
- ;%%%%%%%%%%%%%%%%%%%%%%%%%%%%
- ;23.May.2017 - added movie year support and added api key support. get a key at http://www.omdbapi.com/
- ;this version of imdb does NOT have actor search or recommended movies
- ;Paste your API key below. Do not share your API key.
- alias omdb.api.key return ENTER_YOUR_API_KEY_HERE
- ;max results when user is searching
- alias -l imdb2.max.results return 3
- ;for colors, set to 1
- alias -l imdb2.colors return 1
- ;------------------------------------------------------------------
- on *:TEXT:*:#: {
- if ($chr(37) isin $1-) || ($chr(36) isin $1-) return
- if ($1 == !imdb) || ($1 == !imdb2) {
- if (!$findtok(%imdb2,$nick,0,46)) {
- set -u10 %imdb2 $addtok(%imdb2,$nick,46)
- var %h imdb2
- if ($hget(%a)) hfree %h
- h %h chan $chan
- h %h cid $cid
- h %h nick $nick
- h %h network $network
- imdb2 $nick $2-
- }
- else .timerimdb2. $+ $nick 1 1 .notice $nick Please wait 10 seconds and try again...
- }
- elseif (*imdb.com/title/tt*/* iswm $1-) {
- var %url $1-
- var %tt $gettok(%url,$calc($findtok(%url,title,47) + 1),47)
- if (tt isin %tt) {
- if (!$findtok(%imdb2,$nick,0,46)) {
- set -u10 %theatre $addtok(%imdb2,$nick,46)
- var %h imdb2
- if ($hget(%a)) hfree %a
- h %h chan $chan
- h %h cid $cid
- h %h nick $nick
- h %h network $network
- h %h code %tt
- imdb2 $nick %tt
- }
- }
- }
- }
- on *:INPUT:#:{
- if ($1 == !imdb) || ($1 == !imdb2) {
- var %a = imdb2
- if ($hget(%a)) hfree %a
- h %a chan $chan
- h %a network $network
- h %a cid $cid
- h %a nick $me
- imdb2 $me $2-
- }
- }
- alias imdb2.TIMEOUT {
- dualcmd Connection to imdb.com has timed out. Try again later.
- imdb2.gclean
- }
- alias -l iMDbhelp {
- if (!$h(imdb2,nick)) return
- .notice $h(imdb2,nick) iMdb by mruno - Options:
- .notice $h(imdb2,nick) !imdb <keywords>
- .notice $h(imdb2,nick) Not the one you want? Try !imdb -s <keywords>
- }
- alias imdb2 {
- var %h imdb2
- if (!$2) { imdbhelp $1 | return }
- if ($2 == -s) || ($2 == -l) && (!$3) { imdbhelp $1 | return }
- elseif ($left($2,2) == -l) || ($left($2,2) == -s) {
- var %text $3-
- var %spaces $gettok(%text,0,32)
- var %end $gettok(%text,%spaces,32), %year
- if ($len(%end) == 4) && (%end isnum) {
- if ($left(%end,2) == 19) || ($left(%end,2) == 20) {
- set %year %end
- set %text $gettok(%text,1 - $calc(%spaces - 1),32)
- }
- }
- .timerimdb2.timeout 0 45 imdb2.TIMEOUT
- var %a, %b, %p, %u, %o, %query
- if ($left($3,2) == tt) && ($remove($3,tt,/) isnum) {
- h %h query code
- h %h jsonurl $+(http://www.omdbapi.com/?apikey=,$omdb.api.key,&i=,$remove(%text,$chr(32)),&y=,$iif(%year,%year),&plot=short&r=json)
- imdb2.search.single
- }
- else {
- h %h query multiple
- h %h jsonurl $+(http://www.omdbapi.com/?apikey=,$omdb.api.key,&s=,$replace(%text,$chr(32),+),&y=,$iif(%year,%year),&plot=short&r=json)
- imdb2.search.multiple
- }
- set %query $replace($3-,$chr(32),+,.,+,-,+)
- set %query $remove(%query,<,>)
- h %h text %query
- }
- else {
- .timerimdb2.timeout 0 45 imdb2.TIMEOUT
- var %a, %b, %p, %u, %o, %query
- set %query $replace($2-,$chr(32),+,.,+,-,+)
- set %query $remove(%query,<,>)
- h %h text %query
- var %text %query
- var %spaces $gettok(%text,0,43)
- var %end $gettok(%text,%spaces,43), %year
- if ($len(%end) == 4) && (%end isnum) {
- if ($left(%end,2) == 19) || ($left(%end,2) == 20) {
- set %year %end
- set %text $gettok(%text,1 - $calc(%spaces - 1),43)
- }
- }
- if ($left($2,2) == tt) && ($remove($2,tt,/) isnum) {
- h %h query code
- h %h jsonurl $+(http://www.omdbapi.com/?apikey=,$omdb.api.key,&i=,%text,&y=,$iif(%year,%year),&plot=short&r=json)
- }
- else {
- h %h query single
- h %h jsonurl $+(http://www.omdbapi.com/?apikey=,$omdb.api.key,&t=,%text,&y=,$iif(%year,%year),&plot=short&r=json)
- }
- imdb2.search.single
- }
- .notice $h(imdb2,nick) Querying imdb.com...
- }
- alias -l imdb2.search.multiple {
- ;searches for a title and returns multiple results
- var %h imdb2
- imdb2.Json
- .timerimdb2.Waiting.to.Query 0 1 imdb2.Get.Multiple.Query
- }
- alias -l imdb2.Get.Multiple.Query {
- ; called by imdb2.Search.Multiple to record multiple shows' information
- var %h imdb2
- if (!%imdb2.num) set %imdb2.num 1
- else inc %imdb2.num
- if (%imdb2.num > 3) {
- unset %imdb2.num
- if ($hget(imdb2,query.type) == id) .timerimdb2.repeat -m 1 500 imdb2.Json
- else .timerimdb2.repeat -m 1 500 imdb2.Json
- }
- var %response $json(imdb2,Response)
- if (%response != False) {
- var %total 0
- var %i 0
- while ($json(imdb2,Search,%i,Title)) {
- inc %total
- if (%total > 10) break
- h %h title. $+ %i $json(imdb2,Search,%i,Title)
- h %h year. $+ %i $replace($json(imdb2,Search,%i,Year),–,-)
- h %h type. $+ %i $json(imdb2,Search,%i,Type)
- h %h id. $+ %i $json(imdb2,Search,%i,imdbID)
- inc %i
- }
- }
- else h %h Error $json(imdb2,Error)
- .timerimdb2.Waiting.to.Query off
- if (!$hget(imdb2,Waiting)) imdb2.Complete
- }
- alias -l imdb2.search.single {
- ;searches for a title or code and returns a single result
- var %h imdb2
- imdb2.Json
- .timerimdb2.Waiting.to.Query 0 1 imdb2.Get.Single.Query
- }
- alias imdb2.Get.Single.Query {
- ; called by imdb2.Search.Single to record a single search show's information
- var %h imdb2
- if (!%imdb2.num) set %imdb2.num 1
- else inc %imdb2.num
- if (%imdb2.num > 3) {
- unset %imdb2.num
- if ($hget(imdb2,query.type) == id) .timerimdb2.repeat -m 1 500 imdb2.Json
- else .timerimdb2.repeat -m 1 500 imdb2.Json
- }
- var %response $json(imdb2,Response)
- if (%response == True) {
- h %h Title $json(imdb2,Title)
- h %h Year $replace($json(imdb2,Year),–,-)
- h %h Rated $json(imdb2,Rated)
- h %h Released $json(imdb2,Released)
- h %h Genre $json(imdb2,Genre)
- h %h Runtime $json(imdb2,Runtime)
- h %h imdbRating $json(imdb2,imdbRating)
- h %h Network $json(imdb2,network,Network)
- h %h Country $json(imdb2,Country)
- h %h Director $json(imdb2,Director)
- h %h Writer $json(imdb2,Writer)
- h %h Actors $json(imdb2,Actors)
- h %h Plot $json(imdb2,Plot)
- h %h Language $json(imdb2,Language )
- h %h Type $json(imdb2,Type)
- h %h Awards $json(imdb2,Awards)
- h %h ID $json(imdb2,imdbID)
- }
- else h %h Error $json(imdb2,Error)
- .timerimdb2.Waiting.to.Query off
- if (!$hget(imdb2,Waiting)) imdb2.Complete
- }
- alias -l IMDB2.COMPLETE {
- ;this alias produces the text
- var %h imdb2
- if ($h(%h,Error)) {
- dualcmd Error, $ifmatch Try using less keywords.
- }
- else {
- if ($h(%h,query) == multiple) {
- var %nick $h(%h,nick)
- if (!%nick) { .timer 1 1 imdb2.gclean | return }
- var %total 0
- var %i 0
- while ($h(%h,title. $+ %i)) {
- inc %total
- if (%total > $imdb2.max.results) break
- .notice %nick $h(%h,title. $+ %i) $paren($h(%h,year. $+ %i)) - Type: $h(%h,type. $+ %i) - ID: $h(%h,id. $+ %i)
- inc %i
- }
- .notice %nick Type !imdb <ID> to lookup a specific title. Example: !imdb tt1520211
- }
- else {
- var %url http://www.imdb.com/title/ $+ $h(%h,ID)
- if ($imdb2.colors) var %logo 1,8[iMDb]
- else var %logo [iMDb]
- dualcmd %logo $h(%h,title) $+ $paren($h(%h,year)) $chr(40) 12 $+ %url $+ $chr(41)
- dualcmd $iif($h(%h,rating),Rated: $h(%h,rating)) $iif($h(%h,released) && $h(%h,released) != N/A,Released: $h(%h,released)) $iif($h(%h,runtime) && $h(%h,runtime) != N/A,Runtime: $h(%h,runtime)) $iif($h(%h,genre),Genre: $h(%h,genre))
- dualcmd $iif($h(%h,director) && $h(%h,director) != N/A,Director: $h(%h,director)) $iif($h(%h,actors) && $h(%h,actors) != N/A,Cast: $h(%h,actors))
- dualcmd $iif($h(%h,plot),Plot: $h(%h,Plot))
- var %r
- if ($h(%h,imdbrating) isnum) set %r $h(%h,imdbrating)
- if (%r) dualcmd Rating: $chr(91) $+ $iif(%r > .55,12,) $+ * $+ $iif(%r > 1.55,12,) $+ * $+ $iif(%r > 2.55,12,) $+ * $+ $iif(%r > 3.55,12,) $+ * $+ $iif(%r > 4.55,12,) $+ * $+ $iif(%r > 5.55,12,) $+ * $+ $iif(%r > 6.55,12,) $+ * $+ $iif(%r > 7.55,12,) $+ * $+ $iif(%r > 8.55,12,) $+ * $+ $iif(%r > 9.55,12,) $+ *] %r $+ /10
- else dualcmd Rating: none
- var %nick $h(%h,nick)
- if (!%nick) { .timer 1 1 imdb2.gclean | return }
- if ($h(%h,query) != code) .notice %nick Not the right movie or show? Try !imdb -s $replace($h(%h,text),+,$chr(32))
- }
- }
- imdb2.gclean
- }
- alias -l imdb2.results {
- if (!$h(imdb2,code)) { echo -st 4ERROR! imdb no code: $h(imdb2,code) | return }
- imdb2.Json
- .timerimdb2.Waiting.to.Query 0 1 imdb2.Get.Single.Query %name %query
- }
- alias imdb2.Query.Single {
- ;/imdb2.Query.Single channel nickname query
- ;this returns a single show's results
- set %query $+(http://www.omdbapi.com/?apikey=,$omdb.api.key,&i=,$h(imdb2,code),&plot=short&r=json)
- h imdb2 query $+(http://www.omdbapi.com/?apikey=,$omdb.api.key,&i=,$h(imdb2,code),&plot=short&r=json)
- imdb2.Json
- .timerimdb2.Waiting.to.Query 0 1 imdb2.Get.Single.Query imdb2 %query
- }
- alias imdb2.Get.Single.Query {
- ; called by imdb2.Query.Single to record a single search show's information
- if (!%imdb2.num) set %imdb2.num 1
- else inc %imdb2.num
- if (%imdb2.num > 3) {
- unset %imdb2.num
- if ($hget(imdb2,query.type) == id) .timerimdb2.repeat -m 1 500 imdb2.Json imdb2
- else .timerimdb2.repeat -m 1 500 imdb2.Json
- }
- var %title $json(imdb2,Title)
- if (%title) {
- h imdb2 Title %title
- h imdb2 Year $replace($json(imdb2,Year),–,-)
- h imdb2 Rated $json(imdb2,Rated)
- h imdb2 Released $json(imdb2,Released)
- h imdb2 Genre $json(imdb2,Genre)
- h imdb2 Runtime $json(imdb2,Runtime)
- h imdb2 imdbRating $json(imdb2,imdbRating)
- h imdb2 Network $json(imdb2,network,Network)
- h imdb2 Country $json(imdb2,Country)
- h imdb2 Director $json(imdb2,Director)
- h imdb2 Writer $json(imdb2,Writer)
- h imdb2 Actors $json(imdb2,Actors)
- h imdb2 Plot $json(imdb2,Plot)
- h imdb2 Language $json(imdb2,Language )
- h imdb2 Type $json(imdb2,Type)
- var %genres
- var %i 0
- while (%i < 5) {
- if ($json(%name,genres,%i)) set %genres $addtok(%genres,$ifmatch,44)
- inc %i
- }
- h imdb2 genres %genres
- .timerimdb2.Waiting.to.Query off
- if (!$hget(imdb2,Waiting)) .timerimdb2.Complete 1 1 imdb2.Complete
- }
- }
- alias imdb2.Json JSONOpen -u imdb2 $h(imdb2,jsonurl)
- alias -l h {
- if ($1 == isnum) return
- if (!$2) { echo -a error: no 2 for hash table | return }
- if (!$hget($1)) hmake $1
- if ($isid) return $hget($1,$2)
- else hadd $1 $2-
- }
- alias -l dualcmd {
- if ($1) {
- if ($me ison $h(imdb2,chan)) msg $h(imdb2,chan) $iif($imdb2.colors,$1-,$strip($1-))
- }
- }
- alias -l paren {
- if ($3) return $2 $+ $1 $+ $3
- elseif ($2) return $2 $+ $1 $+ $2
- elseif ($1 != $null) return ( $+ $1- $+ )
- }
- alias imdb2.gclean {
- ;this removes the hash tables that were used
- if ($hget(imdb2)) hfree $ifmatch
- unset %imdb2*
- jsonclose imdb2
- .timerimdb2.timeout off
- }
- on 1:UNLOAD:imdb2.gclean
- ;JSON for MIRC By SReject
- ;http://hawkee.com/snippet/10194/
- alias -l JSONOpen {
- var %switches = -
- if (-* iswm $1) {
- %switches = $1
- tokenize 32 $2-
- }
- var %com = JSONHandler:: $+ $1, %error, %file, %rem
- var %init = function init(a,b){errortext="";data="";url=b ? b : "";method="GET";headers=[];parsedJSON={};status=a;fso=new ActiveXObject("Scripting.FileSystemObject")}
- var %read = function readFile(filename){var ado=new ActiveXObject("ADODB.Stream");ado.CharSet="utf-8";ado.Open();ado.LoadFromFile(filename);if(!ado.EOF){data=ado.ReadText();}ado.close()}
- var %json = "object"!==typeof JSON&&(JSON={});(function(){function m(a){return 10>a?"0"+a:a}function t(a){p.lastIndex=0;return p.test(a)?'"'+a.replace(p,function(a){var c=u[a];return"string"===typeof c?c:"\\u"+("0000"+a.charCodeAt(0).toString(16)).slice(-4)})+'"':'"'+a+'"'}function q(a,l){var c,d,h,r,g=e,f,b=l[a];b&&"object"===typeof b&&"function"===typeof b.toJSON&&(b=b.toJSON(a));"function"===typeof k&&(b=k.call(l,a,b));switch(typeof b){case "string":return t(b);case "number":return isFinite(b)?String(b):"null";case "boolean":case "null":return String(b);case "object":if(!b)return"null";e+=n;f=[];if("[object Array]"===Object.prototype.toString.apply(b)){r=b.length;for(c=0;c<r;c+=1)f[c]=q(c,b)||"null";h=0===f.length?"[]":e?"[\n"+e+f.join(",\n"+e)+"\n"+g+"]":"["+f.join(",")+"]";e=g;return h}if(k&&"object"===typeof k)for(r=k.length,c=0;c<r;c+=1)"string"===typeof k[c]&&(d=k[c],(h=q(d,b))&&f.push(t(d)+(e?": ":":")+h));else for(d in b)Object.prototype.hasOwnProperty.call(b,d)&&(h=q(d,b))&&f.push(t(d)+(e?": ":":")+h);h=0===f.length?"{}":e?"{\n"+e+f.join(",\n"+e)+"\n"+g+"}":"{"+f.join(",")+"}";e=g;return h}}"function"!==typeof Date.prototype.toJSON&&(Date.prototype.toJSON=function(){return isFinite(this.valueOf())?this.getUTCFullYear()+"-"+m(this.getUTCMonth()+1)+"-"+m(this.getUTCDate())+"T"+m(this.getUTCHours())+":"+m(this.getUTCMinutes())+":"+m(this.getUTCSeconds())+"Z":null},String.prototype.toJSON=Number.prototype.toJSON=Boolean.prototype.toJSON=function(){return this.valueOf()});var s,p,e,n,u,k;"function"!==typeof JSON.stringify&&(p=/[\\\"\x00-\x1f\x7f-\x9f\u00ad\u0600-\u0604\u070f\u17b4\u17b5\u200c-\u200f\u2028-\u202f\u2060-\u206f\ufeff\ufff0-\uffff]/g,u={"\b":"\\b","\t":"\\t","\n":"\\n","\f":"\\f","\r":"\\r",'"':'\\"',"\\":"\\\\"},JSON.stringify=function(a,l,c){var d;n=e="";if("number"===typeof c)for(d=0;d<c;d+=1)n+=" ";else"string"===typeof c&&(n=c);if((k=l)&&"function"!==typeof l&&("object"!==typeof l||"number"!==typeof l.length))throw Error("JSON.stringify");return q("",{"":a})});"function"!==typeof JSON.parse&&(s=/[\u0000\u00ad\u0600-\u0604\u070f\u17b4\u17b5\u200c-\u200f\u2028-\u202f\u2060-\u206f\ufeff\ufff0-\uffff]/g,JSON.parse=function(a,e){function c(a,d){var g,f,b=a[d];if(b&&"object"===typeof b)for(g in b)Object.prototype.hasOwnProperty.call(b,g)&&(f=c(b,g),void 0!==f?b[g]=f:delete b[g]);return e.call(a,d,b)}var d;a=String(a);s.lastIndex=0;s.test(a)&&(a=a.replace(s,function(a){return"\\u"+("0000"+a.charCodeAt(0).toString(16)).slice(-4)}));if(/^[\],:{}\s]*$/.test(a.replace(/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g,"@").replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g,"]").replace(/(?:^|:|,)(?:\s*\[)+/g,"")))return d=eval("("+a+")"),"function"===typeof e?c({"":d},""):d;throw new SyntaxError("JSON.parse");})})();
- var %xhr = function xhr(){var a,b=['MSXML2.XMLHTTP.6.0','MSXML2.XMLHTTP.3.0','Microsoft.XMLHTTP'],c;for(a=0;a<b.length;a++){try{c=new ActiveXObject(b[a]);break}catch(e){}}if(typeof c==="undefined"){errortext = "Unable to locate an XMLHTTP object for use"}else{c.open(method,url,false);for(a=0;a<headers.length;a++){c.setRequestHeader(headers[a][0],headers[a][1])}c.send(data);if(c.status!==200){errortext="Unable to retrieve data - Server Error: " + c.status}else{status="Parsed";try{parsedJSON=JSON.parse(c.responseText)}catch(ee){errortext="Unable to parse Retrieved Data"}}}}
- if (!$regex(%switches, /^-[ufbwd]*$/)) {
- %error = Invalid switches specified
- }
- elseif ($regex(%switches, /([ufbwd])\1/)) {
- %error = Duplicate switch specified ( $+ $regml(1) $+ )
- }
- elseif ($regex(%switches, /([ufb])/g) > 1) {
- %error = Conflicting switches specified (- $+ $regml(1) $+ , - $+ $regml(2) $+ $iif($regml(3), $chr(44) - $+ $v1) $+ )
- }
- elseif (w isin %switches && u !isin %switches) {
- %error = Invalid switch (-w is only for use with -u)
- }
- elseif ($0 < 2) {
- %error = Required parameters missing
- }
- elseif (!$regex($1,/^[a-z\d_.-]+$/i)) {
- %error = Invalid name specified (Can only contant letters, numbers, _, ., and -)
- }
- elseif ($com(%com)) {
- %error = Specified name in use
- }
- elseif (u isin %switches && $0 > 2) {
- %error = Invalid URL specified. (Contains Spaces: $2-)
- }
- elseif (f isin %switches && !$isfile($2-)) {
- %error = File not found: $2-
- }
- elseif (b isin %switches && &* !iswm $2) {
- %error = Invalid binary variable specified (No '&' Prefix)
- }
- elseif (b isin %switches && $0 > 2) {
- %error = Invalid binary variable specified (Contains Spaces: $2-)
- }
- elseif (b isin %switches && $bvar($2, 0) < 1) {
- %error = Invalid binary variable specified (No content)
- }
- elseif (!$JSON::ComOpen(%com, MSScriptControl.ScriptControl) || $comerr) {
- %error = Unable to create an instance of MSScriptControl.ScriptControl
- }
- elseif (!$com(%com, language, 4, bstr, jscript) || $comerr) {
- %error = Unable to set ScriptControl's language to Javascript
- }
- elseif (!$com(%com, addcode, 1, bstr, %init) || $comerr) {
- %error = Unable to add init() to ScriptControl
- }
- elseif (!$com(%com, addcode, 1, bstr, %xhr) || $comerr) {
- %error = Unable to add xhr() to ScriptControl
- }
- elseif (!$com(%com, addcode, 1, bstr, %read) || $comerr) {
- %error = Unable to add readFile() to ScriptControl
- }
- elseif (!$com(%com, ExecuteStatement, 1, bstr, %JSON) || $comerr) {
- %error = Unable to Initalize the JSON parser object
- }
- elseif (!$com(%com, ExecuteStatement, 1, bstr, $iif(u isin %switches, $+(init,$chr(40), "XHR", $chr(44), $qt($JSON::Escape($2)),$chr(41)), $+(init,$chr(40), "Parsed", $chr(44), "", $chr(41)))) || $comerr) {
- %error = Unable to initalize variables for ScriptControl
- }
- else {
- if (u isin %switches) {
- if (w !isin %switches) {
- var %i = $com(%com, ExecuteStatement, 1, bstr, $+(xhr,$chr(40),$chr(41)))
- if (!%i || $comerr) {
- %error = Unable to retrieve data from $2 :: $com(%com).error :: $com(%com).errortext
- }
- elseif (!$com(%com, eval, 1, bstr, errortext) || $com(%com).result) {
- %error = Unable to retrieve data $+ $iif($v1,: $v1,)
- }
- }
- }
- else {
- %file = $JSON::File($1)
- if (f isin %switches) {
- %file = $longfn($2)
- }
- elseif (b isin %switches) {
- bwrite $qt(%file) 0 -1 $2
- %rem = $true
- }
- else {
- write -n $qt(%file) $2-
- %rem = $true
- }
- if (!$com(%com, ExecuteStatement, 1, bstr, $JSON::Funct(readFile, $qt($JSON::Escape(%file)))) || $comerr) {
- %error = Unable to read contents of data-passing file
- }
- elseif (!$com(%com, ExecuteStatement, 1, bstr, $JSON::Funct(parsedJSON=JSON.parse,data)) || $comerr) {
- %error = Unable to parse data into valid JSON
- }
- }
- if (d isin %switches) {
- $+(.timer,%com) 1 0 JSONClose $1
- }
- }
- :error
- %error = $iif($error, $v1, %error)
- if (%rem && %file && $isfile(%file)) {
- .remove $qt(%file)
- }
- if (%error) {
- if ($timer(%com)) { $+(.timer,%com) off }
- if ($com(%com)) {
- set -eu0 $+(%,%com,::error) %error
- .comclose $v1
- }
- else {
- set -eu0 %JSONError %error
- }
- }
- }
- alias -l JSONURLOption {
- var %com = JSONHandler:: $+ $1, %error, %head, %value, %x = 2
- if (!$com(%com)) {
- return
- }
- unset % [ $+ [ %com ] $+ ] ::error
- if ($0 < 3) {
- %error = Missing parameters
- }
- elseif (!$com(%com, eval, 1, bstr, status) || $com(%com).result != XHR) {
- %error = HTTP Request already completed or wasn't specified
- }
- elseif ($2 == method) {
- if (!$regex($3-, /^(?:GET|POST|PUT|DELETE)$/i)) {
- %error = Invalid HTTP Request method Specified: $3-
- }
- elseif (!$com(%com, ExecuteStatement, 1, bstr, method=" $+ $3 $+ ") || $comerr) {
- %error = Unable to set HTTP Request method
- }
- }
- else {
- if (!$com(%com, ExecuteStatement, 1, bstr, $JSON::Funct(headers.push,[ $+ $qt($JSON::Escape($2)), $qt($JSON::Escape($3-)) $+ ])) || $comerr) {
- %error = Unable to set HTTP Header: %head $+ : $+ %value
- }
- }
- :error
- %error = $iif($error, $v1, %error)
- if (%error) {
- reseterror
- set -e $+(%,%com,::Error) %error
- }
- }
- alias -l JSONGet {
- var %switches -
- if (-* iswm $1) {
- %switches = $1
- tokenize 32 $2-
- }
- var %com = JSONHandler:: $+ $1
- var %file = $JSON::File($1)
- var %error
- var %rem
- if ($com(%com)) {
- if ($com(%com, eval, 1, bstr, status) && $com(%com).result !== XHR) {
- %error = HTTP Request already completed or wasn't specified
- }
- elseif (!$regex(%switches, /^-[bf]*$/)) {
- %error = Invalid switches specified
- }
- elseif ($regex(%switches, /([bf])\1/)) {
- %error = Duplicate switch specified ( $+ $regml(1) $+ )
- }
- elseif ($regex(%switches, /([bf])/g) > 1) {
- %error = Conflicting switches specified (- $+ $regml(1) $+ , - $+ $regml(2) $+ )
- }
- elseif (b isin %switches && &* !iswm $2) {
- %error = Invalid binary variable specified (No '&' Prefix)
- }
- elseif (b isin %switches && $0 > 2) {
- %error = Invalid binary variable specified (Contains Spaces: $2-)
- }
- elseif (f isin %switches && !$isfile($2-)) {
- %error = File not found: $2-
- }
- else {
- if (b isin %switches && $bvar($2,0)) {
- bwrite $qt(%file) 0 -1 $2
- %rem = $true
- }
- elseif (f isin %switches) {
- %file = $2-
- }
- elseif ($2-) {
- write -n $qt(%file) $2-
- %rem = $true
- }
- %file = $longfn(%file)
- if ($isfile(%file) && (!$com(%com, ExecuteStatement, 1, bstr, $JSON::Funct(readFile,$qt($JSON::Escape(%file)))) || $comerr)) {
- %error = Unable to pass data to JSON Handler
- }
- elseif (!$com(%com, ExecuteStatement, 1, bstr, xhr $+ $chr(40) $+ $chr(41)) || $comerr) {
- %error = Unable to retrieve data from specified URL :: $com(%com).error :: $com(%com).errortext
- }
- elseif (!$com(%com, eval, 1, bstr, errortext) || $com(%com).result) {
- %error = $v1
- }
- if (%rem && $isfile(%file)) { .remove %file }
- }
- }
- :error
- %error = $iif($error, $v1, %error)
- if (%error) {
- reseterror
- set -eu0 $+(%,%com,::Error) %error
- }
- }
- alias -l JSON {
- var %com, %x = 1, %i = 0, %get = parsedJSON, %tok, %res
- if ($regex($1,/^\d+$/) && $0 === 1) {
- while ($com(%x)) {
- if (JSONHandler::* iswm $v1) {
- %com = $v2
- inc %i
- if (%i === $1) { return %com }
- }
- inc %x
- }
- return $iif($1 == 0, %i)
- }
- elseif ($regex($1, /^JSONHandler::CHILD::([^:]+)::(.*)$/)) {
- %com = $regml(1)
- %get = $regml(2)
- }
- else {
- %com = JSONHandler:: $+ $1
- }
- if ($com(%com)) {
- if ($0 == 1) {
- if ($prop == isChild) {
- return $iif($regex($1, /^JSONHandler::CHILD::([^:]+)::(.*)$/), $true, $false)
- }
- elseif ($prop == error) {
- return $iif($(,$+(%,%com,::error)), $true,$false)
- }
- elseif ($prop == errortext) {
- return $(,$+(%,%com,::error))
- }
- elseif ($com($1)) {
- return $1
- }
- }
- elseif (!$com(%com, eval, 1, bstr, status) || $com(%com).result != parsed) {
- set -eu0 $+(%,%com,::error) JSON Handler waiting for HTTP Request
- }
- else {
- %x = 2
- while (%x <= $0) {
- %tok = $(,$ $+ %x)
- if (!$regex(%tok, /^\d+$/)) {
- %tok = $qt($replace(%tok,\,\\,",\"))
- }
- %get = $+(%get,[,%tok,])
- inc %x
- }
- if (!$com(%com, eval, 1, bstr, %get) || $comerr) {
- set -e $+(%,%com,::error) Invalid Item|index specified
- }
- else {
- %res = $com(%com).result
- if (%res == [object]) {
- return JSONHandler::CHILD:: $+ $1 $+ :: $+ %get
- }
- else {
- return %res
- }
- }
- }
- }
- }
- alias -l JSONClose {
- var %com = JSONHandler:: $+ $1
- unset % [ $+ [ %com ] $+ ] ::*
- if ($com(%com)) { .comclose $v1 }
- if ($timer(%com)) { $+(.timer,%com) off }
- }
- alias -l JSONList {
- var %x = 1, %i = 0
- while ($com(%x)) {
- if (JSONHandler::* iswm $v1) {
- inc %i
- echo $color(info text) -a * # $+ %i : $regsubex($v2, /^JSONHandler::/,)
- }
- inc %x
- }
- if (!%i) {
- echo $color(info text) -a * No active JSON handlers
- }
- }
- on *:Start: unset %JSONHandler::*
- alias -l JSON::ComOpen { .comopen $1- | if ($com($1) && !$comerr) { return $true } | :error | reseterror | if ($com($1)) { .comclose $1 } }
- alias -l JSON::Escape { return $replace($1,\,\\,",\") }
- alias -l JSON::File { var %a = 1 | while ($isfile(JSON $+ $1 $+ %a $+ .json)) { inc %a } | return $+(JSON, $1, %a, .json) }
- alias -l JSON::Funct { var %a = $1 $+ $chr(40), %i = 1 | while (%i < $0) { inc %i | %a = $+(%a,$iif(%i > 2,$chr(44)),$(, $ $+ %i)) } | return %a $+ $chr(41) }
Add Comment
Please, Sign In to add comment