corrade-lsl-templates – Diff between revs 41 and 42

Subversion Repositories:
Rev:
Show entire fileIgnore whitespace
Rev 41 Rev 42
Line 1... Line 1...
1 /////////////////////////////////////////////////////////////////////////// 1 ///////////////////////////////////////////////////////////////////////////
2 // Copyright (C) Wizardry and Steamworks 2016 - License: CC BY 2.0 // 2 // Copyright (C) Wizardry and Steamworks 2016 - License: GNU GPLv3 //
3 /////////////////////////////////////////////////////////////////////////// 3 ///////////////////////////////////////////////////////////////////////////
4 // 4 //
5 // A module that unbans group members using fuzzy name matching. 5 // A module that unbans group members using fuzzy name matching.
6 // 6 //
7 /////////////////////////////////////////////////////////////////////////// 7 ///////////////////////////////////////////////////////////////////////////
Line 15... Line 15...
15 list a = llParseStringKeepNulls(data, ["&", "="], []); 15 list a = llParseStringKeepNulls(data, ["&", "="], []);
16 integer i = llListFindList(llList2ListStrided(a, 0, -1, 2), [ k ]); 16 integer i = llListFindList(llList2ListStrided(a, 0, -1, 2), [ k ]);
17 if(i != -1) return llList2String(a, 2*i+1); 17 if(i != -1) return llList2String(a, 2*i+1);
18 return ""; 18 return "";
19 } 19 }
20 20  
21 /////////////////////////////////////////////////////////////////////////// 21 ///////////////////////////////////////////////////////////////////////////
22 // Copyright (C) 2013 Wizardry and Steamworks - License: CC BY 2.0 // 22 // Copyright (C) 2013 Wizardry and Steamworks - License: GNU GPLv3 //
23 /////////////////////////////////////////////////////////////////////////// 23 ///////////////////////////////////////////////////////////////////////////
24 string wasKeyValueEncode(list data) { 24 string wasKeyValueEncode(list data) {
25 list k = llList2ListStrided(data, 0, -1, 2); 25 list k = llList2ListStrided(data, 0, -1, 2);
26 list v = llList2ListStrided(llDeleteSubList(data, 0, 0), 0, -1, 2); 26 list v = llList2ListStrided(llDeleteSubList(data, 0, 0), 0, -1, 2);
27 data = []; 27 data = [];
Line 32... Line 32...
32 } while(llGetListLength(k) != 0); 32 } while(llGetListLength(k) != 0);
33 return llDumpList2String(data, "&"); 33 return llDumpList2String(data, "&");
34 } 34 }
Line 35... Line 35...
35   35  
36 /////////////////////////////////////////////////////////////////////////// 36 ///////////////////////////////////////////////////////////////////////////
37 // Copyright (C) 2011 Wizardry and Steamworks - License: CC BY 2.0 // 37 // Copyright (C) 2011 Wizardry and Steamworks - License: GNU GPLv3 //
38 /////////////////////////////////////////////////////////////////////////// 38 ///////////////////////////////////////////////////////////////////////////
39 // http://was.fm/secondlife/wanderer 39 // http://was.fm/secondlife/wanderer
40 vector wasCirclePoint(float radius) { 40 vector wasCirclePoint(float radius) {
41 float x = llPow(-1, 1 + (integer) llFrand(2)) * llFrand(radius*2); 41 float x = llPow(-1, 1 + (integer) llFrand(2)) * llFrand(radius*2);
Line 44... Line 44...
44 return <x, y, 0>; 44 return <x, y, 0>;
45 return wasCirclePoint(radius); 45 return wasCirclePoint(radius);
46 } 46 }
Line 47... Line 47...
47   47  
48 /////////////////////////////////////////////////////////////////////////// 48 ///////////////////////////////////////////////////////////////////////////
49 // Copyright (C) 2015 Wizardry and Steamworks - License: CC BY 2.0 // 49 // Copyright (C) 2015 Wizardry and Steamworks - License: GNU GPLv3 //
50 /////////////////////////////////////////////////////////////////////////// 50 ///////////////////////////////////////////////////////////////////////////
51 // escapes a string in conformance with RFC1738 51 // escapes a string in conformance with RFC1738
52 string wasURLEscape(string i) { 52 string wasURLEscape(string i) {
53 string o = ""; 53 string o = "";
Line 68... Line 68...
68 } while(i != ""); 68 } while(i != "");
69 return o; 69 return o;
70 } 70 }
Line 71... Line 71...
71   71  
72 /////////////////////////////////////////////////////////////////////////// 72 ///////////////////////////////////////////////////////////////////////////
73 // Copyright (C) 2015 Wizardry and Steamworks - License: CC BY 2.0 // 73 // Copyright (C) 2015 Wizardry and Steamworks - License: GNU GPLv3 //
74 /////////////////////////////////////////////////////////////////////////// 74 ///////////////////////////////////////////////////////////////////////////
75 list wasCSVToList(string csv) { 75 list wasCSVToList(string csv) {
76 list l = []; 76 list l = [];
77 list s = []; 77 list s = [];
Line 107... Line 107...
107 // postcondition: length(s) = 0 107 // postcondition: length(s) = 0
108 return l + m; 108 return l + m;
109 } 109 }
Line 110... Line 110...
110   110  
111 /////////////////////////////////////////////////////////////////////////// 111 ///////////////////////////////////////////////////////////////////////////
112 // Copyright (C) 2015 Wizardry and Steamworks - License: CC BY 2.0 // 112 // Copyright (C) 2015 Wizardry and Steamworks - License: GNU GPLv3 //
113 /////////////////////////////////////////////////////////////////////////// 113 ///////////////////////////////////////////////////////////////////////////
114 string wasListToCSV(list l) { 114 string wasListToCSV(list l) {
115 list v = []; 115 list v = [];
116 do { 116 do {
117 string a = llDumpList2String( 117 string a = llDumpList2String(
118 llParseStringKeepNulls( 118 llParseStringKeepNulls(
119 llList2String( 119 llList2String(
120 l, 120 l,
121 0 121 0
122 ), 122 ),
123 ["\""], 123 ["\""],
124 [] 124 []
125 ), 125 ),
126 "\"\"" 126 "\"\""
127 ); 127 );
128 if(llParseStringKeepNulls( 128 if(llParseStringKeepNulls(
129 a, 129 a,
130 [" ", ",", "\n", "\""], [] 130 [" ", ",", "\n", "\""], []
131 ) != 131 ) !=
132 (list) a 132 (list) a
133 ) a = "\"" + a + "\""; 133 ) a = "\"" + a + "\"";
134 v += a; 134 v += a;
135 l = llDeleteSubList(l, 0, 0); 135 l = llDeleteSubList(l, 0, 0);
136 } while(l != []); 136 } while(l != []);
137 return llDumpList2String(v, ","); 137 return llDumpList2String(v, ",");
Line 138... Line 138...
138 } 138 }
139   139  
140 /////////////////////////////////////////////////////////////////////////// 140 ///////////////////////////////////////////////////////////////////////////
141 // Copyright (C) 2015 Wizardry and Steamworks - License: CC BY 2.0 // 141 // Copyright (C) 2015 Wizardry and Steamworks - License: GNU GPLv3 //
142 /////////////////////////////////////////////////////////////////////////// 142 ///////////////////////////////////////////////////////////////////////////
143 // unescapes a string in conformance with RFC1738 143 // unescapes a string in conformance with RFC1738
144 string wasURLUnescape(string i) { 144 string wasURLUnescape(string i) {
145 return llUnescapeURL( 145 return llUnescapeURL(
146 llDumpList2String( 146 llDumpList2String(
147 llParseString2List( 147 llParseString2List(
148 llDumpList2String( 148 llDumpList2String(
149 llParseString2List( 149 llParseString2List(
150 i, 150 i,
151 ["+"], 151 ["+"],
152 [] 152 []
153 ), 153 ),
154 " " 154 " "
155 ), 155 ),
156 ["%0D%0A"], 156 ["%0D%0A"],
157 [] 157 []
158 ), 158 ),
159 "\n" 159 "\n"
160 ) 160 )
Line 161... Line 161...
161 ); 161 );
162 } 162 }
163   163  
164 /////////////////////////////////////////////////////////////////////////// 164 ///////////////////////////////////////////////////////////////////////////
165 // Copyright (C) 2017 Wizardry and Steamworks - License: CC BY 2.0 // 165 // Copyright (C) 2017 Wizardry and Steamworks - License: GNU GPLv3 //
166 /////////////////////////////////////////////////////////////////////////// 166 ///////////////////////////////////////////////////////////////////////////
167 list wasSetIntersect(list a, list b) { 167 list wasSetIntersect(list a, list b) {
Line 173... Line 173...
173 return i + wasSetIntersect(a, b); 173 return i + wasSetIntersect(a, b);
174 } 174 }
Line 175... Line 175...
175   175  
176 // configuration data 176 // configuration data
177 string configuration = ""; -  
178 // callback URL -  
179 string URL = ""; 177 string configuration = "";
180 // store message over state. 178 // store message over state.
181 string data = ""; 179 string data = "";
182 // banee 180 // banee
183 string firstname = ""; 181 string firstname = "";
Line 200... Line 198...
200 } 198 }
201 on_rez(integer num) { 199 on_rez(integer num) {
202 llResetScript(); 200 llResetScript();
203 } 201 }
204 changed(integer change) { 202 changed(integer change) {
205 if((change & CHANGED_INVENTORY) || 203 if((change & CHANGED_INVENTORY) ||
206 (change & CHANGED_REGION_START) || 204 (change & CHANGED_REGION_START) ||
207 (change & CHANGED_OWNER)) { 205 (change & CHANGED_OWNER)) {
208 llResetScript(); 206 llResetScript();
209 } 207 }
210 } 208 }
211 state_exit() { 209 state_exit() {
Line 220... Line 218...
220 } 218 }
221 link_message(integer sender, integer num, string message, key id) { 219 link_message(integer sender, integer num, string message, key id) {
222 // We only care about notifications now. 220 // We only care about notifications now.
223 if(id != "notification") 221 if(id != "notification")
224 return; 222 return;
225 223  
226 // This script only processes group notifications. 224 // This script only processes group notifications.
227 if(wasKeyValueGet("type", message) != "group") 225 if(wasKeyValueGet("type", message) != "group" ||
-   226 (wasKeyValueGet("type", message) == "group" &&
-   227 wasURLUnescape(wasKeyValueGet("group", message)) !=
-   228 wasKeyValueGet("group", configuration)))
228 return; 229 return;
229 230  
230 // Get the sent message. 231 // Get the sent message.
231 data = wasURLUnescape( 232 data = wasURLUnescape(
232 wasKeyValueGet( 233 wasKeyValueGet(
233 "message", 234 "message",
234 message 235 message
235 ) 236 )
236 ); 237 );
237 238  
238 // Check if this is an eggdrop command. 239 // Check if this is an eggdrop command.
239 if(llGetSubString(data, 0, 0) != 240 if(llGetSubString(data, 0, 0) !=
240 wasKeyValueGet("command", configuration)) 241 wasKeyValueGet("command", configuration))
241 return; 242 return;
242 243  
243 // Check if the command matches the current module. 244 // Check if the command matches the current module.
244 list command = llParseString2List(data, [" "], []); 245 list command = llParseString2List(data, [" "], []);
245 if(llList2String(command, 0) != 246 if(llList2String(command, 0) !=
246 wasKeyValueGet("command", configuration) + "softunban") 247 wasKeyValueGet("command", configuration) + "softunban")
247 return; 248 return;
248 249  
249 // Remove command. 250 // Remove command.
250 command = llDeleteSubList(command, 0, 0); 251 command = llDeleteSubList(command, 0, 0);
251 252  
252 firstname = wasKeyValueGet("firstname", message); 253 firstname = wasKeyValueGet("firstname", message);
253 lastname = wasKeyValueGet("lastname", message); 254 lastname = wasKeyValueGet("lastname", message);
254 255  
255 if(firstname == "" || lastname == "") { 256 if(firstname == "" || lastname == "") {
256 data = "And who would yarr be?"; 257 data = "And who would yarr be?";
257 state tell; 258 state tell;
258 } 259 }
259 260  
260 // Dump the rest of the message. 261 // Dump the rest of the message.
261 data = llDumpList2String(command, " "); 262 data = llDumpList2String(command, " ");
262 -  
263 // Get an URL. -  
264 state url; -  
265 } -  
266 on_rez(integer num) { -  
267 llResetScript(); -  
268 } -  
269 changed(integer change) { -  
270 if((change & CHANGED_INVENTORY) || -  
271 (change & CHANGED_REGION_START) || -  
272 (change & CHANGED_OWNER)) { -  
273 llResetScript(); -  
274 } -  
275 } -  
276 } -  
Line 277... Line -...
277   -  
278 state url { -  
279 state_entry() { -  
280 // DEBUG -  
281 llOwnerSay("[Softunban] Requesting URL..."); 263  
282 llRequestURL(); -  
283 } -  
284 http_request(key id, string method, string body) { -  
285 if(method != URL_REQUEST_GRANTED) return; -  
286 URL = body; -  
287 // DEBUG -  
288 llOwnerSay("[Softunban] Got URL..."); 264 // Get roles of caller.
289 state get_caller_roles; 265 state get_caller_roles;
290 } 266 }
291 on_rez(integer num) { 267 on_rez(integer num) {
292 llResetScript(); 268 llResetScript();
293 } 269 }
294 changed(integer change) { 270 changed(integer change) {
295 if((change & CHANGED_INVENTORY) || 271 if((change & CHANGED_INVENTORY) ||
296 (change & CHANGED_REGION_START) || 272 (change & CHANGED_REGION_START) ||
297 (change & CHANGED_OWNER)) { 273 (change & CHANGED_OWNER)) {
298 llResetScript(); 274 llResetScript();
299 } 275 }
300 } 276 }
Line 304... Line 280...
304 state_entry() { 280 state_entry() {
305 // DEBUG 281 // DEBUG
306 llOwnerSay("[Softunban] Searching for caller..."); 282 llOwnerSay("[Softunban] Searching for caller...");
307 llInstantMessage( 283 llInstantMessage(
308 wasKeyValueGet( 284 wasKeyValueGet(
309 "corrade", 285 "corrade",
310 configuration 286 configuration
311 ), 287 ),
312 wasKeyValueEncode( 288 wasKeyValueEncode(
313 [ 289 [
314 "command", "getmemberroles", 290 "command", "getmemberroles",
315 "group", wasURLEscape( 291 "group", wasURLEscape(
316 wasKeyValueGet( 292 wasKeyValueGet(
317 "group", 293 "group",
318 configuration 294 configuration
319 ) 295 )
320 ), 296 ),
321 "password", wasURLEscape( 297 "password", wasURLEscape(
322 wasKeyValueGet( 298 wasKeyValueGet(
323 "password", 299 "password",
324 configuration 300 configuration
325 ) 301 )
326 ), 302 ),
327 "firstname", firstname, 303 "firstname", firstname,
328 "lastname", lastname, 304 "lastname", lastname,
329 "callback", wasURLEscape(URL) 305 "callback", wasURLEscape(
-   306 wasKeyValueGet(
-   307 "URL",
-   308 configuration
-   309 )
-   310 )
330 ] 311 ]
331 ) 312 )
332 ); 313 );
333 llSetTimerEvent(60); 314 llSetTimerEvent(60);
334 } 315 }
335 http_request(key id, string method, string body) { 316 link_message(integer sender, integer num, string body, key id) {
336 llHTTPResponse(id, 200, "OK"); 317 // Only process callbacks for the database command.
337 if(wasKeyValueGet("command", body) != "getmemberroles" || 318 if(id != "callback" || wasKeyValueGet("command", body) != "getmemberroles")
-   319 return;
-   320  
338 wasKeyValueGet("success", body) != "True") { 321 if(wasKeyValueGet("success", body) != "True") {
339 // DEBUG 322 // DEBUG
340 llOwnerSay("[Softunban] Unable to get member roles: " + 323 llOwnerSay("[Softunban] Unable to get member roles: " +
341 wasURLUnescape( 324 wasURLUnescape(
342 wasKeyValueGet("error", body) 325 wasKeyValueGet("error", body)
343 ) 326 )
344 ); 327 );
345 llReleaseURL(URL); -  
346 state listen_group; 328 state listen_group;
347 } 329 }
348 330  
349 // Dump the roles to a list. 331 // Dump the roles to a list.
350 list roles = wasCSVToList( 332 list roles = wasCSVToList(
351 wasURLUnescape( 333 wasURLUnescape(
352 wasKeyValueGet("data", body) 334 wasKeyValueGet("data", body)
353 ) 335 )
354 ); 336 );
355 337  
356 if(llGetListLength( 338 if(llGetListLength(
357 wasSetIntersect(roles, 339 wasSetIntersect(roles,
358 wasCSVToList( 340 wasCSVToList(
359 wasKeyValueGet( 341 wasKeyValueGet(
360 "admin roles", configuration 342 "admin roles", configuration
361 ) 343 )
362 ) 344 )
363 ) 345 )
364 ) == 0) { 346 ) == 0) {
365 data = "You ain't got the cojones!"; 347 data = "You ain't got the cojones!";
366 llReleaseURL(URL); -  
367 state tell; 348 state tell;
368 } 349 }
369 350  
370 list banee = llParseString2List(data, [" "], []); 351 list banee = llParseString2List(data, [" "], []);
371 352  
372 firstname = llList2String(banee, 0); 353 firstname = llList2String(banee, 0);
373 lastname = llList2String(banee, 1); 354 lastname = llList2String(banee, 1);
374 355  
375 if(firstname == "" || lastname == "") { 356 if(firstname == "" || lastname == "") {
376 data = "Full name required."; 357 data = "Full name required.";
377 state tell; 358 state tell;
378 } 359 }
379 360  
380 // GC 361 // GC
381 banee = []; 362 banee = [];
382 state get_banee_roles; 363 state get_banee_roles;
383 } 364 }
384 timer() { 365 timer() {
385 llReleaseURL(URL); -  
386 state listen_group; 366 state listen_group;
387 } 367 }
388 on_rez(integer num) { 368 on_rez(integer num) {
389 llResetScript(); 369 llResetScript();
390 } 370 }
391 changed(integer change) { 371 changed(integer change) {
392 if((change & CHANGED_INVENTORY) || 372 if((change & CHANGED_INVENTORY) ||
393 (change & CHANGED_REGION_START) || 373 (change & CHANGED_REGION_START) ||
394 (change & CHANGED_OWNER)) { 374 (change & CHANGED_OWNER)) {
395 llResetScript(); 375 llResetScript();
396 } 376 }
397 } 377 }
398 state_exit() { 378 state_exit() {
Line 404... Line 384...
404 state_entry() { 384 state_entry() {
405 // DEBUG 385 // DEBUG
406 llOwnerSay("[Softunban] Searching for banee..."); 386 llOwnerSay("[Softunban] Searching for banee...");
407 llInstantMessage( 387 llInstantMessage(
408 wasKeyValueGet( 388 wasKeyValueGet(
409 "corrade", 389 "corrade",
410 configuration 390 configuration
411 ), 391 ),
412 wasKeyValueEncode( 392 wasKeyValueEncode(
413 [ 393 [
414 "command", "getmemberroles", 394 "command", "getmemberroles",
415 "group", wasURLEscape( 395 "group", wasURLEscape(
416 wasKeyValueGet( 396 wasKeyValueGet(
417 "group", 397 "group",
418 configuration 398 configuration
419 ) 399 )
420 ), 400 ),
421 "password", wasURLEscape( 401 "password", wasURLEscape(
422 wasKeyValueGet( 402 wasKeyValueGet(
423 "password", 403 "password",
424 configuration 404 configuration
425 ) 405 )
426 ), 406 ),
427 "firstname", firstname, 407 "firstname", firstname,
428 "lastname", lastname, 408 "lastname", lastname,
429 "callback", wasURLEscape(URL) 409 "callback", wasURLEscape(
-   410 wasKeyValueGet(
-   411 "URL",
-   412 configuration
-   413 )
-   414 )
430 ] 415 ]
431 ) 416 )
432 ); 417 );
433 llSetTimerEvent(60); 418 llSetTimerEvent(60);
434 } 419 }
435 http_request(key id, string method, string body) { 420 link_message(integer sender, integer num, string body, key id) {
436 llHTTPResponse(id, 200, "OK"); 421 // Only process callbacks for the database command.
437 if(wasKeyValueGet("command", body) != "getmemberroles" || 422 if(id != "callback" || wasKeyValueGet("command", body) != "getmemberroles")
-   423 return;
-   424  
438 wasKeyValueGet("success", body) != "True") { 425 if(wasKeyValueGet("success", body) != "True") {
439 if(wasKeyValueGet("status", body) == "19862") { 426 if(wasKeyValueGet("status", body) == "19862") {
440 // DEBUG 427 // DEBUG
441 llOwnerSay("[Softunban] User not in group, but proceeding anyway..."); 428 llOwnerSay("[Softunban] User not in group, but proceeding anyway...");
442 jump continue; 429 jump continue;
443 } 430 }
444 // DEBUG 431 // DEBUG
445 llOwnerSay("[Softunban] Unable to get member roles: " + 432 llOwnerSay("[Softunban] Unable to get member roles: " +
446 wasURLUnescape( 433 wasURLUnescape(
447 wasKeyValueGet("error", body) 434 wasKeyValueGet("error", body)
448 ) 435 )
449 ); 436 );
450 llReleaseURL(URL); -  
451 state listen_group; 437 state listen_group;
452 } 438 }
453 439  
454 string result = wasURLUnescape( 440 string result = wasURLUnescape(
455 wasKeyValueGet("data", body) 441 wasKeyValueGet("data", body)
456 ); 442 );
457 443  
458 if(result != "" && llListFindList(wasCSVToList(result), (list)"Owners") != -1) { 444 if(result != "" && llListFindList(wasCSVToList(result), (list)"Owners") != -1) {
459 data = "Ejectee is an owner. I'm not gonna open the pod bay doors."; 445 data = "Ejectee is an owner. I'm not gonna open the pod bay doors.";
460 llReleaseURL(URL); -  
461 state tell; 446 state tell;
462 } 447 }
463 448  
464 @continue; 449 @continue;
Line 465... Line 450...
465   450  
466 state unban; 451 state unban;
467 } 452 }
468 timer() { -  
469 llReleaseURL(URL); 453 timer() {
470 state listen_group; 454 state listen_group;
471 } 455 }
472 on_rez(integer num) { 456 on_rez(integer num) {
473 llResetScript(); 457 llResetScript();
474 } 458 }
475 changed(integer change) { 459 changed(integer change) {
476 if((change & CHANGED_INVENTORY) || 460 if((change & CHANGED_INVENTORY) ||
477 (change & CHANGED_REGION_START) || 461 (change & CHANGED_REGION_START) ||
478 (change & CHANGED_OWNER)) { 462 (change & CHANGED_OWNER)) {
479 llResetScript(); 463 llResetScript();
480 } 464 }
481 } 465 }
Line 488... Line 472...
488 state_entry() { 472 state_entry() {
489 // DEBUG 473 // DEBUG
490 llOwnerSay("[Softunban] Unbanning..."); 474 llOwnerSay("[Softunban] Unbanning...");
491 llInstantMessage( 475 llInstantMessage(
492 wasKeyValueGet( 476 wasKeyValueGet(
493 "corrade", 477 "corrade",
494 configuration 478 configuration
495 ), 479 ),
496 wasKeyValueEncode( 480 wasKeyValueEncode(
497 [ 481 [
498 "command", "softban", 482 "command", "softban",
499 "group", wasURLEscape( 483 "group", wasURLEscape(
500 wasKeyValueGet( 484 wasKeyValueGet(
501 "group", 485 "group",
502 configuration 486 configuration
503 ) 487 )
504 ), 488 ),
505 "password", wasURLEscape( 489 "password", wasURLEscape(
506 wasKeyValueGet( 490 wasKeyValueGet(
507 "password", 491 "password",
508 configuration 492 configuration
509 ) 493 )
510 ), 494 ),
511 "action", "unban", 495 "action", "unban",
512 "avatars", wasURLEscape( 496 "avatars", wasURLEscape(
Line 514... Line 498...
514 [ 498 [
515 firstname + " " + lastname 499 firstname + " " + lastname
516 ] 500 ]
517 ) 501 )
518 ), 502 ),
519 "callback", wasURLEscape(URL) 503 "callback", wasURLEscape(
-   504 wasKeyValueGet(
-   505 "URL",
-   506 configuration
-   507 )
-   508 )
520 ] 509 ]
521 ) 510 )
522 ); 511 );
523 llSetTimerEvent(60); 512 llSetTimerEvent(60);
524 } 513 }
525 http_request(key id, string method, string body) { 514 link_message(integer sender, integer num, string body, key id) {
526 llHTTPResponse(id, 200, "OK"); 515 // Only process callbacks for the database command.
527 llReleaseURL(URL); -  
528 if(wasKeyValueGet("command", body) != "softban" || 516 if(id != "callback" || wasKeyValueGet("command", body) != "softban")
-   517 return;
-   518  
529 wasKeyValueGet("success", body) != "True") { 519 if(wasKeyValueGet("success", body) != "True") {
530 // DEBUG 520 // DEBUG
531 llOwnerSay("[Softunban] Unable to ban member: " + 521 llOwnerSay("[Softunban] Unable to ban member: " +
532 wasURLUnescape( 522 wasURLUnescape(
533 wasKeyValueGet("error", body) 523 wasKeyValueGet("error", body)
534 ) 524 )
535 ); 525 );
536 state listen_group; 526 state listen_group;
537 } 527 }
538 528  
539 data = "They'll be bak!"; 529 data = "They'll be bak!";
540 530  
541 state tell; 531 state tell;
542 } 532 }
543 timer() { 533 timer() {
544 llReleaseURL(URL); -  
545 state listen_group; 534 state listen_group;
546 } 535 }
547 on_rez(integer num) { 536 on_rez(integer num) {
548 llResetScript(); 537 llResetScript();
549 } 538 }
550 changed(integer change) { 539 changed(integer change) {
551 if((change & CHANGED_INVENTORY) || 540 if((change & CHANGED_INVENTORY) ||
552 (change & CHANGED_REGION_START) || 541 (change & CHANGED_REGION_START) ||
553 (change & CHANGED_OWNER)) { 542 (change & CHANGED_OWNER)) {
554 llResetScript(); 543 llResetScript();
555 } 544 }
556 } 545 }
557 state_exit() { 546 state_exit() {
Line 563... Line 552...
563 state_entry() { 552 state_entry() {
564 // DEBUG 553 // DEBUG
565 llOwnerSay("[Softunban] Sending to group."); 554 llOwnerSay("[Softunban] Sending to group.");
566 llInstantMessage( 555 llInstantMessage(
567 wasKeyValueGet( 556 wasKeyValueGet(
568 "corrade", 557 "corrade",
569 configuration 558 configuration
570 ), 559 ),
571 wasKeyValueEncode( 560 wasKeyValueEncode(
572 [ 561 [
573 "command", "tell", 562 "command", "tell",
574 "group", wasURLEscape( 563 "group", wasURLEscape(
575 wasKeyValueGet( 564 wasKeyValueGet(
576 "group", 565 "group",
577 configuration 566 configuration
578 ) 567 )
579 ), 568 ),
580 "password", wasURLEscape( 569 "password", wasURLEscape(
581 wasKeyValueGet( 570 wasKeyValueGet(
582 "password", 571 "password",
583 configuration 572 configuration
584 ) 573 )
585 ), 574 ),
586 "entity", "group", 575 "entity", "group",
587 "message", wasURLEscape(data) 576 "message", wasURLEscape(data)
588 ] 577 ]
589 ) 578 )
590 ); 579 );
591 580  
592 state listen_group; 581 state listen_group;
593 } 582 }
594 } 583 }