corrade-lsl-templates – Diff between revs 11 and 15

Subversion Repositories:
Rev:
Only display areas with differencesIgnore whitespace
Rev 11 Rev 15
1 /////////////////////////////////////////////////////////////////////////// 1 ///////////////////////////////////////////////////////////////////////////
2 // Copyright (C) Wizardry and Steamworks 2016 - License: GNU GPLv3 // 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 ///////////////////////////////////////////////////////////////////////////
8   8  
9 /////////////////////////////////////////////////////////////////////////// 9 ///////////////////////////////////////////////////////////////////////////
10 // Copyright (C) 2014 Wizardry and Steamworks - License: GNU GPLv3 // 10 // Copyright (C) 2014 Wizardry and Steamworks - License: GNU GPLv3 //
11 /////////////////////////////////////////////////////////////////////////// 11 ///////////////////////////////////////////////////////////////////////////
12 string wasKeyValueGet(string k, string data) { 12 string wasKeyValueGet(string k, string data) {
13 if(llStringLength(data) == 0) return ""; 13 if(llStringLength(data) == 0) return "";
14 if(llStringLength(k) == 0) return ""; 14 if(llStringLength(k) == 0) return "";
15 list a = llParseString2List(data, ["&", "="], []); 15 list a = llParseString2List(data, ["&", "="], []);
16 integer i = llListFindList(a, [ k ]); 16 integer i = llListFindList(a, [ k ]);
17 if(i != -1) return llList2String(a, i+1); 17 if(i != -1) return llList2String(a, i+1);
18 return ""; 18 return "";
19 } 19 }
20 20
21 /////////////////////////////////////////////////////////////////////////// 21 ///////////////////////////////////////////////////////////////////////////
22 // Copyright (C) 2013 Wizardry and Steamworks - License: GNU GPLv3 // 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 = [];
28 do { 28 do {
29 data += llList2String(k, 0) + "=" + llList2String(v, 0); 29 data += llList2String(k, 0) + "=" + llList2String(v, 0);
30 k = llDeleteSubList(k, 0, 0); 30 k = llDeleteSubList(k, 0, 0);
31 v = llDeleteSubList(v, 0, 0); 31 v = llDeleteSubList(v, 0, 0);
32 } while(llGetListLength(k) != 0); 32 } while(llGetListLength(k) != 0);
33 return llDumpList2String(data, "&"); 33 return llDumpList2String(data, "&");
34 } 34 }
35   35  
36 /////////////////////////////////////////////////////////////////////////// 36 ///////////////////////////////////////////////////////////////////////////
37 // Copyright (C) 2011 Wizardry and Steamworks - License: GNU GPLv3 // 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);
42 float y = llPow(-1, 1 + (integer) llFrand(2)) * llFrand(radius*2); 42 float y = llPow(-1, 1 + (integer) llFrand(2)) * llFrand(radius*2);
43 if(llPow(x,2) + llPow(y,2) <= llPow(radius,2)) 43 if(llPow(x,2) + llPow(y,2) <= llPow(radius,2))
44 return <x, y, 0>; 44 return <x, y, 0>;
45 return wasCirclePoint(radius); 45 return wasCirclePoint(radius);
46 } 46 }
47   47  
48 /////////////////////////////////////////////////////////////////////////// 48 ///////////////////////////////////////////////////////////////////////////
49 // Copyright (C) 2015 Wizardry and Steamworks - License: GNU GPLv3 // 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 = "";
54 do { 54 do {
55 string c = llGetSubString(i, 0, 0); 55 string c = llGetSubString(i, 0, 0);
56 i = llDeleteSubString(i, 0, 0); 56 i = llDeleteSubString(i, 0, 0);
57 if(c == "") jump continue; 57 if(c == "") jump continue;
58 if(c == " ") { 58 if(c == " ") {
59 o += "+"; 59 o += "+";
60 jump continue; 60 jump continue;
61 } 61 }
62 if(c == "\n") { 62 if(c == "\n") {
63 o += "%0D" + llEscapeURL(c); 63 o += "%0D" + llEscapeURL(c);
64 jump continue; 64 jump continue;
65 } 65 }
66 o += llEscapeURL(c); 66 o += llEscapeURL(c);
67 @continue; 67 @continue;
68 } while(i != ""); 68 } while(i != "");
69 return o; 69 return o;
70 } 70 }
71   71  
72 /////////////////////////////////////////////////////////////////////////// 72 ///////////////////////////////////////////////////////////////////////////
73 // Copyright (C) 2015 Wizardry and Steamworks - License: GNU GPLv3 // 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 = [];
78 string m = ""; 78 string m = "";
79 do { 79 do {
80 string a = llGetSubString(csv, 0, 0); 80 string a = llGetSubString(csv, 0, 0);
81 csv = llDeleteSubString(csv, 0, 0); 81 csv = llDeleteSubString(csv, 0, 0);
82 if(a == ",") { 82 if(a == ",") {
83 if(llList2String(s, -1) != "\"") { 83 if(llList2String(s, -1) != "\"") {
84 l += m; 84 l += m;
85 m = ""; 85 m = "";
86 jump continue; 86 jump continue;
87 } 87 }
88 m += a; 88 m += a;
89 jump continue; 89 jump continue;
90 } 90 }
91 if(a == "\"" && llGetSubString(csv, 0, 0) == a) { 91 if(a == "\"" && llGetSubString(csv, 0, 0) == a) {
92 m += a; 92 m += a;
93 csv = llDeleteSubString(csv, 0, 0); 93 csv = llDeleteSubString(csv, 0, 0);
94 jump continue; 94 jump continue;
95 } 95 }
96 if(a == "\"") { 96 if(a == "\"") {
97 if(llList2String(s, -1) != a) { 97 if(llList2String(s, -1) != a) {
98 s += a; 98 s += a;
99 jump continue; 99 jump continue;
100 } 100 }
101 s = llDeleteSubList(s, -1, -1); 101 s = llDeleteSubList(s, -1, -1);
102 jump continue; 102 jump continue;
103 } 103 }
104 m += a; 104 m += a;
105 @continue; 105 @continue;
106 } while(csv != ""); 106 } while(csv != "");
107 // postcondition: length(s) = 0 107 // postcondition: length(s) = 0
108 return l + m; 108 return l + m;
109 } 109 }
110   110  
111 /////////////////////////////////////////////////////////////////////////// 111 ///////////////////////////////////////////////////////////////////////////
112 // Copyright (C) 2015 Wizardry and Steamworks - License: GNU GPLv3 // 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, ",");
138 } 138 }
139   139  
140 /////////////////////////////////////////////////////////////////////////// 140 ///////////////////////////////////////////////////////////////////////////
141 // Copyright (C) 2015 Wizardry and Steamworks - License: GNU GPLv3 // 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 )
161 ); 161 );
162 } 162 }
163   163  
164 /////////////////////////////////////////////////////////////////////////// 164 ///////////////////////////////////////////////////////////////////////////
165 // Copyright (C) 2017 Wizardry and Steamworks - License: GNU GPLv3 // 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) {
168 if(llGetListLength(a) == 0) return []; 168 if(llGetListLength(a) == 0) return [];
169 string i = llList2String(a, 0); 169 string i = llList2String(a, 0);
170 a = llDeleteSubList(a, 0, 0); 170 a = llDeleteSubList(a, 0, 0);
171 if(llListFindList(b, (list)i) == -1) 171 if(llListFindList(b, (list)i) == -1)
172 return wasSetIntersect(a, b); 172 return wasSetIntersect(a, b);
173 return i + wasSetIntersect(a, b); 173 return i + wasSetIntersect(a, b);
174 } 174 }
175   175  
176 // configuration data 176 // configuration data
177 string configuration = ""; 177 string configuration = "";
178 // callback URL 178 // callback URL
179 string URL = ""; 179 string URL = "";
180 // store message over state. 180 // store message over state.
181 string data = ""; 181 string data = "";
182 // banee 182 // banee
183 string firstname = ""; 183 string firstname = "";
184 string lastname = ""; 184 string lastname = "";
-   185 string soft = "True";
185   186  
186 default { 187 default {
187 state_entry() { 188 state_entry() {
188 llOwnerSay("[Unban] Starting..."); 189 llOwnerSay("[Unban] Starting...");
189 llSetTimerEvent(10); 190 llSetTimerEvent(10);
190 } 191 }
191 link_message(integer sender, integer num, string message, key id) { 192 link_message(integer sender, integer num, string message, key id) {
192 if(id != "configuration") return; 193 if(id != "configuration") return;
193 llOwnerSay("[Unban] Got configuration..."); 194 llOwnerSay("[Unban] Got configuration...");
194 configuration = message; 195 configuration = message;
195 state listen_group; 196 state listen_group;
196 } 197 }
197 timer() { 198 timer() {
198 llOwnerSay("[Unban] Requesting configuration..."); 199 llOwnerSay("[Unban] Requesting configuration...");
199 llMessageLinked(LINK_THIS, 0, "configuration", NULL_KEY); 200 llMessageLinked(LINK_THIS, 0, "configuration", NULL_KEY);
200 } 201 }
201 on_rez(integer num) { 202 on_rez(integer num) {
202 llResetScript(); 203 llResetScript();
203 } 204 }
204 changed(integer change) { 205 changed(integer change) {
205 if((change & CHANGED_INVENTORY) || 206 if((change & CHANGED_INVENTORY) ||
206 (change & CHANGED_REGION_START) || 207 (change & CHANGED_REGION_START) ||
207 (change & CHANGED_OWNER)) { 208 (change & CHANGED_OWNER)) {
208 llResetScript(); 209 llResetScript();
209 } 210 }
210 } 211 }
211 state_exit() { 212 state_exit() {
212 llSetTimerEvent(0); 213 llSetTimerEvent(0);
213 } 214 }
214 } 215 }
215   216  
216 state listen_group { 217 state listen_group {
217 state_entry() { 218 state_entry() {
218 // DEBUG 219 // DEBUG
219 llOwnerSay("[Unban] Waiting for group messages..."); 220 llOwnerSay("[Unban] Waiting for group messages...");
220 } 221 }
221 link_message(integer sender, integer num, string message, key id) { 222 link_message(integer sender, integer num, string message, key id) {
222 // We only care about notifications now. 223 // We only care about notifications now.
223 if(id != "notification") 224 if(id != "notification")
224 return; 225 return;
225 226
226 // This script only processes group notifications. 227 // This script only processes group notifications.
227 if(wasKeyValueGet("type", message) != "group") 228 if(wasKeyValueGet("type", message) != "group")
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 [wasKeyValueGet("command", configuration), " "], ["@"]); 246 if(llList2String(command, 0) !=
246 if(llList2String(command, 0) != "unban") 247 wasKeyValueGet("command", configuration) + "unban")
247 return; 248 return;
-   249
-   250 // Remove command.
-   251 command = llDeleteSubList(command, 0, 0);
248 252
249 firstname = wasKeyValueGet("firstname", message); 253 firstname = wasKeyValueGet("firstname", message);
250 lastname = wasKeyValueGet("lastname", message); 254 lastname = wasKeyValueGet("lastname", message);
251 255
252 if(firstname == "" || lastname == "") { 256 if(firstname == "" || lastname == "") {
253 data = "And who would yarr be?"; 257 data = "And who would yarr be?";
254 state tell; 258 state tell;
255 } 259 }
256 -  
257 // Remove command. -  
258 command = llDeleteSubList(command, 0, 0); -  
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
263 // Get an URL. 264 // Get an URL.
264 state url; 265 state url;
265 } 266 }
266 on_rez(integer num) { 267 on_rez(integer num) {
267 llResetScript(); 268 llResetScript();
268 } 269 }
269 changed(integer change) { 270 changed(integer change) {
270 if((change & CHANGED_INVENTORY) || 271 if((change & CHANGED_INVENTORY) ||
271 (change & CHANGED_REGION_START) || 272 (change & CHANGED_REGION_START) ||
272 (change & CHANGED_OWNER)) { 273 (change & CHANGED_OWNER)) {
273 llResetScript(); 274 llResetScript();
274 } 275 }
275 } 276 }
276 } 277 }
277   278  
278 state url { 279 state url {
279 state_entry() { 280 state_entry() {
280 // DEBUG 281 // DEBUG
281 llOwnerSay("[Unban] Requesting URL..."); 282 llOwnerSay("[Unban] Requesting URL...");
282 llRequestURL(); 283 llRequestURL();
283 } 284 }
284 http_request(key id, string method, string body) { 285 http_request(key id, string method, string body) {
285 if(method != URL_REQUEST_GRANTED) return; 286 if(method != URL_REQUEST_GRANTED) return;
286 URL = body; 287 URL = body;
287 // DEBUG 288 // DEBUG
288 llOwnerSay("[Unban] Got URL..."); 289 llOwnerSay("[Unban] Got URL...");
289 state get_caller_roles; 290 state get_caller_roles;
290 } 291 }
291 on_rez(integer num) { 292 on_rez(integer num) {
292 llResetScript(); 293 llResetScript();
293 } 294 }
294 changed(integer change) { 295 changed(integer change) {
295 if((change & CHANGED_INVENTORY) || 296 if((change & CHANGED_INVENTORY) ||
296 (change & CHANGED_REGION_START) || 297 (change & CHANGED_REGION_START) ||
297 (change & CHANGED_OWNER)) { 298 (change & CHANGED_OWNER)) {
298 llResetScript(); 299 llResetScript();
299 } 300 }
300 } 301 }
301 } 302 }
302   303  
303 state get_caller_roles { 304 state get_caller_roles {
304 state_entry() { 305 state_entry() {
305 // DEBUG 306 // DEBUG
306 llOwnerSay("[Unban] Searching for caller..."); 307 llOwnerSay("[Unban] Searching for caller...");
307 llInstantMessage( 308 llInstantMessage(
308 wasKeyValueGet( 309 wasKeyValueGet(
309 "corrade", 310 "corrade",
310 configuration 311 configuration
311 ), 312 ),
312 wasKeyValueEncode( 313 wasKeyValueEncode(
313 [ 314 [
314 "command", "getmemberroles", 315 "command", "getmemberroles",
315 "group", wasURLEscape( 316 "group", wasURLEscape(
316 wasKeyValueGet( 317 wasKeyValueGet(
317 "group", 318 "group",
318 configuration 319 configuration
319 ) 320 )
320 ), 321 ),
321 "password", wasURLEscape( 322 "password", wasURLEscape(
322 wasKeyValueGet( 323 wasKeyValueGet(
323 "password", 324 "password",
324 configuration 325 configuration
325 ) 326 )
326 ), 327 ),
327 "firstname", firstname, 328 "firstname", firstname,
328 "lastname", lastname, 329 "lastname", lastname,
329 "callback", wasURLEscape(URL) 330 "callback", wasURLEscape(URL)
330 ] 331 ]
331 ) 332 )
332 ); 333 );
333 llSetTimerEvent(60); 334 llSetTimerEvent(60);
334 } 335 }
335 http_request(key id, string method, string body) { 336 http_request(key id, string method, string body) {
336 llHTTPResponse(id, 200, "OK"); 337 llHTTPResponse(id, 200, "OK");
337 if(wasKeyValueGet("command", body) != "getmemberroles" || 338 if(wasKeyValueGet("command", body) != "getmemberroles" ||
338 wasKeyValueGet("success", body) != "True") { 339 wasKeyValueGet("success", body) != "True") {
339 // DEBUG 340 // DEBUG
340 llOwnerSay("[Unban] Unable to get member roles: " + 341 llOwnerSay("[Unban] Unable to get member roles: " +
341 wasURLUnescape( 342 wasURLUnescape(
342 wasKeyValueGet("error", body) 343 wasKeyValueGet("error", body)
343 ) 344 )
344 ); 345 );
345 llReleaseURL(URL); 346 llReleaseURL(URL);
346 state listen_group; 347 state listen_group;
347 } 348 }
348 349
349 // Dump the roles to a list. 350 // Dump the roles to a list.
350 list roles = wasCSVToList( 351 list roles = wasCSVToList(
351 wasURLUnescape( 352 wasURLUnescape(
352 wasKeyValueGet("data", body) 353 wasKeyValueGet("data", body)
353 ) 354 )
354 ); 355 );
355 356
356 if(llGetListLength( 357 if(llGetListLength(
357 wasSetIntersect(roles, 358 wasSetIntersect(roles,
358 wasCSVToList( 359 wasCSVToList(
359 wasKeyValueGet( 360 wasKeyValueGet(
360 "admin roles", configuration 361 "admin roles", configuration
361 ) 362 )
362 ) 363 )
363 ) 364 )
364 ) == 0) { 365 ) == 0) {
365 data = "You ain't got the cojones!"; 366 data = "You ain't got the cojones!";
366 llReleaseURL(URL); 367 llReleaseURL(URL);
367 state tell; 368 state tell;
368 } 369 }
369 370
370 list banee = llParseString2List(data, [" "], []); 371 list banee = llParseString2List(data, [" "], []);
371 372
372 firstname = llList2String(banee, 0); 373 firstname = llList2String(banee, 0);
-   374 banee = llDeleteSubList(banee, 0, 0);
373 lastname = llList2String(banee, 1); 375 lastname = llList2String(banee, 0);
-   376 banee = llDeleteSubList(banee, 0, 0);
374 377
375 if(firstname == "" || lastname == "") { 378 if(firstname == "" || lastname == "") {
376 data = "Full name required."; 379 data = "Full name required.";
377 state tell; 380 state tell;
378 } 381 }
-   382
-   383 if(llGetListLength(banee) != 0 &&
-   384 llToLower(llList2String(banee, 0)) == "nosoft") {
-   385 soft = "False";
-   386 banee = llDeleteSubList(banee, 0, 0);
-   387 }
379 388
380 // GC 389 // GC
381 banee = []; 390 banee = [];
382 state get_banee_roles; 391 state get_banee_roles;
383 } 392 }
384 timer() { 393 timer() {
385 llReleaseURL(URL); 394 llReleaseURL(URL);
386 state listen_group; 395 state listen_group;
387 } 396 }
388 on_rez(integer num) { 397 on_rez(integer num) {
389 llResetScript(); 398 llResetScript();
390 } 399 }
391 changed(integer change) { 400 changed(integer change) {
392 if((change & CHANGED_INVENTORY) || 401 if((change & CHANGED_INVENTORY) ||
393 (change & CHANGED_REGION_START) || 402 (change & CHANGED_REGION_START) ||
394 (change & CHANGED_OWNER)) { 403 (change & CHANGED_OWNER)) {
395 llResetScript(); 404 llResetScript();
396 } 405 }
397 } 406 }
398 state_exit() { 407 state_exit() {
399 llSetTimerEvent(0); 408 llSetTimerEvent(0);
400 } 409 }
401 } 410 }
402   411  
403 state get_banee_roles { 412 state get_banee_roles {
404 state_entry() { 413 state_entry() {
405 // DEBUG 414 // DEBUG
406 llOwnerSay("[Unban] Searching for banee..."); 415 llOwnerSay("[Unban] Searching for banee...");
407 llInstantMessage( 416 llInstantMessage(
408 wasKeyValueGet( 417 wasKeyValueGet(
409 "corrade", 418 "corrade",
410 configuration 419 configuration
411 ), 420 ),
412 wasKeyValueEncode( 421 wasKeyValueEncode(
413 [ 422 [
414 "command", "getmemberroles", 423 "command", "getmemberroles",
415 "group", wasURLEscape( 424 "group", wasURLEscape(
416 wasKeyValueGet( 425 wasKeyValueGet(
417 "group", 426 "group",
418 configuration 427 configuration
419 ) 428 )
420 ), 429 ),
421 "password", wasURLEscape( 430 "password", wasURLEscape(
422 wasKeyValueGet( 431 wasKeyValueGet(
423 "password", 432 "password",
424 configuration 433 configuration
425 ) 434 )
426 ), 435 ),
427 "firstname", firstname, 436 "firstname", firstname,
428 "lastname", lastname, 437 "lastname", lastname,
429 "callback", wasURLEscape(URL) 438 "callback", wasURLEscape(URL)
430 ] 439 ]
431 ) 440 )
432 ); 441 );
433 llSetTimerEvent(60); 442 llSetTimerEvent(60);
434 } 443 }
435 http_request(key id, string method, string body) { 444 http_request(key id, string method, string body) {
436 llHTTPResponse(id, 200, "OK"); 445 llHTTPResponse(id, 200, "OK");
437 if(wasKeyValueGet("command", body) != "getmemberroles" || 446 if(wasKeyValueGet("command", body) != "getmemberroles" ||
438 wasKeyValueGet("success", body) != "True") { 447 wasKeyValueGet("success", body) != "True") {
-   448 if(wasKeyValueGet("status", body) == "19862") {
-   449 // DEBUG
-   450 llOwnerSay("[Unban] User not in group, but proceeding anyway...");
-   451 jump continue;
-   452 }
439 // DEBUG 453 // DEBUG
440 llOwnerSay("[Unban] Unable to get member roles: " + 454 llOwnerSay("[Unban] Unable to get member roles: " +
441 wasURLUnescape( 455 wasURLUnescape(
442 wasKeyValueGet("error", body) 456 wasKeyValueGet("error", body)
443 ) 457 )
444 ); 458 );
445 llReleaseURL(URL); 459 llReleaseURL(URL);
446 state listen_group; 460 state listen_group;
447 } 461 }
448 462
449 string result = wasURLUnescape( 463 string result = wasURLUnescape(
450 wasKeyValueGet("data", body) 464 wasKeyValueGet("data", body)
451 ); 465 );
452 466
453 if(result != "" && llListFindList(wasCSVToList(result), (list)"Owners") != -1) { 467 if(result != "" && llListFindList(wasCSVToList(result), (list)"Owners") != -1) {
454 data = "Ejectee is an owner. I'm not gonna open the pod bay doors."; 468 data = "Ejectee is an owner. I'm not gonna open the pod bay doors.";
455 llReleaseURL(URL); 469 llReleaseURL(URL);
456 state tell; 470 state tell;
457 } 471 }
-   472
-   473 @continue;
458 474  
459 state ban; 475 state unban;
460 } 476 }
461 timer() { 477 timer() {
462 llReleaseURL(URL); 478 llReleaseURL(URL);
463 state listen_group; 479 state listen_group;
464 } 480 }
465 on_rez(integer num) { 481 on_rez(integer num) {
466 llResetScript(); 482 llResetScript();
467 } 483 }
468 changed(integer change) { 484 changed(integer change) {
469 if((change & CHANGED_INVENTORY) || 485 if((change & CHANGED_INVENTORY) ||
470 (change & CHANGED_REGION_START) || 486 (change & CHANGED_REGION_START) ||
471 (change & CHANGED_OWNER)) { 487 (change & CHANGED_OWNER)) {
472 llResetScript(); 488 llResetScript();
473 } 489 }
474 } 490 }
475 state_exit() { 491 state_exit() {
476 llSetTimerEvent(0); 492 llSetTimerEvent(0);
477 } 493 }
478 } 494 }
479   495  
480 state ban { 496 state unban {
481 state_entry() { 497 state_entry() {
482 // DEBUG 498 // DEBUG
483 llOwnerSay("[Unban] Unbanning..."); 499 llOwnerSay("[Unban] Unbanning...");
484 llInstantMessage( 500 llInstantMessage(
485 wasKeyValueGet( 501 wasKeyValueGet(
486 "corrade", 502 "corrade",
487 configuration 503 configuration
488 ), 504 ),
489 wasKeyValueEncode( 505 wasKeyValueEncode(
490 [ 506 [
491 "command", "unban", 507 "command", "ban",
492 "group", wasURLEscape( 508 "group", wasURLEscape(
493 wasKeyValueGet( 509 wasKeyValueGet(
494 "group", 510 "group",
495 configuration 511 configuration
496 ) 512 )
497 ), 513 ),
498 "password", wasURLEscape( 514 "password", wasURLEscape(
499 wasKeyValueGet( 515 wasKeyValueGet(
500 "password", 516 "password",
501 configuration 517 configuration
502 ) 518 )
503 ), 519 ),
-   520 "soft", soft,
504 "action", "unban", 521 "action", "unban",
505 "avatars", wasURLEscape( 522 "avatars", wasURLEscape(
506 wasListToCSV( 523 wasListToCSV(
507 [ 524 [
508 firstname + " " + lastname 525 firstname + " " + lastname
509 ] 526 ]
510 ) 527 )
511 ), 528 ),
512 "callback", wasURLEscape(URL) 529 "callback", wasURLEscape(URL)
513 ] 530 ]
514 ) 531 )
515 ); 532 );
516 llSetTimerEvent(60); 533 llSetTimerEvent(60);
517 } 534 }
518 http_request(key id, string method, string body) { 535 http_request(key id, string method, string body) {
519 llHTTPResponse(id, 200, "OK"); 536 llHTTPResponse(id, 200, "OK");
520 llReleaseURL(URL); 537 llReleaseURL(URL);
521 if(wasKeyValueGet("command", body) != "ban" || 538 if(wasKeyValueGet("command", body) != "ban" ||
522 wasKeyValueGet("success", body) != "True") { 539 wasKeyValueGet("success", body) != "True") {
523 // DEBUG 540 // DEBUG
524 llOwnerSay("[Unban] Unable to ban member: " + 541 llOwnerSay("[Unban] Unable to ban member: " +
525 wasURLUnescape( 542 wasURLUnescape(
526 wasKeyValueGet("error", body) 543 wasKeyValueGet("error", body)
527 ) 544 )
528 ); 545 );
529 state listen_group; 546 state listen_group;
530 } 547 }
531 548
532 data = "Hasta la vista, baby!"; 549 data = "They'll be bak!";
533 550
534 state tell; 551 state tell;
535 } 552 }
536 timer() { 553 timer() {
537 llReleaseURL(URL); 554 llReleaseURL(URL);
538 state listen_group; 555 state listen_group;
539 } 556 }
540 on_rez(integer num) { 557 on_rez(integer num) {
541 llResetScript(); 558 llResetScript();
542 } 559 }
543 changed(integer change) { 560 changed(integer change) {
544 if((change & CHANGED_INVENTORY) || 561 if((change & CHANGED_INVENTORY) ||
545 (change & CHANGED_REGION_START) || 562 (change & CHANGED_REGION_START) ||
546 (change & CHANGED_OWNER)) { 563 (change & CHANGED_OWNER)) {
547 llResetScript(); 564 llResetScript();
548 } 565 }
549 } 566 }
550 state_exit() { 567 state_exit() {
551 llSetTimerEvent(0); 568 llSetTimerEvent(0);
552 } 569 }
553 } 570 }
554   571  
555 state tell { 572 state tell {
556 state_entry() { 573 state_entry() {
557 // DEBUG 574 // DEBUG
558 llOwnerSay("[Unban] Sending to group."); 575 llOwnerSay("[Unban] Sending to group.");
559 llInstantMessage( 576 llInstantMessage(
560 wasKeyValueGet( 577 wasKeyValueGet(
561 "corrade", 578 "corrade",
562 configuration 579 configuration
563 ), 580 ),
564 wasKeyValueEncode( 581 wasKeyValueEncode(
565 [ 582 [
566 "command", "tell", 583 "command", "tell",
567 "group", wasURLEscape( 584 "group", wasURLEscape(
568 wasKeyValueGet( 585 wasKeyValueGet(
569 "group", 586 "group",
570 configuration 587 configuration
571 ) 588 )
572 ), 589 ),
573 "password", wasURLEscape( 590 "password", wasURLEscape(
574 wasKeyValueGet( 591 wasKeyValueGet(
575 "password", 592 "password",
576 configuration 593 configuration
577 ) 594 )
578 ), 595 ),
579 "entity", "group", 596 "entity", "group",
580 "message", wasURLEscape(data) 597 "message", wasURLEscape(data)
581 ] 598 ]
582 ) 599 )
583 ); 600 );
-   601
-   602 // reset variables.
-   603 soft = "True";
-   604
584 state listen_group; 605 state listen_group;
585 } 606 }
586 } 607 }
587   608