SHOW:
|
|
- or go back to the newest paste.
1 | - | local tArg = {...} |
1 | + | |
2 | local controls = {["\n"]="\\n", ["\r"]="\\r", ["\t"]="\\t", ["\b"]="\\b", ["\f"]="\\f", ["\""]="\\\"", ["\\"]="\\\\"} | |
3 | local function isArray(t) | |
4 | local max = 0 | |
5 | for k,v in pairs(t) do | |
6 | if type(k) ~= "number" then | |
7 | return false | |
8 | elseif k > max then | |
9 | max = k | |
10 | end | |
11 | end | |
12 | return max == #t | |
13 | end | |
14 | local whites = {['\n']=true; ['\r']=true; ['\t']=true; [' ']=true; [',']=true; [':']=true} | |
15 | local function removeWhite(str) | |
16 | while whites[str:sub(1, 1)] do | |
17 | str = str:sub(2) | |
18 | end | |
19 | return str | |
20 | end | |
21 | local encodeCommon, arrEncoding, parseNumber, parseString, parseArray, parseMember, parseValue, parseObject, decode, decodeFromFile | |
22 | ||
23 | ------------------------------------------------------------------ encoding | |
24 | ||
25 | function encodeCommon(val, pretty, tabLevel, tTracking) | |
26 | local str = "" | |
27 | local function tab(s) | |
28 | str = str .. ("\t"):rep(tabLevel) .. s | |
29 | end | |
30 | function arrEncoding(val, bracket, closeBracket, iterator, loopFunc) | |
31 | str = str .. bracket | |
32 | if pretty then | |
33 | str = str .. "\n" | |
34 | tabLevel = tabLevel + 1 | |
35 | end | |
36 | for k,v in iterator(val) do | |
37 | tab("") | |
38 | loopFunc(k,v) | |
39 | str = str .. "," | |
40 | if pretty then str = str .. "\n" end | |
41 | end | |
42 | if pretty then | |
43 | tabLevel = tabLevel - 1 | |
44 | end | |
45 | if str:sub(-2) == ",\n" then | |
46 | str = str:sub(1, -3) .. "\n" | |
47 | elseif str:sub(-1) == "," then | |
48 | str = str:sub(1, -2) | |
49 | end | |
50 | tab(closeBracket) | |
51 | end | |
52 | if type(val) == "table" then | |
53 | assert(not tTracking[val], "Cannot encode a table holding itself recursively") | |
54 | tTracking[val] = true | |
55 | if isArray(val) then | |
56 | arrEncoding(val, "[", "]", ipairs, function(k,v) | |
57 | str = str .. encodeCommon(v, pretty, tabLevel, tTracking) | |
58 | end) | |
59 | else | |
60 | arrEncoding(val, "{", "}", pairs, function(k,v) | |
61 | assert(type(k) == "string", "JSON object keys must be strings", 2) | |
62 | str = str .. encodeCommon(k, pretty, tabLevel, tTracking) | |
63 | str = str .. (pretty and ": " or ":") .. encodeCommon(v, pretty, tabLevel, tTracking) | |
64 | end) | |
65 | end | |
66 | elseif type(val) == "string" then | |
67 | str = '"' .. val:gsub("[%c\"\\]", controls) .. '"' | |
68 | elseif type(val) == "number" or type(val) == "boolean" then | |
69 | str = tostring(val) | |
70 | else | |
71 | error("JSON only supports arrays, objects, numbers, booleans, and strings", 2) | |
72 | end | |
73 | return str | |
74 | end | |
75 | local function encode(val) | |
76 | return encodeCommon(val, false, 0, {}) | |
77 | end | |
78 | local function encodePretty(val) | |
79 | return encodeCommon(val, true, 0, {}) | |
80 | end | |
81 | ||
82 | ------------------------------------------------------------------ decoding | |
83 | ||
84 | local decodeControls = {} | |
85 | for k,v in pairs(controls) do | |
86 | decodeControls[v] = k | |
87 | end | |
88 | local function parseBoolean(str) | |
89 | if str:sub(1, 4) == "true" then | |
90 | return true, removeWhite(str:sub(5)) | |
91 | else | |
92 | return false, removeWhite(str:sub(6)) | |
93 | end | |
94 | end | |
95 | local function parseNull(str) | |
96 | return nil, removeWhite(str:sub(5)) | |
97 | end | |
98 | local numChars = {['e']=true; ['E']=true; ['+']=true; ['-']=true; ['.']=true} | |
99 | function parseNumber(str) | |
100 | local i = 1 | |
101 | while numChars[str:sub(i, i)] or tonumber(str:sub(i, i)) do | |
102 | i = i + 1 | |
103 | end | |
104 | local val = tonumber(str:sub(1, i - 1)) | |
105 | str = removeWhite(str:sub(i)) | |
106 | return val, str | |
107 | end | |
108 | function parseString(str) | |
109 | str = str:sub(2) | |
110 | local s = "" | |
111 | while str:sub(1,1) ~= "\"" do | |
112 | local next = str:sub(1,1) | |
113 | str = str:sub(2) | |
114 | assert(next ~= "\n", "Unclosed string") | |
115 | ||
116 | if next == "\\" then | |
117 | local escape = str:sub(1,1) | |
118 | str = str:sub(2) | |
119 | ||
120 | next = assert(decodeControls[next..escape], "Invalid escape character") | |
121 | end | |
122 | s = s .. next | |
123 | end | |
124 | return s, removeWhite(str:sub(2)) | |
125 | end | |
126 | function parseArray(str) | |
127 | str = removeWhite(str:sub(2)) | |
128 | local val = {} | |
129 | local i = 1 | |
130 | while str:sub(1, 1) ~= "]" do | |
131 | local v = nil | |
132 | v, str = parseValue(str) | |
133 | val[i] = v | |
134 | i = i + 1 | |
135 | str = removeWhite(str) | |
136 | end | |
137 | str = removeWhite(str:sub(2)) | |
138 | return val, str | |
139 | end | |
140 | function parseValue(str) | |
141 | local fchar = str:sub(1, 1) | |
142 | if fchar == "{" then | |
143 | return parseObject(str) | |
144 | elseif fchar == "[" then | |
145 | return parseArray(str) | |
146 | elseif tonumber(fchar) ~= nil or numChars[fchar] then | |
147 | return parseNumber(str) | |
148 | elseif str:sub(1, 4) == "true" or str:sub(1, 5) == "false" then | |
149 | return parseBoolean(str) | |
150 | elseif fchar == "\"" then | |
151 | return parseString(str) | |
152 | elseif str:sub(1, 4) == "null" then | |
153 | return parseNull(str) | |
154 | end | |
155 | return nil | |
156 | end | |
157 | function parseMember(str) | |
158 | local k = nil | |
159 | k, str = parseValue(str) | |
160 | local val = nil | |
161 | val, str = parseValue(str) | |
162 | return k, val, str | |
163 | end | |
164 | function parseObject(str) | |
165 | str = removeWhite(str:sub(2)) | |
166 | local val = {} | |
167 | while str:sub(1, 1) ~= "}" do | |
168 | local k, v = nil, nil | |
169 | k, v, str = parseMember(str) | |
170 | val[k] = v | |
171 | str = removeWhite(str) | |
172 | end | |
173 | str = removeWhite(str:sub(2)) | |
174 | return val, str | |
175 | end | |
176 | function decode(str) | |
177 | str = removeWhite(str) | |
178 | t = parseValue(str) | |
179 | return t | |
180 | end | |
181 | function decodeFromFile(path) | |
182 | local file = assert(fs.open(path, "r")) | |
183 | local decoded = decode(file.readAll()) | |
184 | file.close() | |
185 | return decoded | |
186 | end | |
187 | ||
188 | ||
189 | std.storeCatagoryNames = {} | |
190 | - | local getTableSize = function(tbl) |
190 | + | local boardIDs = {} |
191 | - | local amnt = 0 |
191 | + | local req = http.get("http://backend.jouhou.ml/api/Boards") |
192 | - | for k,v in pairs(tbl) do |
192 | + | |
193 | - | amnt = amnt + 1 |
193 | + | |
194 | end | |
195 | - | return amnt |
195 | + | |
196 | for a = 1, #req do | |
197 | boardIDs[req[a].id] = a | |
198 | - | if tArg[1] ~= "storelengthcheck" then |
198 | + | std.storeCatagoryNames[#std.storeCatagoryNames+1] = req[a].name |
199 | - | std.storeCatagoryNames = {"Programs"} |
199 | + | |
200 | ||
201 | local req = http.get("http://backend.jouhou.ml/api/Posts") | |
202 | - | local req = http.get("http://twijnweb.com/cc/api/v1.0/programs/getall.php") |
202 | + | |
203 | return false | |
204 | end | |
205 | req = decode(req.readAll()) | |
206 | std.storeURLs = {} | |
207 | - | if type(req) ~= "table" then |
207 | + | |
208 | for k,v in pairs(req) do | |
209 | - | elseif req.programs then |
209 | + | |
210 | - | req = req.programs |
210 | + | title = v.id, |
211 | - | else |
211 | + | url = {v.id}, |
212 | creator = "n/a", | |
213 | description = "Timestamp: "..v.creation, | |
214 | catagory = boardIDs[v.id], | |
215 | - | local laURLs = {} |
215 | + | |
216 | keywords = {tostring(v.content)}, | |
217 | } | |
218 | - | title = v.name, |
218 | + | std.storeURLs[v.code] = buffer |
219 | - | url = "http://get.twijnweb.com/"..v.code, |
219 | + | |
220 | - | creator = v.owner, |
220 | + | |
221 | - | description = v.description, |
221 | + | std.contextualGet = function(appid) |
222 | - | catagory = 1, |
222 | + | local url = "http://backend.jouhou.ml/api/Posts/" |
223 | local out = http.get(url..appid) | |
224 | - | keywords = {}, |
224 | + | if out then |
225 | out = decode(out.readAll()) | |
226 | - | laURLs[v.code] = buffer |
226 | + | return out.content |
227 | else | |
228 | - | if tArg[1] == "storelengthcheck" then |
228 | + | return false |
229 | - | return getTableSize(laURLs) |
229 | + | |
230 | - | else |
230 | + |