├── .env.example ├── .gitignore ├── LICENSE ├── Procfile ├── index.js ├── package-lock.json ├── package.json └── src ├── assets ├── fonts │ ├── Calibri.ttf │ ├── Montserrat-Black.ttf │ ├── Montserrat-BlackItalic.ttf │ └── Montserrat-BoldItalic.ttf └── img │ ├── Profile_1.jpg │ ├── Profile_2.jpg │ └── Work_Info.png ├── client └── listeningIn │ ├── message.js │ ├── messageReactionAdd.js │ ├── raw.js │ └── ready.js ├── commands ├── Bot │ ├── botinfo.js │ ├── help.js │ └── ping.js ├── Economy │ ├── coins.js │ ├── daily.js │ ├── deposity.js │ ├── pay.js │ ├── rank.js │ ├── steal.js │ ├── withdraw.js │ └── work.js ├── Information │ ├── avatar.js │ └── server.js ├── Miscellaneous │ ├── hug.js │ ├── kiss.js │ ├── profile.js │ └── sugerir.js ├── Owner │ └── eval.js └── Staff │ ├── ban.js │ ├── cmdblock.js │ ├── kick.js │ └── ticket.js ├── database ├── Schemas │ ├── Client.js │ ├── Guild.js │ └── User.js └── index.js ├── index.js ├── structure ├── ClientEmbed.js └── Command.js └── utils ├── Emojis.js ├── Plugins.js ├── Util.js ├── bdd.json ├── index.js └── plugins ├── abbrev.js └── renderEmoji.js /.env.example: -------------------------------------------------------------------------------- 1 | TOKEN= 2 | 3 | OWNER_ID= 4 | GUILD_ID= 5 | 6 | ROLE_ID= 7 | CAPTCHA= 8 | MSG_ID= 9 | CHANNEL_ID= 10 | STAFF_ROLE= 11 | LOGS= 12 | 13 | EMBED_COLOR=#88e8ff 14 | PREFIX=/ 15 | 16 | SERVER_NAME=Rede Specter 17 | 18 | SUGESTION= 19 | 20 | MONGODB_URI= -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | .env 2 | package-lock 3 | node_modules/ 4 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2021 Rede-Specter 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /Procfile: -------------------------------------------------------------------------------- 1 | SmoozeRun: node index.js -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | require('dotenv').config() 2 | var Specter = require('./src/index.js') 3 | 4 | module.exports = Specter -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "specter", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/runtime": { 8 | "version": "7.12.5", 9 | "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.12.5.tgz", 10 | "integrity": "sha512-plcc+hbExy3McchJCEQG3knOsuh3HH+Prx1P6cLIkET/0dLuQDEnrT+s27Axgc9bqfsmNUNHfscgMUdBpC9xfg==", 11 | "requires": { 12 | "regenerator-runtime": "^0.13.4" 13 | } 14 | }, 15 | "@discordjs/collection": { 16 | "version": "0.1.6", 17 | "resolved": "https://registry.npmjs.org/@discordjs/collection/-/collection-0.1.6.tgz", 18 | "integrity": "sha512-utRNxnd9kSS2qhyivo9lMlt5qgAUasH2gb7BEOn6p0efFh24gjGomHzWKMAPn2hEReOPQZCJaRKoURwRotKucQ==" 19 | }, 20 | "@discordjs/form-data": { 21 | "version": "3.0.1", 22 | "resolved": "https://registry.npmjs.org/@discordjs/form-data/-/form-data-3.0.1.tgz", 23 | "integrity": "sha512-ZfFsbgEXW71Rw/6EtBdrP5VxBJy4dthyC0tpQKGKmYFImlmmrykO14Za+BiIVduwjte0jXEBlhSKf0MWbFp9Eg==", 24 | "requires": { 25 | "asynckit": "^0.4.0", 26 | "combined-stream": "^1.0.8", 27 | "mime-types": "^2.1.12" 28 | } 29 | }, 30 | "@jimp/bmp": { 31 | "version": "0.16.1", 32 | "resolved": "https://registry.npmjs.org/@jimp/bmp/-/bmp-0.16.1.tgz", 33 | "integrity": "sha512-iwyNYQeBawrdg/f24x3pQ5rEx+/GwjZcCXd3Kgc+ZUd+Ivia7sIqBsOnDaMZdKCBPlfW364ekexnlOqyVa0NWg==", 34 | "requires": { 35 | "@babel/runtime": "^7.7.2", 36 | "@jimp/utils": "^0.16.1", 37 | "bmp-js": "^0.1.0" 38 | } 39 | }, 40 | "@jimp/core": { 41 | "version": "0.16.1", 42 | "resolved": "https://registry.npmjs.org/@jimp/core/-/core-0.16.1.tgz", 43 | "integrity": "sha512-la7kQia31V6kQ4q1kI/uLimu8FXx7imWVajDGtwUG8fzePLWDFJyZl0fdIXVCL1JW2nBcRHidUot6jvlRDi2+g==", 44 | "requires": { 45 | "@babel/runtime": "^7.7.2", 46 | "@jimp/utils": "^0.16.1", 47 | "any-base": "^1.1.0", 48 | "buffer": "^5.2.0", 49 | "exif-parser": "^0.1.12", 50 | "file-type": "^9.0.0", 51 | "load-bmfont": "^1.3.1", 52 | "mkdirp": "^0.5.1", 53 | "phin": "^2.9.1", 54 | "pixelmatch": "^4.0.2", 55 | "tinycolor2": "^1.4.1" 56 | } 57 | }, 58 | "@jimp/custom": { 59 | "version": "0.16.1", 60 | "resolved": "https://registry.npmjs.org/@jimp/custom/-/custom-0.16.1.tgz", 61 | "integrity": "sha512-DNUAHNSiUI/j9hmbatD6WN/EBIyeq4AO0frl5ETtt51VN1SvE4t4v83ZA/V6ikxEf3hxLju4tQ5Pc3zmZkN/3A==", 62 | "requires": { 63 | "@babel/runtime": "^7.7.2", 64 | "@jimp/core": "^0.16.1" 65 | } 66 | }, 67 | "@jimp/gif": { 68 | "version": "0.16.1", 69 | "resolved": "https://registry.npmjs.org/@jimp/gif/-/gif-0.16.1.tgz", 70 | "integrity": "sha512-r/1+GzIW1D5zrP4tNrfW+3y4vqD935WBXSc8X/wm23QTY9aJO9Lw6PEdzpYCEY+SOklIFKaJYUAq/Nvgm/9ryw==", 71 | "requires": { 72 | "@babel/runtime": "^7.7.2", 73 | "@jimp/utils": "^0.16.1", 74 | "gifwrap": "^0.9.2", 75 | "omggif": "^1.0.9" 76 | } 77 | }, 78 | "@jimp/jpeg": { 79 | "version": "0.16.1", 80 | "resolved": "https://registry.npmjs.org/@jimp/jpeg/-/jpeg-0.16.1.tgz", 81 | "integrity": "sha512-8352zrdlCCLFdZ/J+JjBslDvml+fS3Z8gttdml0We759PnnZGqrnPRhkOEOJbNUlE+dD4ckLeIe6NPxlS/7U+w==", 82 | "requires": { 83 | "@babel/runtime": "^7.7.2", 84 | "@jimp/utils": "^0.16.1", 85 | "jpeg-js": "0.4.2" 86 | } 87 | }, 88 | "@jimp/plugin-blit": { 89 | "version": "0.16.1", 90 | "resolved": "https://registry.npmjs.org/@jimp/plugin-blit/-/plugin-blit-0.16.1.tgz", 91 | "integrity": "sha512-fKFNARm32RoLSokJ8WZXHHH2CGzz6ire2n1Jh6u+XQLhk9TweT1DcLHIXwQMh8oR12KgjbgsMGvrMVlVknmOAg==", 92 | "requires": { 93 | "@babel/runtime": "^7.7.2", 94 | "@jimp/utils": "^0.16.1" 95 | } 96 | }, 97 | "@jimp/plugin-blur": { 98 | "version": "0.16.1", 99 | "resolved": "https://registry.npmjs.org/@jimp/plugin-blur/-/plugin-blur-0.16.1.tgz", 100 | "integrity": "sha512-1WhuLGGj9MypFKRcPvmW45ht7nXkOKu+lg3n2VBzIB7r4kKNVchuI59bXaCYQumOLEqVK7JdB4glaDAbCQCLyw==", 101 | "requires": { 102 | "@babel/runtime": "^7.7.2", 103 | "@jimp/utils": "^0.16.1" 104 | } 105 | }, 106 | "@jimp/plugin-circle": { 107 | "version": "0.16.1", 108 | "resolved": "https://registry.npmjs.org/@jimp/plugin-circle/-/plugin-circle-0.16.1.tgz", 109 | "integrity": "sha512-JK7yi1CIU7/XL8hdahjcbGA3V7c+F+Iw+mhMQhLEi7Q0tCnZ69YJBTamMiNg3fWPVfMuvWJJKOBRVpwNTuaZRg==", 110 | "requires": { 111 | "@babel/runtime": "^7.7.2", 112 | "@jimp/utils": "^0.16.1" 113 | } 114 | }, 115 | "@jimp/plugin-color": { 116 | "version": "0.16.1", 117 | "resolved": "https://registry.npmjs.org/@jimp/plugin-color/-/plugin-color-0.16.1.tgz", 118 | "integrity": "sha512-9yQttBAO5SEFj7S6nJK54f+1BnuBG4c28q+iyzm1JjtnehjqMg6Ljw4gCSDCvoCQ3jBSYHN66pmwTV74SU1B7A==", 119 | "requires": { 120 | "@babel/runtime": "^7.7.2", 121 | "@jimp/utils": "^0.16.1", 122 | "tinycolor2": "^1.4.1" 123 | } 124 | }, 125 | "@jimp/plugin-contain": { 126 | "version": "0.16.1", 127 | "resolved": "https://registry.npmjs.org/@jimp/plugin-contain/-/plugin-contain-0.16.1.tgz", 128 | "integrity": "sha512-44F3dUIjBDHN+Ym/vEfg+jtjMjAqd2uw9nssN67/n4FdpuZUVs7E7wadKY1RRNuJO+WgcD5aDQcsvurXMETQTg==", 129 | "requires": { 130 | "@babel/runtime": "^7.7.2", 131 | "@jimp/utils": "^0.16.1" 132 | } 133 | }, 134 | "@jimp/plugin-cover": { 135 | "version": "0.16.1", 136 | "resolved": "https://registry.npmjs.org/@jimp/plugin-cover/-/plugin-cover-0.16.1.tgz", 137 | "integrity": "sha512-YztWCIldBAVo0zxcQXR+a/uk3/TtYnpKU2CanOPJ7baIuDlWPsG+YE4xTsswZZc12H9Kl7CiziEbDtvF9kwA/Q==", 138 | "requires": { 139 | "@babel/runtime": "^7.7.2", 140 | "@jimp/utils": "^0.16.1" 141 | } 142 | }, 143 | "@jimp/plugin-crop": { 144 | "version": "0.16.1", 145 | "resolved": "https://registry.npmjs.org/@jimp/plugin-crop/-/plugin-crop-0.16.1.tgz", 146 | "integrity": "sha512-UQdva9oQzCVadkyo3T5Tv2CUZbf0klm2cD4cWMlASuTOYgaGaFHhT9st+kmfvXjKL8q3STkBu/zUPV6PbuV3ew==", 147 | "requires": { 148 | "@babel/runtime": "^7.7.2", 149 | "@jimp/utils": "^0.16.1" 150 | } 151 | }, 152 | "@jimp/plugin-displace": { 153 | "version": "0.16.1", 154 | "resolved": "https://registry.npmjs.org/@jimp/plugin-displace/-/plugin-displace-0.16.1.tgz", 155 | "integrity": "sha512-iVAWuz2+G6Heu8gVZksUz+4hQYpR4R0R/RtBzpWEl8ItBe7O6QjORAkhxzg+WdYLL2A/Yd4ekTpvK0/qW8hTVw==", 156 | "requires": { 157 | "@babel/runtime": "^7.7.2", 158 | "@jimp/utils": "^0.16.1" 159 | } 160 | }, 161 | "@jimp/plugin-dither": { 162 | "version": "0.16.1", 163 | "resolved": "https://registry.npmjs.org/@jimp/plugin-dither/-/plugin-dither-0.16.1.tgz", 164 | "integrity": "sha512-tADKVd+HDC9EhJRUDwMvzBXPz4GLoU6s5P7xkVq46tskExYSptgj5713J5Thj3NMgH9Rsqu22jNg1H/7tr3V9Q==", 165 | "requires": { 166 | "@babel/runtime": "^7.7.2", 167 | "@jimp/utils": "^0.16.1" 168 | } 169 | }, 170 | "@jimp/plugin-fisheye": { 171 | "version": "0.16.1", 172 | "resolved": "https://registry.npmjs.org/@jimp/plugin-fisheye/-/plugin-fisheye-0.16.1.tgz", 173 | "integrity": "sha512-BWHnc5hVobviTyIRHhIy9VxI1ACf4CeSuCfURB6JZm87YuyvgQh5aX5UDKtOz/3haMHXBLP61ZBxlNpMD8CG4A==", 174 | "requires": { 175 | "@babel/runtime": "^7.7.2", 176 | "@jimp/utils": "^0.16.1" 177 | } 178 | }, 179 | "@jimp/plugin-flip": { 180 | "version": "0.16.1", 181 | "resolved": "https://registry.npmjs.org/@jimp/plugin-flip/-/plugin-flip-0.16.1.tgz", 182 | "integrity": "sha512-KdxTf0zErfZ8DyHkImDTnQBuHby+a5YFdoKI/G3GpBl3qxLBvC+PWkS2F/iN3H7wszP7/TKxTEvWL927pypT0w==", 183 | "requires": { 184 | "@babel/runtime": "^7.7.2", 185 | "@jimp/utils": "^0.16.1" 186 | } 187 | }, 188 | "@jimp/plugin-gaussian": { 189 | "version": "0.16.1", 190 | "resolved": "https://registry.npmjs.org/@jimp/plugin-gaussian/-/plugin-gaussian-0.16.1.tgz", 191 | "integrity": "sha512-u9n4wjskh3N1mSqketbL6tVcLU2S5TEaFPR40K6TDv4phPLZALi1Of7reUmYpVm8mBDHt1I6kGhuCJiWvzfGyg==", 192 | "requires": { 193 | "@babel/runtime": "^7.7.2", 194 | "@jimp/utils": "^0.16.1" 195 | } 196 | }, 197 | "@jimp/plugin-invert": { 198 | "version": "0.16.1", 199 | "resolved": "https://registry.npmjs.org/@jimp/plugin-invert/-/plugin-invert-0.16.1.tgz", 200 | "integrity": "sha512-2DKuyVXANH8WDpW9NG+PYFbehzJfweZszFYyxcaewaPLN0GxvxVLOGOPP1NuUTcHkOdMFbE0nHDuB7f+sYF/2w==", 201 | "requires": { 202 | "@babel/runtime": "^7.7.2", 203 | "@jimp/utils": "^0.16.1" 204 | } 205 | }, 206 | "@jimp/plugin-mask": { 207 | "version": "0.16.1", 208 | "resolved": "https://registry.npmjs.org/@jimp/plugin-mask/-/plugin-mask-0.16.1.tgz", 209 | "integrity": "sha512-snfiqHlVuj4bSFS0v96vo2PpqCDMe4JB+O++sMo5jF5mvGcGL6AIeLo8cYqPNpdO6BZpBJ8MY5El0Veckhr39Q==", 210 | "requires": { 211 | "@babel/runtime": "^7.7.2", 212 | "@jimp/utils": "^0.16.1" 213 | } 214 | }, 215 | "@jimp/plugin-normalize": { 216 | "version": "0.16.1", 217 | "resolved": "https://registry.npmjs.org/@jimp/plugin-normalize/-/plugin-normalize-0.16.1.tgz", 218 | "integrity": "sha512-dOQfIOvGLKDKXPU8xXWzaUeB0nvkosHw6Xg1WhS1Z5Q0PazByhaxOQkSKgUryNN/H+X7UdbDvlyh/yHf3ITRaw==", 219 | "requires": { 220 | "@babel/runtime": "^7.7.2", 221 | "@jimp/utils": "^0.16.1" 222 | } 223 | }, 224 | "@jimp/plugin-print": { 225 | "version": "0.16.1", 226 | "resolved": "https://registry.npmjs.org/@jimp/plugin-print/-/plugin-print-0.16.1.tgz", 227 | "integrity": "sha512-ceWgYN40jbN4cWRxixym+csyVymvrryuKBQ+zoIvN5iE6OyS+2d7Mn4zlNgumSczb9GGyZZESIgVcBDA1ezq0Q==", 228 | "requires": { 229 | "@babel/runtime": "^7.7.2", 230 | "@jimp/utils": "^0.16.1", 231 | "load-bmfont": "^1.4.0" 232 | } 233 | }, 234 | "@jimp/plugin-resize": { 235 | "version": "0.16.1", 236 | "resolved": "https://registry.npmjs.org/@jimp/plugin-resize/-/plugin-resize-0.16.1.tgz", 237 | "integrity": "sha512-u4JBLdRI7dargC04p2Ha24kofQBk3vhaf0q8FwSYgnCRwxfvh2RxvhJZk9H7Q91JZp6wgjz/SjvEAYjGCEgAwQ==", 238 | "requires": { 239 | "@babel/runtime": "^7.7.2", 240 | "@jimp/utils": "^0.16.1" 241 | } 242 | }, 243 | "@jimp/plugin-rotate": { 244 | "version": "0.16.1", 245 | "resolved": "https://registry.npmjs.org/@jimp/plugin-rotate/-/plugin-rotate-0.16.1.tgz", 246 | "integrity": "sha512-ZUU415gDQ0VjYutmVgAYYxC9Og9ixu2jAGMCU54mSMfuIlmohYfwARQmI7h4QB84M76c9hVLdONWjuo+rip/zg==", 247 | "requires": { 248 | "@babel/runtime": "^7.7.2", 249 | "@jimp/utils": "^0.16.1" 250 | } 251 | }, 252 | "@jimp/plugin-scale": { 253 | "version": "0.16.1", 254 | "resolved": "https://registry.npmjs.org/@jimp/plugin-scale/-/plugin-scale-0.16.1.tgz", 255 | "integrity": "sha512-jM2QlgThIDIc4rcyughD5O7sOYezxdafg/2Xtd1csfK3z6fba3asxDwthqPZAgitrLgiKBDp6XfzC07Y/CefUw==", 256 | "requires": { 257 | "@babel/runtime": "^7.7.2", 258 | "@jimp/utils": "^0.16.1" 259 | } 260 | }, 261 | "@jimp/plugin-shadow": { 262 | "version": "0.16.1", 263 | "resolved": "https://registry.npmjs.org/@jimp/plugin-shadow/-/plugin-shadow-0.16.1.tgz", 264 | "integrity": "sha512-MeD2Is17oKzXLnsphAa1sDstTu6nxscugxAEk3ji0GV1FohCvpHBcec0nAq6/czg4WzqfDts+fcPfC79qWmqrA==", 265 | "requires": { 266 | "@babel/runtime": "^7.7.2", 267 | "@jimp/utils": "^0.16.1" 268 | } 269 | }, 270 | "@jimp/plugin-threshold": { 271 | "version": "0.16.1", 272 | "resolved": "https://registry.npmjs.org/@jimp/plugin-threshold/-/plugin-threshold-0.16.1.tgz", 273 | "integrity": "sha512-iGW8U/wiCSR0+6syrPioVGoSzQFt4Z91SsCRbgNKTAk7D+XQv6OI78jvvYg4o0c2FOlwGhqz147HZV5utoSLxA==", 274 | "requires": { 275 | "@babel/runtime": "^7.7.2", 276 | "@jimp/utils": "^0.16.1" 277 | } 278 | }, 279 | "@jimp/plugins": { 280 | "version": "0.16.1", 281 | "resolved": "https://registry.npmjs.org/@jimp/plugins/-/plugins-0.16.1.tgz", 282 | "integrity": "sha512-c+lCqa25b+4q6mJZSetlxhMoYuiltyS+ValLzdwK/47+aYsq+kcJNl+TuxIEKf59yr9+5rkbpsPkZHLF/V7FFA==", 283 | "requires": { 284 | "@babel/runtime": "^7.7.2", 285 | "@jimp/plugin-blit": "^0.16.1", 286 | "@jimp/plugin-blur": "^0.16.1", 287 | "@jimp/plugin-circle": "^0.16.1", 288 | "@jimp/plugin-color": "^0.16.1", 289 | "@jimp/plugin-contain": "^0.16.1", 290 | "@jimp/plugin-cover": "^0.16.1", 291 | "@jimp/plugin-crop": "^0.16.1", 292 | "@jimp/plugin-displace": "^0.16.1", 293 | "@jimp/plugin-dither": "^0.16.1", 294 | "@jimp/plugin-fisheye": "^0.16.1", 295 | "@jimp/plugin-flip": "^0.16.1", 296 | "@jimp/plugin-gaussian": "^0.16.1", 297 | "@jimp/plugin-invert": "^0.16.1", 298 | "@jimp/plugin-mask": "^0.16.1", 299 | "@jimp/plugin-normalize": "^0.16.1", 300 | "@jimp/plugin-print": "^0.16.1", 301 | "@jimp/plugin-resize": "^0.16.1", 302 | "@jimp/plugin-rotate": "^0.16.1", 303 | "@jimp/plugin-scale": "^0.16.1", 304 | "@jimp/plugin-shadow": "^0.16.1", 305 | "@jimp/plugin-threshold": "^0.16.1", 306 | "timm": "^1.6.1" 307 | } 308 | }, 309 | "@jimp/png": { 310 | "version": "0.16.1", 311 | "resolved": "https://registry.npmjs.org/@jimp/png/-/png-0.16.1.tgz", 312 | "integrity": "sha512-iyWoCxEBTW0OUWWn6SveD4LePW89kO7ZOy5sCfYeDM/oTPLpR8iMIGvZpZUz1b8kvzFr27vPst4E5rJhGjwsdw==", 313 | "requires": { 314 | "@babel/runtime": "^7.7.2", 315 | "@jimp/utils": "^0.16.1", 316 | "pngjs": "^3.3.3" 317 | } 318 | }, 319 | "@jimp/tiff": { 320 | "version": "0.16.1", 321 | "resolved": "https://registry.npmjs.org/@jimp/tiff/-/tiff-0.16.1.tgz", 322 | "integrity": "sha512-3K3+xpJS79RmSkAvFMgqY5dhSB+/sxhwTFA9f4AVHUK0oKW+u6r52Z1L0tMXHnpbAdR9EJ+xaAl2D4x19XShkQ==", 323 | "requires": { 324 | "@babel/runtime": "^7.7.2", 325 | "utif": "^2.0.1" 326 | } 327 | }, 328 | "@jimp/types": { 329 | "version": "0.16.1", 330 | "resolved": "https://registry.npmjs.org/@jimp/types/-/types-0.16.1.tgz", 331 | "integrity": "sha512-g1w/+NfWqiVW4CaXSJyD28JQqZtm2eyKMWPhBBDCJN9nLCN12/Az0WFF3JUAktzdsEC2KRN2AqB1a2oMZBNgSQ==", 332 | "requires": { 333 | "@babel/runtime": "^7.7.2", 334 | "@jimp/bmp": "^0.16.1", 335 | "@jimp/gif": "^0.16.1", 336 | "@jimp/jpeg": "^0.16.1", 337 | "@jimp/png": "^0.16.1", 338 | "@jimp/tiff": "^0.16.1", 339 | "timm": "^1.6.1" 340 | } 341 | }, 342 | "@jimp/utils": { 343 | "version": "0.16.1", 344 | "resolved": "https://registry.npmjs.org/@jimp/utils/-/utils-0.16.1.tgz", 345 | "integrity": "sha512-8fULQjB0x4LzUSiSYG6ZtQl355sZjxbv8r9PPAuYHzS9sGiSHJQavNqK/nKnpDsVkU88/vRGcE7t3nMU0dEnVw==", 346 | "requires": { 347 | "@babel/runtime": "^7.7.2", 348 | "regenerator-runtime": "^0.13.3" 349 | } 350 | }, 351 | "@sindresorhus/is": { 352 | "version": "4.0.0", 353 | "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-4.0.0.tgz", 354 | "integrity": "sha512-FyD2meJpDPjyNQejSjvnhpgI/azsQkA4lGbuu5BQZfjvJ9cbRZXzeWL2HceCekW4lixO9JPesIIQkSoLjeJHNQ==" 355 | }, 356 | "@szmarczak/http-timer": { 357 | "version": "4.0.5", 358 | "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-4.0.5.tgz", 359 | "integrity": "sha512-PyRA9sm1Yayuj5OIoJ1hGt2YISX45w9WcFbh6ddT0Z/0yaFxOtGLInr4jUfU1EAFVs0Yfyfev4RNwBlUaHdlDQ==", 360 | "requires": { 361 | "defer-to-connect": "^2.0.0" 362 | } 363 | }, 364 | "@types/bson": { 365 | "version": "4.0.3", 366 | "resolved": "https://registry.npmjs.org/@types/bson/-/bson-4.0.3.tgz", 367 | "integrity": "sha512-mVRvYnTOZJz3ccpxhr3wgxVmSeiYinW+zlzQz3SXWaJmD1DuL05Jeq7nKw3SnbKmbleW5qrLG5vdyWe/A9sXhw==", 368 | "requires": { 369 | "@types/node": "*" 370 | } 371 | }, 372 | "@types/cacheable-request": { 373 | "version": "6.0.1", 374 | "resolved": "https://registry.npmjs.org/@types/cacheable-request/-/cacheable-request-6.0.1.tgz", 375 | "integrity": "sha512-ykFq2zmBGOCbpIXtoVbz4SKY5QriWPh3AjyU4G74RYbtt5yOc5OfaY75ftjg7mikMOla1CTGpX3lLbuJh8DTrQ==", 376 | "requires": { 377 | "@types/http-cache-semantics": "*", 378 | "@types/keyv": "*", 379 | "@types/node": "*", 380 | "@types/responselike": "*" 381 | } 382 | }, 383 | "@types/http-cache-semantics": { 384 | "version": "4.0.0", 385 | "resolved": "https://registry.npmjs.org/@types/http-cache-semantics/-/http-cache-semantics-4.0.0.tgz", 386 | "integrity": "sha512-c3Xy026kOF7QOTn00hbIllV1dLR9hG9NkSrLQgCVs8NF6sBU+VGWjD3wLPhmh1TYAc7ugCFsvHYMN4VcBN1U1A==" 387 | }, 388 | "@types/keyv": { 389 | "version": "3.1.1", 390 | "resolved": "https://registry.npmjs.org/@types/keyv/-/keyv-3.1.1.tgz", 391 | "integrity": "sha512-MPtoySlAZQ37VoLaPcTHCu1RWJ4llDkULYZIzOYxlhxBqYPB0RsRlmMU0R6tahtFe27mIdkHV+551ZWV4PLmVw==", 392 | "requires": { 393 | "@types/node": "*" 394 | } 395 | }, 396 | "@types/mongodb": { 397 | "version": "3.6.3", 398 | "resolved": "https://registry.npmjs.org/@types/mongodb/-/mongodb-3.6.3.tgz", 399 | "integrity": "sha512-6YNqGP1hk5bjUFaim+QoFFuI61WjHiHE1BNeB41TA00Xd2K7zG4lcWyLLq/XtIp36uMavvS5hoAUJ+1u/GcX2Q==", 400 | "requires": { 401 | "@types/bson": "*", 402 | "@types/node": "*" 403 | } 404 | }, 405 | "@types/node": { 406 | "version": "14.14.20", 407 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.14.20.tgz", 408 | "integrity": "sha512-Y93R97Ouif9JEOWPIUyU+eyIdyRqQR0I8Ez1dzku4hDx34NWh4HbtIc3WNzwB1Y9ULvNGeu5B8h8bVL5cAk4/A==" 409 | }, 410 | "@types/responselike": { 411 | "version": "1.0.0", 412 | "resolved": "https://registry.npmjs.org/@types/responselike/-/responselike-1.0.0.tgz", 413 | "integrity": "sha512-85Y2BjiufFzaMIlvJDvTTB8Fxl2xfLo4HgmHzVBz08w4wDePCTjYw66PdrolO0kzli3yam/YCgRufyo1DdQVTA==", 414 | "requires": { 415 | "@types/node": "*" 416 | } 417 | }, 418 | "abbrev": { 419 | "version": "1.1.1", 420 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 421 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 422 | }, 423 | "abort-controller": { 424 | "version": "3.0.0", 425 | "resolved": "https://registry.npmjs.org/abort-controller/-/abort-controller-3.0.0.tgz", 426 | "integrity": "sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==", 427 | "requires": { 428 | "event-target-shim": "^5.0.0" 429 | } 430 | }, 431 | "alexflipnote.js": { 432 | "version": "2.3.4", 433 | "resolved": "https://registry.npmjs.org/alexflipnote.js/-/alexflipnote.js-2.3.4.tgz", 434 | "integrity": "sha512-avVLS3v04CAZHS4wEmyiGTAN09vuEr2PmTn9zpk7oc+HtQwIXArzK3pXv7L53OJqVC77xFyZ70hMCA9iQk5C4Q==", 435 | "requires": { 436 | "node-fetch": "^2.6.1" 437 | } 438 | }, 439 | "amdefine": { 440 | "version": "1.0.1", 441 | "resolved": "https://registry.npmjs.org/amdefine/-/amdefine-1.0.1.tgz", 442 | "integrity": "sha1-SlKCrBZHKek2Gbz9OtFR+BfOkfU=" 443 | }, 444 | "ansi-regex": { 445 | "version": "2.1.1", 446 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 447 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 448 | }, 449 | "any-base": { 450 | "version": "1.1.0", 451 | "resolved": "https://registry.npmjs.org/any-base/-/any-base-1.1.0.tgz", 452 | "integrity": "sha512-uMgjozySS8adZZYePpaWs8cxB9/kdzmpX6SgJZ+wbz1K5eYk5QMYDVJaZKhxyIHUdnnJkfR7SVgStgH7LkGUyg==" 453 | }, 454 | "any-promise": { 455 | "version": "1.3.0", 456 | "resolved": "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz", 457 | "integrity": "sha1-q8av7tzqUugJzcA3au0845Y10X8=" 458 | }, 459 | "aproba": { 460 | "version": "1.2.0", 461 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", 462 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==" 463 | }, 464 | "are-we-there-yet": { 465 | "version": "1.1.5", 466 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz", 467 | "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==", 468 | "requires": { 469 | "delegates": "^1.0.0", 470 | "readable-stream": "^2.0.6" 471 | } 472 | }, 473 | "asynckit": { 474 | "version": "0.4.0", 475 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 476 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 477 | }, 478 | "balanced-match": { 479 | "version": "1.0.0", 480 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 481 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 482 | }, 483 | "barse": { 484 | "version": "0.4.3", 485 | "resolved": "https://registry.npmjs.org/barse/-/barse-0.4.3.tgz", 486 | "integrity": "sha1-KJhk15XQECu7sYHmbs0IxUobwMs=", 487 | "requires": { 488 | "readable-stream": "~1.0.2" 489 | }, 490 | "dependencies": { 491 | "isarray": { 492 | "version": "0.0.1", 493 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 494 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=" 495 | }, 496 | "readable-stream": { 497 | "version": "1.0.34", 498 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.0.34.tgz", 499 | "integrity": "sha1-Elgg40vIQtLyqq+v5MKRbuMsFXw=", 500 | "requires": { 501 | "core-util-is": "~1.0.0", 502 | "inherits": "~2.0.1", 503 | "isarray": "0.0.1", 504 | "string_decoder": "~0.10.x" 505 | } 506 | }, 507 | "string_decoder": { 508 | "version": "0.10.31", 509 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 510 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=" 511 | } 512 | } 513 | }, 514 | "base64-js": { 515 | "version": "1.5.1", 516 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 517 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==" 518 | }, 519 | "biskviit": { 520 | "version": "1.0.1", 521 | "resolved": "https://registry.npmjs.org/biskviit/-/biskviit-1.0.1.tgz", 522 | "integrity": "sha1-A3oM1LcbnjMf2QoRIt4X3EnkIKc=", 523 | "requires": { 524 | "psl": "^1.1.7" 525 | } 526 | }, 527 | "bl": { 528 | "version": "2.2.1", 529 | "resolved": "https://registry.npmjs.org/bl/-/bl-2.2.1.tgz", 530 | "integrity": "sha512-6Pesp1w0DEX1N550i/uGV/TqucVL4AM/pgThFSN/Qq9si1/DF9aIHs1BxD8V/QU0HoeHO6cQRTAuYnLPKq1e4g==", 531 | "requires": { 532 | "readable-stream": "^2.3.5", 533 | "safe-buffer": "^5.1.1" 534 | } 535 | }, 536 | "bluebird": { 537 | "version": "3.5.1", 538 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", 539 | "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==" 540 | }, 541 | "bmp-js": { 542 | "version": "0.1.0", 543 | "resolved": "https://registry.npmjs.org/bmp-js/-/bmp-js-0.1.0.tgz", 544 | "integrity": "sha1-4Fpj95amwf8l9Hcex62twUjAcjM=" 545 | }, 546 | "boolbase": { 547 | "version": "1.0.0", 548 | "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz", 549 | "integrity": "sha1-aN/1++YMUes3cl6p4+0xDcwed24=" 550 | }, 551 | "brace-expansion": { 552 | "version": "1.1.11", 553 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 554 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 555 | "requires": { 556 | "balanced-match": "^1.0.0", 557 | "concat-map": "0.0.1" 558 | } 559 | }, 560 | "bson": { 561 | "version": "1.1.5", 562 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.5.tgz", 563 | "integrity": "sha512-kDuEzldR21lHciPQAIulLs1LZlCXdLziXI6Mb/TDkwXhb//UORJNPXgcRs2CuO4H0DcMkpfT3/ySsP3unoZjBg==" 564 | }, 565 | "buffer": { 566 | "version": "5.7.1", 567 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", 568 | "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", 569 | "requires": { 570 | "base64-js": "^1.3.1", 571 | "ieee754": "^1.1.13" 572 | } 573 | }, 574 | "buffer-equal": { 575 | "version": "0.0.1", 576 | "resolved": "https://registry.npmjs.org/buffer-equal/-/buffer-equal-0.0.1.tgz", 577 | "integrity": "sha1-kbx0sR6kBbyRa8aqkI+q+ltKrEs=" 578 | }, 579 | "cacheable-lookup": { 580 | "version": "5.0.4", 581 | "resolved": "https://registry.npmjs.org/cacheable-lookup/-/cacheable-lookup-5.0.4.tgz", 582 | "integrity": "sha512-2/kNscPhpcxrOigMZzbiWF7dz8ilhb/nIHU3EyZiXWXpeq/au8qJ8VhdftMkty3n7Gj6HIGalQG8oiBNB3AJgA==" 583 | }, 584 | "cacheable-request": { 585 | "version": "7.0.1", 586 | "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-7.0.1.tgz", 587 | "integrity": "sha512-lt0mJ6YAnsrBErpTMWeu5kl/tg9xMAWjavYTN6VQXM1A/teBITuNcccXsCxF0tDQQJf9DfAaX5O4e0zp0KlfZw==", 588 | "requires": { 589 | "clone-response": "^1.0.2", 590 | "get-stream": "^5.1.0", 591 | "http-cache-semantics": "^4.0.0", 592 | "keyv": "^4.0.0", 593 | "lowercase-keys": "^2.0.0", 594 | "normalize-url": "^4.1.0", 595 | "responselike": "^2.0.0" 596 | } 597 | }, 598 | "canvas": { 599 | "version": "2.6.1", 600 | "resolved": "https://registry.npmjs.org/canvas/-/canvas-2.6.1.tgz", 601 | "integrity": "sha512-S98rKsPcuhfTcYbtF53UIJhcbgIAK533d1kJKMwsMwAIFgfd58MOyxRud3kktlzWiEkFliaJtvyZCBtud/XVEA==", 602 | "requires": { 603 | "nan": "^2.14.0", 604 | "node-pre-gyp": "^0.11.0", 605 | "simple-get": "^3.0.3" 606 | } 607 | }, 608 | "cheerio": { 609 | "version": "1.0.0-rc.5", 610 | "resolved": "https://registry.npmjs.org/cheerio/-/cheerio-1.0.0-rc.5.tgz", 611 | "integrity": "sha512-yoqps/VCaZgN4pfXtenwHROTp8NG6/Hlt4Jpz2FEP0ZJQ+ZUkVDd0hAPDNKhj3nakpfPt/CNs57yEtxD1bXQiw==", 612 | "requires": { 613 | "cheerio-select-tmp": "^0.1.0", 614 | "dom-serializer": "~1.2.0", 615 | "domhandler": "^4.0.0", 616 | "entities": "~2.1.0", 617 | "htmlparser2": "^6.0.0", 618 | "parse5": "^6.0.0", 619 | "parse5-htmlparser2-tree-adapter": "^6.0.0" 620 | } 621 | }, 622 | "cheerio-select-tmp": { 623 | "version": "0.1.1", 624 | "resolved": "https://registry.npmjs.org/cheerio-select-tmp/-/cheerio-select-tmp-0.1.1.tgz", 625 | "integrity": "sha512-YYs5JvbpU19VYJyj+F7oYrIE2BOll1/hRU7rEy/5+v9BzkSo3bK81iAeeQEMI92vRIxz677m72UmJUiVwwgjfQ==", 626 | "requires": { 627 | "css-select": "^3.1.2", 628 | "css-what": "^4.0.0", 629 | "domelementtype": "^2.1.0", 630 | "domhandler": "^4.0.0", 631 | "domutils": "^2.4.4" 632 | } 633 | }, 634 | "chownr": { 635 | "version": "1.1.4", 636 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz", 637 | "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==" 638 | }, 639 | "clone-response": { 640 | "version": "1.0.2", 641 | "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz", 642 | "integrity": "sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws=", 643 | "requires": { 644 | "mimic-response": "^1.0.0" 645 | } 646 | }, 647 | "code-point-at": { 648 | "version": "1.1.0", 649 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 650 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" 651 | }, 652 | "combined-stream": { 653 | "version": "1.0.8", 654 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 655 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 656 | "requires": { 657 | "delayed-stream": "~1.0.0" 658 | } 659 | }, 660 | "commander": { 661 | "version": "2.8.1", 662 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.8.1.tgz", 663 | "integrity": "sha1-Br42f+v9oMMwqh4qBy09yXYkJdQ=", 664 | "requires": { 665 | "graceful-readlink": ">= 1.0.0" 666 | } 667 | }, 668 | "compressjs": { 669 | "version": "1.0.3", 670 | "resolved": "https://registry.npmjs.org/compressjs/-/compressjs-1.0.3.tgz", 671 | "integrity": "sha1-ldt03VuQOM+AvKMhqw7eJxtJWbY=", 672 | "requires": { 673 | "amdefine": "~1.0.0", 674 | "commander": "~2.8.1" 675 | } 676 | }, 677 | "concat-map": { 678 | "version": "0.0.1", 679 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 680 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 681 | }, 682 | "console-control-strings": { 683 | "version": "1.1.0", 684 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 685 | "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=" 686 | }, 687 | "core-util-is": { 688 | "version": "1.0.2", 689 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 690 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 691 | }, 692 | "css-select": { 693 | "version": "3.1.2", 694 | "resolved": "https://registry.npmjs.org/css-select/-/css-select-3.1.2.tgz", 695 | "integrity": "sha512-qmss1EihSuBNWNNhHjxzxSfJoFBM/lERB/Q4EnsJQQC62R2evJDW481091oAdOr9uh46/0n4nrg0It5cAnj1RA==", 696 | "requires": { 697 | "boolbase": "^1.0.0", 698 | "css-what": "^4.0.0", 699 | "domhandler": "^4.0.0", 700 | "domutils": "^2.4.3", 701 | "nth-check": "^2.0.0" 702 | } 703 | }, 704 | "css-what": { 705 | "version": "4.0.0", 706 | "resolved": "https://registry.npmjs.org/css-what/-/css-what-4.0.0.tgz", 707 | "integrity": "sha512-teijzG7kwYfNVsUh2H/YN62xW3KK9YhXEgSlbxMlcyjPNvdKJqFx5lrwlJgoFP1ZHlB89iGDlo/JyshKeRhv5A==" 708 | }, 709 | "debug": { 710 | "version": "3.1.0", 711 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 712 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 713 | "requires": { 714 | "ms": "2.0.0" 715 | }, 716 | "dependencies": { 717 | "ms": { 718 | "version": "2.0.0", 719 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 720 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 721 | } 722 | } 723 | }, 724 | "decompress-response": { 725 | "version": "6.0.0", 726 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-6.0.0.tgz", 727 | "integrity": "sha512-aW35yZM6Bb/4oJlZncMH2LCoZtJXTRxES17vE3hoRiowU2kWHaJKFkSBDnDR+cm9J+9QhXmREyIfv0pji9ejCQ==", 728 | "requires": { 729 | "mimic-response": "^3.1.0" 730 | }, 731 | "dependencies": { 732 | "mimic-response": { 733 | "version": "3.1.0", 734 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-3.1.0.tgz", 735 | "integrity": "sha512-z0yWI+4FDrrweS8Zmt4Ej5HdJmky15+L2e6Wgn3+iK5fWzb6T3fhNFq2+MeTRb064c6Wr4N/wv0DzQTjNzHNGQ==" 736 | } 737 | } 738 | }, 739 | "deep-extend": { 740 | "version": "0.6.0", 741 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 742 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==" 743 | }, 744 | "defer-to-connect": { 745 | "version": "2.0.0", 746 | "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-2.0.0.tgz", 747 | "integrity": "sha512-bYL2d05vOSf1JEZNx5vSAtPuBMkX8K9EUutg7zlKvTqKXHt7RhWJFbmd7qakVuf13i+IkGmp6FwSsONOf6VYIg==" 748 | }, 749 | "delayed-stream": { 750 | "version": "1.0.0", 751 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 752 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" 753 | }, 754 | "delegates": { 755 | "version": "1.0.0", 756 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 757 | "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=" 758 | }, 759 | "denque": { 760 | "version": "1.5.0", 761 | "resolved": "https://registry.npmjs.org/denque/-/denque-1.5.0.tgz", 762 | "integrity": "sha512-CYiCSgIF1p6EUByQPlGkKnP1M9g0ZV3qMIrqMqZqdwazygIA/YP2vrbcyl1h/WppKJTdl1F85cXIle+394iDAQ==" 763 | }, 764 | "detect-libc": { 765 | "version": "1.0.3", 766 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-1.0.3.tgz", 767 | "integrity": "sha1-+hN8S9aY7fVc1c0CrFWfkaTEups=" 768 | }, 769 | "discord.js": { 770 | "version": "12.5.1", 771 | "resolved": "https://registry.npmjs.org/discord.js/-/discord.js-12.5.1.tgz", 772 | "integrity": "sha512-VwZkVaUAIOB9mKdca0I5MefPMTQJTNg0qdgi1huF3iwsFwJ0L5s/Y69AQe+iPmjuV6j9rtKoG0Ta0n9vgEIL6w==", 773 | "requires": { 774 | "@discordjs/collection": "^0.1.6", 775 | "@discordjs/form-data": "^3.0.1", 776 | "abort-controller": "^3.0.0", 777 | "node-fetch": "^2.6.1", 778 | "prism-media": "^1.2.2", 779 | "setimmediate": "^1.0.5", 780 | "tweetnacl": "^1.0.3", 781 | "ws": "^7.3.1" 782 | } 783 | }, 784 | "dom-serializer": { 785 | "version": "1.2.0", 786 | "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-1.2.0.tgz", 787 | "integrity": "sha512-n6kZFH/KlCrqs/1GHMOd5i2fd/beQHuehKdWvNNffbGHTr/almdhuVvTVFb3V7fglz+nC50fFusu3lY33h12pA==", 788 | "requires": { 789 | "domelementtype": "^2.0.1", 790 | "domhandler": "^4.0.0", 791 | "entities": "^2.0.0" 792 | } 793 | }, 794 | "dom-walk": { 795 | "version": "0.1.2", 796 | "resolved": "https://registry.npmjs.org/dom-walk/-/dom-walk-0.1.2.tgz", 797 | "integrity": "sha512-6QvTW9mrGeIegrFXdtQi9pk7O/nSK6lSdXW2eqUspN5LWD7UTji2Fqw5V2YLjBpHEoU9Xl/eUWNpDeZvoyOv2w==" 798 | }, 799 | "domelementtype": { 800 | "version": "2.1.0", 801 | "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.1.0.tgz", 802 | "integrity": "sha512-LsTgx/L5VpD+Q8lmsXSHW2WpA+eBlZ9HPf3erD1IoPF00/3JKHZ3BknUVA2QGDNu69ZNmyFmCWBSO45XjYKC5w==" 803 | }, 804 | "domhandler": { 805 | "version": "4.0.0", 806 | "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-4.0.0.tgz", 807 | "integrity": "sha512-KPTbnGQ1JeEMQyO1iYXoagsI6so/C96HZiFyByU3T6iAzpXn8EGEvct6unm1ZGoed8ByO2oirxgwxBmqKF9haA==", 808 | "requires": { 809 | "domelementtype": "^2.1.0" 810 | } 811 | }, 812 | "domutils": { 813 | "version": "2.4.4", 814 | "resolved": "https://registry.npmjs.org/domutils/-/domutils-2.4.4.tgz", 815 | "integrity": "sha512-jBC0vOsECI4OMdD0GC9mGn7NXPLb+Qt6KW1YDQzeQYRUFKmNG8lh7mO5HiELfr+lLQE7loDVI4QcAxV80HS+RA==", 816 | "requires": { 817 | "dom-serializer": "^1.0.1", 818 | "domelementtype": "^2.0.1", 819 | "domhandler": "^4.0.0" 820 | } 821 | }, 822 | "dotenv": { 823 | "version": "8.2.0", 824 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.2.0.tgz", 825 | "integrity": "sha512-8sJ78ElpbDJBHNeBzUbUVLsqKdccaa/BXF1uPTw3GrvQTBgrQrtObr2mUrE38vzYd8cEv+m/JBfDLioYcfXoaw==" 826 | }, 827 | "encoding": { 828 | "version": "0.1.12", 829 | "resolved": "https://registry.npmjs.org/encoding/-/encoding-0.1.12.tgz", 830 | "integrity": "sha1-U4tm8+5izRq1HsMjgp0flIDHS+s=", 831 | "requires": { 832 | "iconv-lite": "~0.4.13" 833 | }, 834 | "dependencies": { 835 | "iconv-lite": { 836 | "version": "0.4.24", 837 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 838 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 839 | "requires": { 840 | "safer-buffer": ">= 2.1.2 < 3" 841 | } 842 | } 843 | } 844 | }, 845 | "end-of-stream": { 846 | "version": "1.4.4", 847 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 848 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 849 | "requires": { 850 | "once": "^1.4.0" 851 | } 852 | }, 853 | "entities": { 854 | "version": "2.1.0", 855 | "resolved": "https://registry.npmjs.org/entities/-/entities-2.1.0.tgz", 856 | "integrity": "sha512-hCx1oky9PFrJ611mf0ifBLBRW8lUUVRlFolb5gWRfIELabBlbp9xZvrqZLZAs+NxFnbfQoeGd8wDkygjg7U85w==" 857 | }, 858 | "event-target-shim": { 859 | "version": "5.0.1", 860 | "resolved": "https://registry.npmjs.org/event-target-shim/-/event-target-shim-5.0.1.tgz", 861 | "integrity": "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ==" 862 | }, 863 | "event-to-promise": { 864 | "version": "0.7.0", 865 | "resolved": "https://registry.npmjs.org/event-to-promise/-/event-to-promise-0.7.0.tgz", 866 | "integrity": "sha1-ywffzUGNoiIdkPd+q3E7wjXiCQ8=" 867 | }, 868 | "exif-parser": { 869 | "version": "0.1.12", 870 | "resolved": "https://registry.npmjs.org/exif-parser/-/exif-parser-0.1.12.tgz", 871 | "integrity": "sha1-WKnS1ywCwfbwKg70qRZicrd2CSI=" 872 | }, 873 | "fetch": { 874 | "version": "1.1.0", 875 | "resolved": "https://registry.npmjs.org/fetch/-/fetch-1.1.0.tgz", 876 | "integrity": "sha1-CoJ58Gvjf58Ou1Z1YKMKSA2lmi4=", 877 | "requires": { 878 | "biskviit": "1.0.1", 879 | "encoding": "0.1.12" 880 | } 881 | }, 882 | "file-type": { 883 | "version": "9.0.0", 884 | "resolved": "https://registry.npmjs.org/file-type/-/file-type-9.0.0.tgz", 885 | "integrity": "sha512-Qe/5NJrgIOlwijpq3B7BEpzPFcgzggOTagZmkXQY4LA6bsXKTUstK7Wp12lEJ/mLKTpvIZxmIuRcLYWT6ov9lw==" 886 | }, 887 | "fs-extra": { 888 | "version": "8.1.0", 889 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", 890 | "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", 891 | "requires": { 892 | "graceful-fs": "^4.2.0", 893 | "jsonfile": "^4.0.0", 894 | "universalify": "^0.1.0" 895 | }, 896 | "dependencies": { 897 | "jsonfile": { 898 | "version": "4.0.0", 899 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", 900 | "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", 901 | "requires": { 902 | "graceful-fs": "^4.1.6" 903 | } 904 | } 905 | } 906 | }, 907 | "fs-minipass": { 908 | "version": "1.2.7", 909 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-1.2.7.tgz", 910 | "integrity": "sha512-GWSSJGFy4e9GUeCcbIkED+bgAoFyj7XF1mV8rma3QW4NIqX9Kyx79N/PF61H5udOV3aY1IaMLs6pGbH71nlCTA==", 911 | "requires": { 912 | "minipass": "^2.6.0" 913 | } 914 | }, 915 | "fs.realpath": { 916 | "version": "1.0.0", 917 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 918 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 919 | }, 920 | "gamedig": { 921 | "version": "2.0.24", 922 | "resolved": "https://registry.npmjs.org/gamedig/-/gamedig-2.0.24.tgz", 923 | "integrity": "sha512-ssyCGxPYD2y9T35ShROZvwWeH51S7WR+K5alq0wbimjbBXe30/I7UxpnK1GGKtYZYvS0ETUg1zI7Mg9tcgAXZQ==", 924 | "requires": { 925 | "cheerio": "^1.0.0-rc.3", 926 | "compressjs": "^1.0.2", 927 | "gbxremote": "^0.2.1", 928 | "got": "^11.5.1", 929 | "iconv-lite": "^0.6.2", 930 | "long": "^4.0.0", 931 | "minimist": "^1.2.5", 932 | "moment": "^2.27.0", 933 | "punycode": "^2.1.1", 934 | "varint": "^5.0.0" 935 | } 936 | }, 937 | "gauge": { 938 | "version": "2.7.4", 939 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", 940 | "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", 941 | "requires": { 942 | "aproba": "^1.0.3", 943 | "console-control-strings": "^1.0.0", 944 | "has-unicode": "^2.0.0", 945 | "object-assign": "^4.1.0", 946 | "signal-exit": "^3.0.0", 947 | "string-width": "^1.0.1", 948 | "strip-ansi": "^3.0.1", 949 | "wide-align": "^1.1.0" 950 | } 951 | }, 952 | "gbxremote": { 953 | "version": "0.2.1", 954 | "resolved": "https://registry.npmjs.org/gbxremote/-/gbxremote-0.2.1.tgz", 955 | "integrity": "sha1-hN9PvXgXgNxdaS0krASi1/Bd23w=", 956 | "requires": { 957 | "any-promise": "^1.1.0", 958 | "barse": "~0.4.2", 959 | "event-to-promise": "^0.7.0", 960 | "string-to-stream": "^1.0.1", 961 | "xmlrpc": "^1.3.1" 962 | } 963 | }, 964 | "get-stream": { 965 | "version": "5.2.0", 966 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", 967 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", 968 | "requires": { 969 | "pump": "^3.0.0" 970 | } 971 | }, 972 | "gifwrap": { 973 | "version": "0.9.2", 974 | "resolved": "https://registry.npmjs.org/gifwrap/-/gifwrap-0.9.2.tgz", 975 | "integrity": "sha512-fcIswrPaiCDAyO8xnWvHSZdWChjKXUanKKpAiWWJ/UTkEi/aYKn5+90e7DE820zbEaVR9CE2y4z9bzhQijZ0BA==", 976 | "requires": { 977 | "image-q": "^1.1.1", 978 | "omggif": "^1.0.10" 979 | } 980 | }, 981 | "glob": { 982 | "version": "7.1.6", 983 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 984 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 985 | "requires": { 986 | "fs.realpath": "^1.0.0", 987 | "inflight": "^1.0.4", 988 | "inherits": "2", 989 | "minimatch": "^3.0.4", 990 | "once": "^1.3.0", 991 | "path-is-absolute": "^1.0.0" 992 | } 993 | }, 994 | "global": { 995 | "version": "4.4.0", 996 | "resolved": "https://registry.npmjs.org/global/-/global-4.4.0.tgz", 997 | "integrity": "sha512-wv/LAoHdRE3BeTGz53FAamhGlPLhlssK45usmGFThIi4XqnBmjKQ16u+RNbP7WvigRZDxUsM0J3gcQ5yicaL0w==", 998 | "requires": { 999 | "min-document": "^2.19.0", 1000 | "process": "^0.11.10" 1001 | } 1002 | }, 1003 | "got": { 1004 | "version": "11.8.1", 1005 | "resolved": "https://registry.npmjs.org/got/-/got-11.8.1.tgz", 1006 | "integrity": "sha512-9aYdZL+6nHmvJwHALLwKSUZ0hMwGaJGYv3hoPLPgnT8BoBXm1SjnZeky+91tfwJaDzun2s4RsBRy48IEYv2q2Q==", 1007 | "requires": { 1008 | "@sindresorhus/is": "^4.0.0", 1009 | "@szmarczak/http-timer": "^4.0.5", 1010 | "@types/cacheable-request": "^6.0.1", 1011 | "@types/responselike": "^1.0.0", 1012 | "cacheable-lookup": "^5.0.3", 1013 | "cacheable-request": "^7.0.1", 1014 | "decompress-response": "^6.0.0", 1015 | "http2-wrapper": "^1.0.0-beta.5.2", 1016 | "lowercase-keys": "^2.0.0", 1017 | "p-cancelable": "^2.0.0", 1018 | "responselike": "^2.0.0" 1019 | } 1020 | }, 1021 | "graceful-fs": { 1022 | "version": "4.2.4", 1023 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", 1024 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==" 1025 | }, 1026 | "graceful-readlink": { 1027 | "version": "1.0.1", 1028 | "resolved": "https://registry.npmjs.org/graceful-readlink/-/graceful-readlink-1.0.1.tgz", 1029 | "integrity": "sha1-TK+tdrxi8C+gObL5Tpo906ORpyU=" 1030 | }, 1031 | "has-unicode": { 1032 | "version": "2.0.1", 1033 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 1034 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" 1035 | }, 1036 | "htmlparser2": { 1037 | "version": "6.0.0", 1038 | "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-6.0.0.tgz", 1039 | "integrity": "sha512-numTQtDZMoh78zJpaNdJ9MXb2cv5G3jwUoe3dMQODubZvLoGvTE/Ofp6sHvH8OGKcN/8A47pGLi/k58xHP/Tfw==", 1040 | "requires": { 1041 | "domelementtype": "^2.0.1", 1042 | "domhandler": "^4.0.0", 1043 | "domutils": "^2.4.4", 1044 | "entities": "^2.0.0" 1045 | } 1046 | }, 1047 | "http-cache-semantics": { 1048 | "version": "4.1.0", 1049 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz", 1050 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==" 1051 | }, 1052 | "http2-wrapper": { 1053 | "version": "1.0.0-beta.5.2", 1054 | "resolved": "https://registry.npmjs.org/http2-wrapper/-/http2-wrapper-1.0.0-beta.5.2.tgz", 1055 | "integrity": "sha512-xYz9goEyBnC8XwXDTuC/MZ6t+MrKVQZOk4s7+PaDkwIsQd8IwqvM+0M6bA/2lvG8GHXcPdf+MejTUeO2LCPCeQ==", 1056 | "requires": { 1057 | "quick-lru": "^5.1.1", 1058 | "resolve-alpn": "^1.0.0" 1059 | } 1060 | }, 1061 | "iconv-lite": { 1062 | "version": "0.6.2", 1063 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.2.tgz", 1064 | "integrity": "sha512-2y91h5OpQlolefMPmUlivelittSWy0rP+oYVpn6A7GwVHNE8AWzoYOBNmlwks3LobaJxgHCYZAnyNo2GgpNRNQ==", 1065 | "requires": { 1066 | "safer-buffer": ">= 2.1.2 < 3.0.0" 1067 | } 1068 | }, 1069 | "ieee754": { 1070 | "version": "1.2.1", 1071 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", 1072 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==" 1073 | }, 1074 | "ignore-walk": { 1075 | "version": "3.0.3", 1076 | "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-3.0.3.tgz", 1077 | "integrity": "sha512-m7o6xuOaT1aqheYHKf8W6J5pYH85ZI9w077erOzLje3JsB1gkafkAhHHY19dqjulgIZHFm32Cp5uNZgcQqdJKw==", 1078 | "requires": { 1079 | "minimatch": "^3.0.4" 1080 | } 1081 | }, 1082 | "image-q": { 1083 | "version": "1.1.1", 1084 | "resolved": "https://registry.npmjs.org/image-q/-/image-q-1.1.1.tgz", 1085 | "integrity": "sha1-/IQJlmRGC5DKhi2TALa/u7+/gFY=" 1086 | }, 1087 | "inflight": { 1088 | "version": "1.0.6", 1089 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1090 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1091 | "requires": { 1092 | "once": "^1.3.0", 1093 | "wrappy": "1" 1094 | } 1095 | }, 1096 | "inherits": { 1097 | "version": "2.0.3", 1098 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1099 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 1100 | }, 1101 | "ini": { 1102 | "version": "1.3.8", 1103 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", 1104 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==" 1105 | }, 1106 | "is-fullwidth-code-point": { 1107 | "version": "1.0.0", 1108 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 1109 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 1110 | "requires": { 1111 | "number-is-nan": "^1.0.0" 1112 | } 1113 | }, 1114 | "is-function": { 1115 | "version": "1.0.2", 1116 | "resolved": "https://registry.npmjs.org/is-function/-/is-function-1.0.2.tgz", 1117 | "integrity": "sha512-lw7DUp0aWXYg+CBCN+JKkcE0Q2RayZnSvnZBlwgxHBQhqt5pZNVy4Ri7H9GmmXkdu7LUthszM+Tor1u/2iBcpQ==" 1118 | }, 1119 | "isarray": { 1120 | "version": "1.0.0", 1121 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1122 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 1123 | }, 1124 | "iso8601-duration": { 1125 | "version": "1.3.0", 1126 | "resolved": "https://registry.npmjs.org/iso8601-duration/-/iso8601-duration-1.3.0.tgz", 1127 | "integrity": "sha512-K4CiUBzo3YeWk76FuET/dQPH03WE04R94feo5TSKQCXpoXQt9E4yx2CnY737QZnSAI3PI4WlKo/zfqizGx52QQ==" 1128 | }, 1129 | "jimp": { 1130 | "version": "0.16.1", 1131 | "resolved": "https://registry.npmjs.org/jimp/-/jimp-0.16.1.tgz", 1132 | "integrity": "sha512-+EKVxbR36Td7Hfd23wKGIeEyHbxShZDX6L8uJkgVW3ESA9GiTEPK08tG1XI2r/0w5Ch0HyJF5kPqF9K7EmGjaw==", 1133 | "requires": { 1134 | "@babel/runtime": "^7.7.2", 1135 | "@jimp/custom": "^0.16.1", 1136 | "@jimp/plugins": "^0.16.1", 1137 | "@jimp/types": "^0.16.1", 1138 | "regenerator-runtime": "^0.13.3" 1139 | } 1140 | }, 1141 | "jpeg-js": { 1142 | "version": "0.4.2", 1143 | "resolved": "https://registry.npmjs.org/jpeg-js/-/jpeg-js-0.4.2.tgz", 1144 | "integrity": "sha512-+az2gi/hvex7eLTMTlbRLOhH6P6WFdk2ITI8HJsaH2VqYO0I594zXSYEP+tf4FW+8Cy68ScDXoAsQdyQanv3sw==" 1145 | }, 1146 | "json-buffer": { 1147 | "version": "3.0.1", 1148 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 1149 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==" 1150 | }, 1151 | "jsonfile": { 1152 | "version": "5.0.0", 1153 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-5.0.0.tgz", 1154 | "integrity": "sha512-NQRZ5CRo74MhMMC3/3r5g2k4fjodJ/wh8MxjFbCViWKFjxrnudWSY5vomh+23ZaXzAS7J3fBZIR2dV6WbmfM0w==", 1155 | "requires": { 1156 | "graceful-fs": "^4.1.6", 1157 | "universalify": "^0.1.2" 1158 | } 1159 | }, 1160 | "kareem": { 1161 | "version": "2.3.2", 1162 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.2.tgz", 1163 | "integrity": "sha512-STHz9P7X2L4Kwn72fA4rGyqyXdmrMSdxqHx9IXon/FXluXieaFA6KJ2upcHAHxQPQ0LeM/OjLrhFxifHewOALQ==" 1164 | }, 1165 | "keyv": { 1166 | "version": "4.0.3", 1167 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.0.3.tgz", 1168 | "integrity": "sha512-zdGa2TOpSZPq5mU6iowDARnMBZgtCqJ11dJROFi6tg6kTn4nuUdU09lFyLFSaHrWqpIJ+EBq4E8/Dc0Vx5vLdA==", 1169 | "requires": { 1170 | "json-buffer": "3.0.1" 1171 | } 1172 | }, 1173 | "klaw": { 1174 | "version": "3.0.0", 1175 | "resolved": "https://registry.npmjs.org/klaw/-/klaw-3.0.0.tgz", 1176 | "integrity": "sha512-0Fo5oir+O9jnXu5EefYbVK+mHMBeEVEy2cmctR1O1NECcCkPRreJKrS6Qt/j3KC2C148Dfo9i3pCmCMsdqGr0g==", 1177 | "requires": { 1178 | "graceful-fs": "^4.1.9" 1179 | } 1180 | }, 1181 | "load-bmfont": { 1182 | "version": "1.4.1", 1183 | "resolved": "https://registry.npmjs.org/load-bmfont/-/load-bmfont-1.4.1.tgz", 1184 | "integrity": "sha512-8UyQoYmdRDy81Brz6aLAUhfZLwr5zV0L3taTQ4hju7m6biuwiWiJXjPhBJxbUQJA8PrkvJ/7Enqmwk2sM14soA==", 1185 | "requires": { 1186 | "buffer-equal": "0.0.1", 1187 | "mime": "^1.3.4", 1188 | "parse-bmfont-ascii": "^1.0.3", 1189 | "parse-bmfont-binary": "^1.0.5", 1190 | "parse-bmfont-xml": "^1.1.4", 1191 | "phin": "^2.9.1", 1192 | "xhr": "^2.0.1", 1193 | "xtend": "^4.0.0" 1194 | } 1195 | }, 1196 | "long": { 1197 | "version": "4.0.0", 1198 | "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", 1199 | "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" 1200 | }, 1201 | "lowercase-keys": { 1202 | "version": "2.0.0", 1203 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz", 1204 | "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==" 1205 | }, 1206 | "memory-pager": { 1207 | "version": "1.5.0", 1208 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 1209 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 1210 | "optional": true 1211 | }, 1212 | "mime": { 1213 | "version": "1.6.0", 1214 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1215 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 1216 | }, 1217 | "mime-db": { 1218 | "version": "1.45.0", 1219 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.45.0.tgz", 1220 | "integrity": "sha512-CkqLUxUk15hofLoLyljJSrukZi8mAtgd+yE5uO4tqRZsdsAJKv0O+rFMhVDRJgozy+yG6md5KwuXhD4ocIoP+w==" 1221 | }, 1222 | "mime-types": { 1223 | "version": "2.1.28", 1224 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.28.tgz", 1225 | "integrity": "sha512-0TO2yJ5YHYr7M2zzT7gDU1tbwHxEUWBCLt0lscSNpcdAfFyJOVEpRYNS7EXVcTLNj/25QO8gulHC5JtTzSE2UQ==", 1226 | "requires": { 1227 | "mime-db": "1.45.0" 1228 | } 1229 | }, 1230 | "mimic-response": { 1231 | "version": "1.0.1", 1232 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz", 1233 | "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==" 1234 | }, 1235 | "min-document": { 1236 | "version": "2.19.0", 1237 | "resolved": "https://registry.npmjs.org/min-document/-/min-document-2.19.0.tgz", 1238 | "integrity": "sha1-e9KC4/WELtKVu3SM3Z8f+iyCRoU=", 1239 | "requires": { 1240 | "dom-walk": "^0.1.0" 1241 | } 1242 | }, 1243 | "minimatch": { 1244 | "version": "3.0.4", 1245 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1246 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1247 | "requires": { 1248 | "brace-expansion": "^1.1.7" 1249 | } 1250 | }, 1251 | "minimist": { 1252 | "version": "1.2.5", 1253 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1254 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" 1255 | }, 1256 | "minipass": { 1257 | "version": "2.9.0", 1258 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-2.9.0.tgz", 1259 | "integrity": "sha512-wxfUjg9WebH+CUDX/CdbRlh5SmfZiy/hpkxaRI16Y9W56Pa75sWgd/rvFilSgrauD9NyFymP/+JFV3KwzIsJeg==", 1260 | "requires": { 1261 | "safe-buffer": "^5.1.2", 1262 | "yallist": "^3.0.0" 1263 | } 1264 | }, 1265 | "minizlib": { 1266 | "version": "1.3.3", 1267 | "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-1.3.3.tgz", 1268 | "integrity": "sha512-6ZYMOEnmVsdCeTJVE0W9ZD+pVnE8h9Hma/iOwwRDsdQoePpoX56/8B6z3P9VNwppJuBKNRuFDRNRqRWexT9G9Q==", 1269 | "requires": { 1270 | "minipass": "^2.9.0" 1271 | } 1272 | }, 1273 | "mkdirp": { 1274 | "version": "0.5.5", 1275 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 1276 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 1277 | "requires": { 1278 | "minimist": "^1.2.5" 1279 | } 1280 | }, 1281 | "moment": { 1282 | "version": "2.29.1", 1283 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.1.tgz", 1284 | "integrity": "sha512-kHmoybcPV8Sqy59DwNDY3Jefr64lK/by/da0ViFcuA4DH0vQg5Q6Ze5VimxkfQNSC+Mls/Kx53s7TjP1RhFEDQ==" 1285 | }, 1286 | "moment-duration-format": { 1287 | "version": "2.3.2", 1288 | "resolved": "https://registry.npmjs.org/moment-duration-format/-/moment-duration-format-2.3.2.tgz", 1289 | "integrity": "sha512-cBMXjSW+fjOb4tyaVHuaVE/A5TqkukDWiOfxxAjY+PEqmmBQlLwn+8OzwPiG3brouXKY5Un4pBjAeB6UToXHaQ==" 1290 | }, 1291 | "mongodb": { 1292 | "version": "3.6.3", 1293 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.6.3.tgz", 1294 | "integrity": "sha512-rOZuR0QkodZiM+UbQE5kDsJykBqWi0CL4Ec2i1nrGrUI3KO11r6Fbxskqmq3JK2NH7aW4dcccBuUujAP0ERl5w==", 1295 | "requires": { 1296 | "bl": "^2.2.1", 1297 | "bson": "^1.1.4", 1298 | "denque": "^1.4.1", 1299 | "require_optional": "^1.0.1", 1300 | "safe-buffer": "^5.1.2", 1301 | "saslprep": "^1.0.0" 1302 | } 1303 | }, 1304 | "mongoose": { 1305 | "version": "5.11.11", 1306 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-5.11.11.tgz", 1307 | "integrity": "sha512-JgKKAosJf6medPOZi2LmO7sMz7Sg00mgjyPAKari3alzL+R/n8D+zKK29iGtJpNNtv9IKy14H37CWuiaZ7016w==", 1308 | "requires": { 1309 | "@types/mongodb": "^3.5.27", 1310 | "bson": "^1.1.4", 1311 | "kareem": "2.3.2", 1312 | "mongodb": "3.6.3", 1313 | "mongoose-legacy-pluralize": "1.0.2", 1314 | "mpath": "0.8.3", 1315 | "mquery": "3.2.3", 1316 | "ms": "2.1.2", 1317 | "regexp-clone": "1.0.0", 1318 | "safe-buffer": "5.2.1", 1319 | "sift": "7.0.1", 1320 | "sliced": "1.0.1" 1321 | } 1322 | }, 1323 | "mongoose-legacy-pluralize": { 1324 | "version": "1.0.2", 1325 | "resolved": "https://registry.npmjs.org/mongoose-legacy-pluralize/-/mongoose-legacy-pluralize-1.0.2.tgz", 1326 | "integrity": "sha512-Yo/7qQU4/EyIS8YDFSeenIvXxZN+ld7YdV9LqFVQJzTLye8unujAWPZ4NWKfFA+RNjh+wvTWKY9Z3E5XM6ZZiQ==" 1327 | }, 1328 | "mpath": { 1329 | "version": "0.8.3", 1330 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.8.3.tgz", 1331 | "integrity": "sha512-eb9rRvhDltXVNL6Fxd2zM9D4vKBxjVVQNLNijlj7uoXUy19zNDsIif5zR+pWmPCWNKwAtqyo4JveQm4nfD5+eA==" 1332 | }, 1333 | "mquery": { 1334 | "version": "3.2.3", 1335 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-3.2.3.tgz", 1336 | "integrity": "sha512-cIfbP4TyMYX+SkaQ2MntD+F2XbqaBHUYWk3j+kqdDztPWok3tgyssOZxMHMtzbV1w9DaSlvEea0Iocuro41A4g==", 1337 | "requires": { 1338 | "bluebird": "3.5.1", 1339 | "debug": "3.1.0", 1340 | "regexp-clone": "^1.0.0", 1341 | "safe-buffer": "5.1.2", 1342 | "sliced": "1.0.1" 1343 | }, 1344 | "dependencies": { 1345 | "safe-buffer": { 1346 | "version": "5.1.2", 1347 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1348 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1349 | } 1350 | } 1351 | }, 1352 | "ms": { 1353 | "version": "2.1.2", 1354 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1355 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1356 | }, 1357 | "nan": { 1358 | "version": "2.14.2", 1359 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.2.tgz", 1360 | "integrity": "sha512-M2ufzIiINKCuDfBSAUr1vWQ+vuVcA9kqx8JJUsbQi6yf1uGRyb7HfpdfUr5qLXf3B/t8dPvcjhKMmlfnP47EzQ==" 1361 | }, 1362 | "needle": { 1363 | "version": "2.6.0", 1364 | "resolved": "https://registry.npmjs.org/needle/-/needle-2.6.0.tgz", 1365 | "integrity": "sha512-KKYdza4heMsEfSWD7VPUIz3zX2XDwOyX2d+geb4vrERZMT5RMU6ujjaD+I5Yr54uZxQ2w6XRTAhHBbSCyovZBg==", 1366 | "requires": { 1367 | "debug": "^3.2.6", 1368 | "iconv-lite": "^0.4.4", 1369 | "sax": "^1.2.4" 1370 | }, 1371 | "dependencies": { 1372 | "debug": { 1373 | "version": "3.2.7", 1374 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1375 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1376 | "requires": { 1377 | "ms": "^2.1.1" 1378 | } 1379 | }, 1380 | "iconv-lite": { 1381 | "version": "0.4.24", 1382 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1383 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1384 | "requires": { 1385 | "safer-buffer": ">= 2.1.2 < 3" 1386 | } 1387 | } 1388 | } 1389 | }, 1390 | "node-canvas-with-twemoji-and-discord-emoji": { 1391 | "version": "1.1.8", 1392 | "resolved": "https://registry.npmjs.org/node-canvas-with-twemoji-and-discord-emoji/-/node-canvas-with-twemoji-and-discord-emoji-1.1.8.tgz", 1393 | "integrity": "sha512-BF724o19PEkukeMO0L5Myg6XBDStlttzo4V7j9UkX0LL0akl6nBgijgTscedth7weJpTiIdo8XgNaeg+HknBlA==", 1394 | "requires": { 1395 | "canvas": "^2.6.1", 1396 | "twemoji": "^13.0.1" 1397 | } 1398 | }, 1399 | "node-fetch": { 1400 | "version": "2.6.1", 1401 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.1.tgz", 1402 | "integrity": "sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw==" 1403 | }, 1404 | "node-pre-gyp": { 1405 | "version": "0.11.0", 1406 | "resolved": "https://registry.npmjs.org/node-pre-gyp/-/node-pre-gyp-0.11.0.tgz", 1407 | "integrity": "sha512-TwWAOZb0j7e9eGaf9esRx3ZcLaE5tQ2lvYy1pb5IAaG1a2e2Kv5Lms1Y4hpj+ciXJRofIxxlt5haeQ/2ANeE0Q==", 1408 | "requires": { 1409 | "detect-libc": "^1.0.2", 1410 | "mkdirp": "^0.5.1", 1411 | "needle": "^2.2.1", 1412 | "nopt": "^4.0.1", 1413 | "npm-packlist": "^1.1.6", 1414 | "npmlog": "^4.0.2", 1415 | "rc": "^1.2.7", 1416 | "rimraf": "^2.6.1", 1417 | "semver": "^5.3.0", 1418 | "tar": "^4" 1419 | } 1420 | }, 1421 | "nopt": { 1422 | "version": "4.0.3", 1423 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.3.tgz", 1424 | "integrity": "sha512-CvaGwVMztSMJLOeXPrez7fyfObdZqNUK1cPAEzLHrTybIua9pMdmmPR5YwtfNftIOMv3DPUhFaxsZMNTQO20Kg==", 1425 | "requires": { 1426 | "abbrev": "1", 1427 | "osenv": "^0.1.4" 1428 | } 1429 | }, 1430 | "normalize-url": { 1431 | "version": "4.5.0", 1432 | "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.0.tgz", 1433 | "integrity": "sha512-2s47yzUxdexf1OhyRi4Em83iQk0aPvwTddtFz4hnSSw9dCEsLEGf6SwIO8ss/19S9iBb5sJaOuTvTGDeZI00BQ==" 1434 | }, 1435 | "npm-bundled": { 1436 | "version": "1.1.1", 1437 | "resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-1.1.1.tgz", 1438 | "integrity": "sha512-gqkfgGePhTpAEgUsGEgcq1rqPXA+tv/aVBlgEzfXwA1yiUJF7xtEt3CtVwOjNYQOVknDk0F20w58Fnm3EtG0fA==", 1439 | "requires": { 1440 | "npm-normalize-package-bin": "^1.0.1" 1441 | } 1442 | }, 1443 | "npm-normalize-package-bin": { 1444 | "version": "1.0.1", 1445 | "resolved": "https://registry.npmjs.org/npm-normalize-package-bin/-/npm-normalize-package-bin-1.0.1.tgz", 1446 | "integrity": "sha512-EPfafl6JL5/rU+ot6P3gRSCpPDW5VmIzX959Ob1+ySFUuuYHWHekXpwdUZcKP5C+DS4GEtdJluwBjnsNDl+fSA==" 1447 | }, 1448 | "npm-packlist": { 1449 | "version": "1.4.8", 1450 | "resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-1.4.8.tgz", 1451 | "integrity": "sha512-5+AZgwru5IevF5ZdnFglB5wNlHG1AOOuw28WhUq8/8emhBmLv6jX5by4WJCh7lW0uSYZYS6DXqIsyZVIXRZU9A==", 1452 | "requires": { 1453 | "ignore-walk": "^3.0.1", 1454 | "npm-bundled": "^1.0.1", 1455 | "npm-normalize-package-bin": "^1.0.1" 1456 | } 1457 | }, 1458 | "npmlog": { 1459 | "version": "4.1.2", 1460 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", 1461 | "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", 1462 | "requires": { 1463 | "are-we-there-yet": "~1.1.2", 1464 | "console-control-strings": "~1.1.0", 1465 | "gauge": "~2.7.3", 1466 | "set-blocking": "~2.0.0" 1467 | } 1468 | }, 1469 | "nth-check": { 1470 | "version": "2.0.0", 1471 | "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-2.0.0.tgz", 1472 | "integrity": "sha512-i4sc/Kj8htBrAiH1viZ0TgU8Y5XqCaV/FziYK6TBczxmeKm3AEFWqqF3195yKudrarqy7Zu80Ra5dobFjn9X/Q==", 1473 | "requires": { 1474 | "boolbase": "^1.0.0" 1475 | } 1476 | }, 1477 | "number-is-nan": { 1478 | "version": "1.0.1", 1479 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 1480 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" 1481 | }, 1482 | "object-assign": { 1483 | "version": "4.1.1", 1484 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1485 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 1486 | }, 1487 | "omggif": { 1488 | "version": "1.0.10", 1489 | "resolved": "https://registry.npmjs.org/omggif/-/omggif-1.0.10.tgz", 1490 | "integrity": "sha512-LMJTtvgc/nugXj0Vcrrs68Mn2D1r0zf630VNtqtpI1FEO7e+O9FP4gqs9AcnBaSEeoHIPm28u6qgPR0oyEpGSw==" 1491 | }, 1492 | "once": { 1493 | "version": "1.4.0", 1494 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1495 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1496 | "requires": { 1497 | "wrappy": "1" 1498 | } 1499 | }, 1500 | "os-homedir": { 1501 | "version": "1.0.2", 1502 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 1503 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=" 1504 | }, 1505 | "os-tmpdir": { 1506 | "version": "1.0.2", 1507 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1508 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" 1509 | }, 1510 | "osenv": { 1511 | "version": "0.1.5", 1512 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz", 1513 | "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==", 1514 | "requires": { 1515 | "os-homedir": "^1.0.0", 1516 | "os-tmpdir": "^1.0.0" 1517 | } 1518 | }, 1519 | "p-cancelable": { 1520 | "version": "2.0.0", 1521 | "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-2.0.0.tgz", 1522 | "integrity": "sha512-wvPXDmbMmu2ksjkB4Z3nZWTSkJEb9lqVdMaCKpZUGJG9TMiNp9XcbG3fn9fPKjem04fJMJnXoyFPk2FmgiaiNg==" 1523 | }, 1524 | "pako": { 1525 | "version": "1.0.11", 1526 | "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.11.tgz", 1527 | "integrity": "sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw==" 1528 | }, 1529 | "parse-bmfont-ascii": { 1530 | "version": "1.0.6", 1531 | "resolved": "https://registry.npmjs.org/parse-bmfont-ascii/-/parse-bmfont-ascii-1.0.6.tgz", 1532 | "integrity": "sha1-Eaw8P/WPfCAgqyJ2kHkQjU36AoU=" 1533 | }, 1534 | "parse-bmfont-binary": { 1535 | "version": "1.0.6", 1536 | "resolved": "https://registry.npmjs.org/parse-bmfont-binary/-/parse-bmfont-binary-1.0.6.tgz", 1537 | "integrity": "sha1-0Di0dtPp3Z2x4RoLDlOiJ5K2kAY=" 1538 | }, 1539 | "parse-bmfont-xml": { 1540 | "version": "1.1.4", 1541 | "resolved": "https://registry.npmjs.org/parse-bmfont-xml/-/parse-bmfont-xml-1.1.4.tgz", 1542 | "integrity": "sha512-bjnliEOmGv3y1aMEfREMBJ9tfL3WR0i0CKPj61DnSLaoxWR3nLrsQrEbCId/8rF4NyRF0cCqisSVXyQYWM+mCQ==", 1543 | "requires": { 1544 | "xml-parse-from-string": "^1.0.0", 1545 | "xml2js": "^0.4.5" 1546 | } 1547 | }, 1548 | "parse-headers": { 1549 | "version": "2.0.3", 1550 | "resolved": "https://registry.npmjs.org/parse-headers/-/parse-headers-2.0.3.tgz", 1551 | "integrity": "sha512-QhhZ+DCCit2Coi2vmAKbq5RGTRcQUOE2+REgv8vdyu7MnYx2eZztegqtTx99TZ86GTIwqiy3+4nQTWZ2tgmdCA==" 1552 | }, 1553 | "parse5": { 1554 | "version": "6.0.1", 1555 | "resolved": "https://registry.npmjs.org/parse5/-/parse5-6.0.1.tgz", 1556 | "integrity": "sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==" 1557 | }, 1558 | "parse5-htmlparser2-tree-adapter": { 1559 | "version": "6.0.1", 1560 | "resolved": "https://registry.npmjs.org/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-6.0.1.tgz", 1561 | "integrity": "sha512-qPuWvbLgvDGilKc5BoicRovlT4MtYT6JfJyBOMDsKoiT+GiuP5qyrPCnR9HcPECIJJmZh5jRndyNThnhhb/vlA==", 1562 | "requires": { 1563 | "parse5": "^6.0.1" 1564 | } 1565 | }, 1566 | "path": { 1567 | "version": "0.12.7", 1568 | "resolved": "https://registry.npmjs.org/path/-/path-0.12.7.tgz", 1569 | "integrity": "sha1-1NwqUGxM4hl+tIHr/NWzbAFAsQ8=", 1570 | "requires": { 1571 | "process": "^0.11.1", 1572 | "util": "^0.10.3" 1573 | } 1574 | }, 1575 | "path-is-absolute": { 1576 | "version": "1.0.1", 1577 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1578 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 1579 | }, 1580 | "phin": { 1581 | "version": "2.9.3", 1582 | "resolved": "https://registry.npmjs.org/phin/-/phin-2.9.3.tgz", 1583 | "integrity": "sha512-CzFr90qM24ju5f88quFC/6qohjC144rehe5n6DH900lgXmUe86+xCKc10ev56gRKC4/BkHUoG4uSiQgBiIXwDA==" 1584 | }, 1585 | "pixelmatch": { 1586 | "version": "4.0.2", 1587 | "resolved": "https://registry.npmjs.org/pixelmatch/-/pixelmatch-4.0.2.tgz", 1588 | "integrity": "sha1-j0fc7FARtHe2fbA8JDvB8wheiFQ=", 1589 | "requires": { 1590 | "pngjs": "^3.0.0" 1591 | } 1592 | }, 1593 | "pngjs": { 1594 | "version": "3.4.0", 1595 | "resolved": "https://registry.npmjs.org/pngjs/-/pngjs-3.4.0.tgz", 1596 | "integrity": "sha512-NCrCHhWmnQklfH4MtJMRjZ2a8c80qXeMlQMv2uVp9ISJMTt562SbGd6n2oq0PaPgKm7Z6pL9E2UlLIhC+SHL3w==" 1597 | }, 1598 | "prism-media": { 1599 | "version": "1.2.3", 1600 | "resolved": "https://registry.npmjs.org/prism-media/-/prism-media-1.2.3.tgz", 1601 | "integrity": "sha512-fSrR66n0l6roW9Rx4rSLMyTPTjRTiXy5RVqDOurACQ6si1rKHHKDU5gwBJoCsIV0R3o9gi+K50akl/qyw1C74A==" 1602 | }, 1603 | "process": { 1604 | "version": "0.11.10", 1605 | "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz", 1606 | "integrity": "sha1-czIwDoQBYb2j5podHZGn1LwW8YI=" 1607 | }, 1608 | "process-nextick-args": { 1609 | "version": "2.0.1", 1610 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 1611 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" 1612 | }, 1613 | "psl": { 1614 | "version": "1.8.0", 1615 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.8.0.tgz", 1616 | "integrity": "sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ==" 1617 | }, 1618 | "pump": { 1619 | "version": "3.0.0", 1620 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1621 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1622 | "requires": { 1623 | "end-of-stream": "^1.1.0", 1624 | "once": "^1.3.1" 1625 | } 1626 | }, 1627 | "punycode": { 1628 | "version": "2.1.1", 1629 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1630 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==" 1631 | }, 1632 | "quick-lru": { 1633 | "version": "5.1.1", 1634 | "resolved": "https://registry.npmjs.org/quick-lru/-/quick-lru-5.1.1.tgz", 1635 | "integrity": "sha512-WuyALRjWPDGtt/wzJiadO5AXY+8hZ80hVpe6MyivgraREW751X3SbhRvG3eLKOYN+8VEvqLcf3wdnt44Z4S4SA==" 1636 | }, 1637 | "rc": { 1638 | "version": "1.2.8", 1639 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 1640 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 1641 | "requires": { 1642 | "deep-extend": "^0.6.0", 1643 | "ini": "~1.3.0", 1644 | "minimist": "^1.2.0", 1645 | "strip-json-comments": "~2.0.1" 1646 | } 1647 | }, 1648 | "readable-stream": { 1649 | "version": "2.3.7", 1650 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 1651 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 1652 | "requires": { 1653 | "core-util-is": "~1.0.0", 1654 | "inherits": "~2.0.3", 1655 | "isarray": "~1.0.0", 1656 | "process-nextick-args": "~2.0.0", 1657 | "safe-buffer": "~5.1.1", 1658 | "string_decoder": "~1.1.1", 1659 | "util-deprecate": "~1.0.1" 1660 | }, 1661 | "dependencies": { 1662 | "safe-buffer": { 1663 | "version": "5.1.2", 1664 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1665 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1666 | } 1667 | } 1668 | }, 1669 | "regenerator-runtime": { 1670 | "version": "0.13.7", 1671 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.7.tgz", 1672 | "integrity": "sha512-a54FxoJDIr27pgf7IgeQGxmqUNYrcV338lf/6gH456HZ/PhX+5BcwHXG9ajESmwe6WRO0tAzRUrRmNONWgkrew==" 1673 | }, 1674 | "regexp-clone": { 1675 | "version": "1.0.0", 1676 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-1.0.0.tgz", 1677 | "integrity": "sha512-TuAasHQNamyyJ2hb97IuBEif4qBHGjPHBS64sZwytpLEqtBQ1gPJTnOaQ6qmpET16cK14kkjbazl6+p0RRv0yw==" 1678 | }, 1679 | "require_optional": { 1680 | "version": "1.0.1", 1681 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz", 1682 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==", 1683 | "requires": { 1684 | "resolve-from": "^2.0.0", 1685 | "semver": "^5.1.0" 1686 | } 1687 | }, 1688 | "resolve-alpn": { 1689 | "version": "1.0.0", 1690 | "resolved": "https://registry.npmjs.org/resolve-alpn/-/resolve-alpn-1.0.0.tgz", 1691 | "integrity": "sha512-rTuiIEqFmGxne4IovivKSDzld2lWW9QCjqv80SYjPgf+gS35eaCAjaP54CCwGAwBtnCsvNLYtqxe1Nw+i6JEmA==" 1692 | }, 1693 | "resolve-from": { 1694 | "version": "2.0.0", 1695 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", 1696 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=" 1697 | }, 1698 | "responselike": { 1699 | "version": "2.0.0", 1700 | "resolved": "https://registry.npmjs.org/responselike/-/responselike-2.0.0.tgz", 1701 | "integrity": "sha512-xH48u3FTB9VsZw7R+vvgaKeLKzT6jOogbQhEe/jewwnZgzPcnyWui2Av6JpoYZF/91uueC+lqhWqeURw5/qhCw==", 1702 | "requires": { 1703 | "lowercase-keys": "^2.0.0" 1704 | } 1705 | }, 1706 | "rimraf": { 1707 | "version": "2.7.1", 1708 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 1709 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 1710 | "requires": { 1711 | "glob": "^7.1.3" 1712 | } 1713 | }, 1714 | "safe-buffer": { 1715 | "version": "5.2.1", 1716 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1717 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 1718 | }, 1719 | "safer-buffer": { 1720 | "version": "2.1.2", 1721 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1722 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1723 | }, 1724 | "saslprep": { 1725 | "version": "1.0.3", 1726 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 1727 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 1728 | "optional": true, 1729 | "requires": { 1730 | "sparse-bitfield": "^3.0.3" 1731 | } 1732 | }, 1733 | "sax": { 1734 | "version": "1.2.4", 1735 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", 1736 | "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" 1737 | }, 1738 | "semver": { 1739 | "version": "5.7.1", 1740 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1741 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 1742 | }, 1743 | "set-blocking": { 1744 | "version": "2.0.0", 1745 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1746 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 1747 | }, 1748 | "setimmediate": { 1749 | "version": "1.0.5", 1750 | "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", 1751 | "integrity": "sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU=" 1752 | }, 1753 | "sift": { 1754 | "version": "7.0.1", 1755 | "resolved": "https://registry.npmjs.org/sift/-/sift-7.0.1.tgz", 1756 | "integrity": "sha512-oqD7PMJ+uO6jV9EQCl0LrRw1OwsiPsiFQR5AR30heR+4Dl7jBBbDLnNvWiak20tzZlSE1H7RB30SX/1j/YYT7g==" 1757 | }, 1758 | "signal-exit": { 1759 | "version": "3.0.3", 1760 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 1761 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==" 1762 | }, 1763 | "simple-concat": { 1764 | "version": "1.0.1", 1765 | "resolved": "https://registry.npmjs.org/simple-concat/-/simple-concat-1.0.1.tgz", 1766 | "integrity": "sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q==" 1767 | }, 1768 | "simple-get": { 1769 | "version": "3.1.0", 1770 | "resolved": "https://registry.npmjs.org/simple-get/-/simple-get-3.1.0.tgz", 1771 | "integrity": "sha512-bCR6cP+aTdScaQCnQKbPKtJOKDp/hj9EDLJo3Nw4y1QksqaovlW/bnptB6/c1e+qmNIDHRK+oXFDdEqBT8WzUA==", 1772 | "requires": { 1773 | "decompress-response": "^4.2.0", 1774 | "once": "^1.3.1", 1775 | "simple-concat": "^1.0.0" 1776 | }, 1777 | "dependencies": { 1778 | "decompress-response": { 1779 | "version": "4.2.1", 1780 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-4.2.1.tgz", 1781 | "integrity": "sha512-jOSne2qbyE+/r8G1VU+G/82LBs2Fs4LAsTiLSHOCOMZQl2OKZ6i8i4IyHemTe+/yIXOtTcRQMzPcgyhoFlqPkw==", 1782 | "requires": { 1783 | "mimic-response": "^2.0.0" 1784 | } 1785 | }, 1786 | "mimic-response": { 1787 | "version": "2.1.0", 1788 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-2.1.0.tgz", 1789 | "integrity": "sha512-wXqjST+SLt7R009ySCglWBCFpjUygmCIfD790/kVbiGmUgfYGuB14PiTd5DwVxSV4NcYHjzMkoj5LjQZwTQLEA==" 1790 | } 1791 | } 1792 | }, 1793 | "simple-youtube-api": { 1794 | "version": "5.2.1", 1795 | "resolved": "https://registry.npmjs.org/simple-youtube-api/-/simple-youtube-api-5.2.1.tgz", 1796 | "integrity": "sha512-vmndP9Bkh35tifn2OwY+th2imSsfYtmDqczgdOW5yEARFzvSoR8VSQFsivJnctfV5QHQUL6VrOpNdbmDRLh9Bg==", 1797 | "requires": { 1798 | "iso8601-duration": "^1.2.0", 1799 | "node-fetch": "^2.6.0" 1800 | } 1801 | }, 1802 | "sliced": { 1803 | "version": "1.0.1", 1804 | "resolved": "https://registry.npmjs.org/sliced/-/sliced-1.0.1.tgz", 1805 | "integrity": "sha1-CzpmK10Ewxd7GSa+qCsD+Dei70E=" 1806 | }, 1807 | "sparse-bitfield": { 1808 | "version": "3.0.3", 1809 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 1810 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=", 1811 | "optional": true, 1812 | "requires": { 1813 | "memory-pager": "^1.0.2" 1814 | } 1815 | }, 1816 | "string-to-stream": { 1817 | "version": "1.1.1", 1818 | "resolved": "https://registry.npmjs.org/string-to-stream/-/string-to-stream-1.1.1.tgz", 1819 | "integrity": "sha512-QySF2+3Rwq0SdO3s7BAp4x+c3qsClpPQ6abAmb0DGViiSBAkT5kL6JT2iyzEVP+T1SmzHrQD1TwlP9QAHCc+Sw==", 1820 | "requires": { 1821 | "inherits": "^2.0.1", 1822 | "readable-stream": "^2.1.0" 1823 | } 1824 | }, 1825 | "string-width": { 1826 | "version": "1.0.2", 1827 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 1828 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 1829 | "requires": { 1830 | "code-point-at": "^1.0.0", 1831 | "is-fullwidth-code-point": "^1.0.0", 1832 | "strip-ansi": "^3.0.0" 1833 | } 1834 | }, 1835 | "string_decoder": { 1836 | "version": "1.1.1", 1837 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 1838 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 1839 | "requires": { 1840 | "safe-buffer": "~5.1.0" 1841 | }, 1842 | "dependencies": { 1843 | "safe-buffer": { 1844 | "version": "5.1.2", 1845 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1846 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1847 | } 1848 | } 1849 | }, 1850 | "strip-ansi": { 1851 | "version": "3.0.1", 1852 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 1853 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 1854 | "requires": { 1855 | "ansi-regex": "^2.0.0" 1856 | } 1857 | }, 1858 | "strip-json-comments": { 1859 | "version": "2.0.1", 1860 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1861 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=" 1862 | }, 1863 | "tar": { 1864 | "version": "4.4.13", 1865 | "resolved": "https://registry.npmjs.org/tar/-/tar-4.4.13.tgz", 1866 | "integrity": "sha512-w2VwSrBoHa5BsSyH+KxEqeQBAllHhccyMFVHtGtdMpF4W7IRWfZjFiQceJPChOeTsSDVUpER2T8FA93pr0L+QA==", 1867 | "requires": { 1868 | "chownr": "^1.1.1", 1869 | "fs-minipass": "^1.2.5", 1870 | "minipass": "^2.8.6", 1871 | "minizlib": "^1.2.1", 1872 | "mkdirp": "^0.5.0", 1873 | "safe-buffer": "^5.1.2", 1874 | "yallist": "^3.0.3" 1875 | } 1876 | }, 1877 | "timm": { 1878 | "version": "1.7.1", 1879 | "resolved": "https://registry.npmjs.org/timm/-/timm-1.7.1.tgz", 1880 | "integrity": "sha512-IjZc9KIotudix8bMaBW6QvMuq64BrJWFs1+4V0lXwWGQZwH+LnX87doAYhem4caOEusRP9/g6jVDQmZ8XOk1nw==" 1881 | }, 1882 | "tinycolor2": { 1883 | "version": "1.4.2", 1884 | "resolved": "https://registry.npmjs.org/tinycolor2/-/tinycolor2-1.4.2.tgz", 1885 | "integrity": "sha512-vJhccZPs965sV/L2sU4oRQVAos0pQXwsvTLkWYdqJ+a8Q5kPFzJTuOFwy7UniPli44NKQGAglksjvOcpo95aZA==" 1886 | }, 1887 | "tweetnacl": { 1888 | "version": "1.0.3", 1889 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-1.0.3.tgz", 1890 | "integrity": "sha512-6rt+RN7aOi1nGMyC4Xa5DdYiukl2UWCbcJft7YhxReBGQD7OAM8Pbxw6YMo4r2diNEA8FEmu32YOn9rhaiE5yw==" 1891 | }, 1892 | "twemoji": { 1893 | "version": "13.0.1", 1894 | "resolved": "https://registry.npmjs.org/twemoji/-/twemoji-13.0.1.tgz", 1895 | "integrity": "sha512-mrTBq+XpCLM4zm76NJOjLHoQNV9mHdBt3Cba/T5lS1rxn8ArwpqE47mqTocupNlkvcLxoeZJjYSUW0DU5ZwqZg==", 1896 | "requires": { 1897 | "fs-extra": "^8.0.1", 1898 | "jsonfile": "^5.0.0", 1899 | "twemoji-parser": "13.0.0", 1900 | "universalify": "^0.1.2" 1901 | } 1902 | }, 1903 | "twemoji-parser": { 1904 | "version": "13.0.0", 1905 | "resolved": "https://registry.npmjs.org/twemoji-parser/-/twemoji-parser-13.0.0.tgz", 1906 | "integrity": "sha512-zMaGdskpH8yKjT2RSE/HwE340R4Fm+fbie4AaqjDa4H/l07YUmAvxkSfNl6awVWNRRQ0zdzLQ8SAJZuY5MgstQ==" 1907 | }, 1908 | "universalify": { 1909 | "version": "0.1.2", 1910 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", 1911 | "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==" 1912 | }, 1913 | "utif": { 1914 | "version": "2.0.1", 1915 | "resolved": "https://registry.npmjs.org/utif/-/utif-2.0.1.tgz", 1916 | "integrity": "sha512-Z/S1fNKCicQTf375lIP9G8Sa1H/phcysstNrrSdZKj1f9g58J4NMgb5IgiEZN9/nLMPDwF0W7hdOe9Qq2IYoLg==", 1917 | "requires": { 1918 | "pako": "^1.0.5" 1919 | } 1920 | }, 1921 | "util": { 1922 | "version": "0.10.4", 1923 | "resolved": "https://registry.npmjs.org/util/-/util-0.10.4.tgz", 1924 | "integrity": "sha512-0Pm9hTQ3se5ll1XihRic3FDIku70C+iHUdT/W926rSgHV5QgXsYbKZN8MSC3tJtSkhuROzvsQjAaFENRXr+19A==", 1925 | "requires": { 1926 | "inherits": "2.0.3" 1927 | } 1928 | }, 1929 | "util-deprecate": { 1930 | "version": "1.0.2", 1931 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1932 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 1933 | }, 1934 | "varint": { 1935 | "version": "5.0.2", 1936 | "resolved": "https://registry.npmjs.org/varint/-/varint-5.0.2.tgz", 1937 | "integrity": "sha512-lKxKYG6H03yCZUpAGOPOsMcGxd1RHCu1iKvEHYDPmTyq2HueGhD73ssNBqqQWfvYs04G9iUFRvmAVLW20Jw6ow==" 1938 | }, 1939 | "wide-align": { 1940 | "version": "1.1.3", 1941 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 1942 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 1943 | "requires": { 1944 | "string-width": "^1.0.2 || 2" 1945 | } 1946 | }, 1947 | "wrappy": { 1948 | "version": "1.0.2", 1949 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1950 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 1951 | }, 1952 | "ws": { 1953 | "version": "7.4.2", 1954 | "resolved": "https://registry.npmjs.org/ws/-/ws-7.4.2.tgz", 1955 | "integrity": "sha512-T4tewALS3+qsrpGI/8dqNMLIVdq/g/85U98HPMa6F0m6xTbvhXU6RCQLqPH3+SlomNV/LdY6RXEbBpMH6EOJnA==" 1956 | }, 1957 | "xhr": { 1958 | "version": "2.6.0", 1959 | "resolved": "https://registry.npmjs.org/xhr/-/xhr-2.6.0.tgz", 1960 | "integrity": "sha512-/eCGLb5rxjx5e3mF1A7s+pLlR6CGyqWN91fv1JgER5mVWg1MZmlhBvy9kjcsOdRk8RrIujotWyJamfyrp+WIcA==", 1961 | "requires": { 1962 | "global": "~4.4.0", 1963 | "is-function": "^1.0.1", 1964 | "parse-headers": "^2.0.0", 1965 | "xtend": "^4.0.0" 1966 | } 1967 | }, 1968 | "xml-parse-from-string": { 1969 | "version": "1.0.1", 1970 | "resolved": "https://registry.npmjs.org/xml-parse-from-string/-/xml-parse-from-string-1.0.1.tgz", 1971 | "integrity": "sha1-qQKekp09vN7RafPG4oI42VpdWig=" 1972 | }, 1973 | "xml2js": { 1974 | "version": "0.4.23", 1975 | "resolved": "https://registry.npmjs.org/xml2js/-/xml2js-0.4.23.tgz", 1976 | "integrity": "sha512-ySPiMjM0+pLDftHgXY4By0uswI3SPKLDw/i3UXbnO8M/p28zqexCUoPmQFrYD+/1BzhGJSs2i1ERWKJAtiLrug==", 1977 | "requires": { 1978 | "sax": ">=0.6.0", 1979 | "xmlbuilder": "~11.0.0" 1980 | }, 1981 | "dependencies": { 1982 | "xmlbuilder": { 1983 | "version": "11.0.1", 1984 | "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-11.0.1.tgz", 1985 | "integrity": "sha512-fDlsI/kFEx7gLvbecc0/ohLG50fugQp8ryHzMTuW9vSa1GJ0XYWKnhsUx7oie3G98+r56aTQIUB4kht42R3JvA==" 1986 | } 1987 | } 1988 | }, 1989 | "xmlbuilder": { 1990 | "version": "8.2.2", 1991 | "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-8.2.2.tgz", 1992 | "integrity": "sha1-aSSGc0ELS6QuGmE2VR0pIjNap3M=" 1993 | }, 1994 | "xmlrpc": { 1995 | "version": "1.3.2", 1996 | "resolved": "https://registry.npmjs.org/xmlrpc/-/xmlrpc-1.3.2.tgz", 1997 | "integrity": "sha1-JrLqNHhI0Ciqx+dRS1NRl23j6D0=", 1998 | "requires": { 1999 | "sax": "1.2.x", 2000 | "xmlbuilder": "8.2.x" 2001 | } 2002 | }, 2003 | "xtend": { 2004 | "version": "4.0.2", 2005 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 2006 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==" 2007 | }, 2008 | "yallist": { 2009 | "version": "3.1.1", 2010 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 2011 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==" 2012 | } 2013 | } 2014 | } 2015 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "specter", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "keywords": [], 10 | "author": "zSpl1nterUS_#6544", 11 | "license": "ISC", 12 | "dependencies": { 13 | "alexflipnote.js": "^2.3.4", 14 | "canvas": "^2.6.1", 15 | "discord.js": "^12.5.1", 16 | "dotenv": "^8.2.0", 17 | "fetch": "^1.1.0", 18 | "gamedig": "^2.0.24", 19 | "jimp": "^0.16.1", 20 | "klaw": "^3.0.0", 21 | "moment": "^2.29.1", 22 | "moment-duration-format": "^2.3.2", 23 | "mongoose": "^5.11.11", 24 | "node-canvas-with-twemoji-and-discord-emoji": "^1.1.8", 25 | "node-fetch": "^2.6.1", 26 | "path": "^0.12.7", 27 | "simple-youtube-api": "^5.2.1" 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /src/assets/fonts/Calibri.ttf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/leonnardom/Rede-Specter/032e6e6fb5bac3f50bd8101ff242721a879b37aa/src/assets/fonts/Calibri.ttf -------------------------------------------------------------------------------- /src/assets/fonts/Montserrat-Black.ttf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/leonnardom/Rede-Specter/032e6e6fb5bac3f50bd8101ff242721a879b37aa/src/assets/fonts/Montserrat-Black.ttf -------------------------------------------------------------------------------- /src/assets/fonts/Montserrat-BlackItalic.ttf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/leonnardom/Rede-Specter/032e6e6fb5bac3f50bd8101ff242721a879b37aa/src/assets/fonts/Montserrat-BlackItalic.ttf -------------------------------------------------------------------------------- /src/assets/fonts/Montserrat-BoldItalic.ttf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/leonnardom/Rede-Specter/032e6e6fb5bac3f50bd8101ff242721a879b37aa/src/assets/fonts/Montserrat-BoldItalic.ttf -------------------------------------------------------------------------------- /src/assets/img/Profile_1.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/leonnardom/Rede-Specter/032e6e6fb5bac3f50bd8101ff242721a879b37aa/src/assets/img/Profile_1.jpg -------------------------------------------------------------------------------- /src/assets/img/Profile_2.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/leonnardom/Rede-Specter/032e6e6fb5bac3f50bd8101ff242721a879b37aa/src/assets/img/Profile_2.jpg -------------------------------------------------------------------------------- /src/assets/img/Work_Info.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/leonnardom/Rede-Specter/032e6e6fb5bac3f50bd8101ff242721a879b37aa/src/assets/img/Work_Info.png -------------------------------------------------------------------------------- /src/client/listeningIn/message.js: -------------------------------------------------------------------------------- 1 | const GetMention = (id) => new RegExp(`^<@!?${id}>( |)$`); 2 | const User = require("../../database/Schemas/User"); 3 | Client = require("../../database/Schemas/Client"); 4 | Guild = require("../../database/Schemas/Guild"); 5 | const Utils = require("../../utils/Util"); 6 | const Emojis = require("../../utils/Emojis"); 7 | const cd = []; 8 | 9 | module.exports = class { 10 | constructor(client) { 11 | this.client = client; 12 | } 13 | 14 | async run(message) { 15 | User.findOne({ _id: message.author.id }, async (err, user) => { 16 | Client.findOne({ _id: this.client.user.id }, async (err, bot) => { 17 | Guild.findOne({ _id: message.guild.id }, async (err, server) => { 18 | if (message.author.bot) return; 19 | 20 | const utils = Utils; 21 | 22 | if (user) { 23 | if (bot) { 24 | if (server) { 25 | const prefix = "/"; 26 | 27 | if (message.content.match(GetMention(this.client.user.id))) { 28 | message.channel.send( 29 | `Olá ${message.author}.\nSou o Bot Oficial da **${process.env.SERVER_NAME}**, caso queira saber minha lista de comandos use **${prefix}ajuda**` 30 | ); 31 | } 32 | 33 | if (message.content.indexOf(prefix) !== 0) return; 34 | const args = message.content 35 | .slice(prefix.length) 36 | .trim() 37 | .split(/ +/g); 38 | const command = args.shift().toLowerCase(); 39 | 40 | if (message.guild && !message.member) 41 | await message.guild.fetchMember(message.author); 42 | 43 | const cmd = 44 | this.client.commands.get(command) || 45 | this.client.commands.get(this.client.aliases.get(command)); 46 | if (!cmd) return message.react(Emojis.Errado); 47 | 48 | const cmdblock = server.cmdblock; 49 | 50 | if (cmdblock.status) { 51 | if (!message.member.hasPermission("MANAGE_MESSAGES")) { 52 | if ( 53 | cmdblock.channels.some((x) => x === message.channel.id) 54 | ) { 55 | if (!cmdblock.enable.some((x) => x === cmd.name)) { 56 | return message.channel.send( 57 | `${Emojis.Errado} - ${message.author}, não pode usar comandos aqui bobinho(a). ^^` 58 | ); 59 | } 60 | } 61 | } 62 | } 63 | let owners = [ 64 | process.env.OWNER_ID, 65 | "757347805529636897", 66 | "574640825003147264", 67 | "342757511218200588", 68 | ]; 69 | 70 | /*if (!owners.some((x) => x === message.author.id)) 71 | return message.channel.send( 72 | `${Emojis.Errado} - ${message.author}, estou em manutenção no momento bobinho(a). ^^` 73 | );*/ 74 | 75 | await cmd.run(message, args, prefix, utils); 76 | 77 | if (!owners.some((x) => x === message.author.id)) { 78 | if (cd.includes(message.author.id)) { 79 | setTimeout(() => { 80 | cd.splice(cd.indexOf(message.author.id), 1); 81 | }, 5000); 82 | 83 | return message.channel.send( 84 | `${Emojis.Cooldown} - ${message.author}, aguarde **5 segundos** para executar outro comando.` 85 | ); 86 | } else cd.push(message.author.id); 87 | } 88 | } else { 89 | Guild.create({ _id: message.guild.id }); 90 | } 91 | } else { 92 | Client.create({ _id: this.client.user.id }); 93 | } 94 | } else { 95 | User.create({ _id: message.author.id }); 96 | } 97 | }); 98 | }); 99 | }); 100 | } 101 | }; 102 | -------------------------------------------------------------------------------- /src/client/listeningIn/messageReactionAdd.js: -------------------------------------------------------------------------------- 1 | const ClientEmbed = require("../../structure/ClientEmbed"); 2 | const bdd = require("../../utils/bdd.json"); 3 | 4 | module.exports = class { 5 | constructor(client) { 6 | this.client = client; 7 | } 8 | 9 | async run(reaction, user) { 10 | const members = reaction.message.guild.members.cache.get(user.id); 11 | if (members.user.bot) return; 12 | if (reaction.message.channel.id === process.env.CHANNEL_ID) { 13 | if (reaction.emoji.name === "✅") { 14 | bdd.NumberTicket++; 15 | if (bdd.NumberTicket >= 10) { 16 | bdd.NumbersTicket = "00"; 17 | } else if (bdd.NumberTicket >= 100) { 18 | bdd.NumbersTicket = "0"; 19 | } else if (bdd.NumberTicket >= 1000) { 20 | bdd.NumberTicket = " "; 21 | } 22 | reaction.remove().then(function (message) { 23 | message.message.react("✅"); 24 | }); 25 | reaction.message.guild.channels 26 | .create("ticket-" + bdd.NumbersTicket + bdd.NumberTicket, { 27 | type: "text", 28 | permissionOverwrites: [ 29 | { 30 | allow: "VIEW_CHANNEL", 31 | deny: "ADD_REACTIONS", 32 | id: user.id, 33 | }, 34 | { 35 | deny: "VIEW_CHANNEL", 36 | id: reaction.message.guild.id, 37 | }, 38 | { 39 | allow: "VIEW_CHANNEL", 40 | deny: "ADD_REACTIONS", 41 | id: process.env.STAFF_ROLE, 42 | }, 43 | ], 44 | }) 45 | .then((msg) => { 46 | const embed = new ClientEmbed(this.client.user) 47 | .setDescription("Bem vindo ao ticket de suporte.") 48 | .setFooter("Rede Specter", this.client.user.avatarURL()) 49 | .setTimestamp(); 50 | msg.send("Olá " + user.toString() + "."); 51 | msg.send(embed).then(function (message) { 52 | message.react("🔒"); 53 | }); 54 | this.client.tickets.push(msg.id); 55 | }); 56 | } 57 | } 58 | if (this.client.tickets.includes(reaction.message.channel.id)) { 59 | if (reaction.emoji.name === "🔒") { 60 | reaction.message.react("✅"); 61 | const chooseArr = ["✅", "❎"]; 62 | const reacted = await AwaitReact(reaction.message, user, 10, chooseArr); 63 | const result = await getResult(reacted); 64 | if (reacted == "✅") { 65 | reaction.message.channel.send(result); 66 | } 67 | function getResult(me) { 68 | if (me === "✅") { 69 | const embed = new ClientEmbed(this.client.user) 70 | .setDescription("`O ticket fechará em 5 segundos`") 71 | .setTimestamp(); 72 | reaction.message.reactions.removeAll(); 73 | reaction.message.channel.setName("ticket-fechado"); 74 | setTimeout(() => { 75 | reaction.message.channel.delete(); 76 | }, 5000); 77 | return embed; 78 | } else if (me === "❎") { 79 | reaction.message.reactions.removeAll(); 80 | reaction.message.react("🔒"); 81 | } 82 | } 83 | } 84 | } 85 | } 86 | }; 87 | async function AwaitReact(message, author, time, validReactions) { 88 | time *= 1000; 89 | for (const reaction of validReactions) await message.react(reaction); 90 | const filter = (reaction, user) => 91 | validReactions.includes(reaction.emoji.name) && user.id === author.id; 92 | return message 93 | .awaitReactions(filter, { max: 1, time: time }) 94 | .then((collected) => collected.first() && collected.first().emoji.name); 95 | } 96 | -------------------------------------------------------------------------------- /src/client/listeningIn/raw.js: -------------------------------------------------------------------------------- 1 | module.exports = class { 2 | constructor(client) { 3 | this.client = client; 4 | } 5 | 6 | async run(dados) { 7 | if (dados.t !== "MESSAGE_REACTION_ADD") return; 8 | if (dados.d.message_id != process.env.MSGID) return; 9 | 10 | let servidor = this.client.guilds.cache.get(process.env.GUILD_ID); 11 | let membro = servidor.members.cache.get(dados.d.user_id); 12 | 13 | let cargo = servidor.roles.cache.get(process.env.ROLE_ID); 14 | 15 | if (dados.t === "MESSAGE_REACTION_ADD") { 16 | if (dados.d.emoji.name === "✅") { 17 | if (membro.roles.cache.has(cargo)) return; 18 | membro.roles.add(cargo); 19 | 20 | servidor.channels.cache 21 | .get(process.env.CAPTCHA) 22 | .messages.fetch(dados.d.message_id) 23 | .then((message) => { 24 | message.reactions.cache 25 | .find((r) => r.emoji.name === "✅") 26 | .users.remove(dados.d.user_id); 27 | }); 28 | } 29 | } 30 | } 31 | }; 32 | -------------------------------------------------------------------------------- /src/client/listeningIn/ready.js: -------------------------------------------------------------------------------- 1 | const SLEEP = async () => { 2 | return Number(60000 * 5); 3 | }; 4 | 5 | module.exports = class { 6 | constructor(client) { 7 | this.client = client; 8 | } 9 | 10 | async run(client) { 11 | try { 12 | console.log( 13 | `(ONLINE) - Bot Online!\nUsuários: ${this.client.users.cache.size}\nServidores: ${this.client.guilds.cache.size}\nCanais: ${this.client.channels.cache.size}` 14 | ); 15 | 16 | this.client.user.setActivity("🎮 na Rede Specter.", { 17 | type: "PLAYING", 18 | url: "https://forum.redespecter.com", 19 | }); 20 | 21 | const timeOut = (ms) => setTimeout(UPDATE_CHANNEL, ms); 22 | const UPDATE_CHANNEL = async () => { 23 | console.log("(ONLINE): Continuo Online sem Problemas."); 24 | 25 | return timeOut(await SLEEP()); 26 | }; 27 | 28 | return timeOut(); 29 | } catch (error) { 30 | console.log(error); 31 | } 32 | } 33 | }; 34 | -------------------------------------------------------------------------------- /src/commands/Bot/botinfo.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | Emojis = require("../../utils/Emojis"); 4 | 5 | module.exports = class BotInfo extends ( 6 | Command 7 | ) { 8 | constructor(client) { 9 | super(client); 10 | this.client = client; 11 | 12 | this.name = "botinfo"; 13 | this.category = "Bot"; 14 | this.description = "Veja às informações do Bot"; 15 | this.usage = "botinfo"; 16 | this.aliases = []; 17 | 18 | this.enabled = true; 19 | this.guildOnly = false; 20 | } 21 | async run(message, args, prefix) { 22 | const dev = await this.client.users.fetch("600804786492932101"); 23 | 24 | const EMBED = new ClientEmbed(message.author) 25 | 26 | .setAuthor(`Minhas Informações`, this.client.user.displayAvatarURL()) 27 | .addFields( 28 | { 29 | name: `${Emojis.Comando} Meu Desenvolvedor`, 30 | value: dev.tag, 31 | }, 32 | { 33 | name: `${Emojis.Robo} Prefixo`, 34 | value: prefix, 35 | }, 36 | { 37 | name: `${Emojis.Aliases} Servidores`, 38 | value: this.client.guilds.cache.size, 39 | }, 40 | { 41 | name: `${Emojis.User} Usuários`, 42 | value: this.client.users.cache.size, 43 | }, 44 | { 45 | name: `${Emojis.JavaScript} Linguagem de Desenvolvimento`, 46 | value: `**[JavaScript](https://discord.js.org/)**`, 47 | } 48 | // { 49 | // name: `Sabia que sou Open Source?`, 50 | // value: `**[Clique Aqui](https://github.com/zSpl1nterUS/Rede-Specter)**` 51 | // } 52 | ) 53 | .setThumbnail( 54 | this.client.user.displayAvatarURL({ size: 2048, format: "jpg" }) 55 | ); 56 | 57 | message.channel.send(EMBED); 58 | } 59 | }; 60 | -------------------------------------------------------------------------------- /src/commands/Bot/help.js: -------------------------------------------------------------------------------- 1 | const { UserFlags, Client } = require("discord.js"); 2 | const Command = require("../../structure/Command"); 3 | const Emojis = require("../../utils/Emojis"); 4 | ClientEmbed = require("../../structure/ClientEmbed"); 5 | const msgTimeOut = async (msg, time) => { 6 | await new Promise(function (resolve, reject) { 7 | setTimeout(resolve, time); 8 | }); 9 | return msg.reactions.removeAll().catch(() => {}); 10 | }; 11 | 12 | module.exports = class Help extends ( 13 | Command 14 | ) { 15 | constructor(client) { 16 | super(client); 17 | this.client = client; 18 | 19 | this.name = "help"; 20 | this.category = "Bot"; 21 | this.description = "Veja a Lista de comandos do Bot"; 22 | this.usage = "help "; 23 | this.aliases = ["ajuda"]; 24 | 25 | this.enabled = true; 26 | this.guildOnly = false; 27 | } 28 | async run(message, args, prefix) { 29 | const Bot = []; 30 | const Owner = []; 31 | const Information = []; 32 | const Economy = []; 33 | const Misc = []; 34 | 35 | const { commands } = message.client; 36 | 37 | const AJUDA = new ClientEmbed(message.author) 38 | .setAuthor( 39 | `Central de Ajuda do Bot`, 40 | this.client.user.displayAvatarURL({ size: 2048 }) 41 | ) 42 | .setThumbnail(this.client.user.displayAvatarURL({ size: 2048 })); 43 | 44 | if (args[0]) { 45 | const name = args[0].toLowerCase(); 46 | const comando = 47 | commands.get(name) || 48 | commands.find((cmd) => cmd.aliases && cmd.aliases.includes(name)); 49 | 50 | if (!comando) { 51 | return message.channel.send( 52 | `${message.author}, não achei nenhum comando com o nome/aliases **\`${name}\`**.` 53 | ); 54 | } 55 | 56 | AJUDA.addField(`${Emojis.Comando} Comando:`, comando.name); 57 | 58 | if (comando.aliases) 59 | AJUDA.addField( 60 | `${Emojis.Aliases} Aliases`, 61 | !comando.aliases.length ? "Nenhum" : comando.aliases.join(", ") 62 | ); 63 | if (comando.description) 64 | AJUDA.addField( 65 | `${Emojis.Desc} Descrição`, 66 | !comando.description.length ? "Nenhuma" : comando.description 67 | ); 68 | if (comando.usage) 69 | AJUDA.addField( 70 | `${Emojis.Uso} Modo de Uso`, 71 | !comando.usage.length ? "Nenhum" : comando.usage 72 | ); 73 | 74 | message.channel.send(AJUDA); 75 | } else { 76 | commands.map((cmd) => { 77 | if (cmd.category === "Bot") 78 | Bot.push({ 79 | name: cmd.name, 80 | aliases: cmd.aliases, 81 | desc: cmd.description, 82 | }); 83 | else if (cmd.category == "Owner") 84 | Owner.push({ 85 | name: cmd.name, 86 | aliases: cmd.aliases, 87 | desc: cmd.description, 88 | }); 89 | else if (cmd.category == "Information") 90 | Information.push({ 91 | name: cmd.name, 92 | aliases: cmd.aliases, 93 | desc: cmd.description, 94 | }); 95 | else if (cmd.category == "Economy") 96 | Economy.push({ 97 | name: cmd.name, 98 | aliases: cmd.aliases, 99 | desc: cmd.description, 100 | }); 101 | else if (cmd.category == "Misc") 102 | Misc.push({ 103 | name: cmd.name, 104 | aliases: cmd.aliases, 105 | desc: cmd.description, 106 | }); 107 | else 108 | Bot.push({ 109 | name: cmd.name, 110 | aliases: cmd.aliases, 111 | desc: cmd.description, 112 | }); 113 | }); 114 | 115 | const HELP = new ClientEmbed(message.author) 116 | .setAuthor( 117 | `Central de Ajuda do Bot`, 118 | this.client.user.displayAvatarURL({ size: 2048 }) 119 | ) 120 | .setDescription( 121 | `${Emojis.User} - **${message.author.tag}**, aqui você irá encontrar todos os meus comandos, para saber mais sobre algum comando use **\`${prefix}help \`**\nNo momento tenho **${this.client.commands.size} comandos**.\n\n${Emojis.One} | Comandos do **Bot**\n${Emojis.Two} | Comandos de **Informação**\n${Emojis.Three} | Comandos de **Economia**\n${Emojis.Four} | Comandos sem **Categoria**\n${Emojis.Five} | Comandos **Restritos**\n\n${Emojis.Back} | Volta a **Página Inicial**\n${Emojis.Errado} | Deleta a **Mensagem**` 122 | ) 123 | .setThumbnail(this.client.user.displayAvatarURL({ size: 2048 })); 124 | 125 | await message.channel.send(HELP).then(async (msg) => { 126 | msg.react(Emojis.One); 127 | msg.react(Emojis.Two); 128 | msg.react(Emojis.Three); 129 | msg.react(Emojis.Four); 130 | msg.react(Emojis.Five); 131 | msg.react(Emojis.Back); 132 | msg.react(Emojis.Errado); 133 | 134 | const filter = (reaction, user) => 135 | [ 136 | Emojis.One, 137 | Emojis.Two, 138 | Emojis.Three, 139 | Emojis.Four, 140 | Emojis.Five, 141 | Emojis.Back, 142 | Emojis.Errado, 143 | ].includes(reaction.emoji.name) && user.id === message.author.id; 144 | 145 | const collector = msg.createReactionCollector(filter, { time: 120000 }); 146 | 147 | msgTimeOut(msg, 120000); 148 | 149 | collector.on("collect", async (r) => { 150 | switch (r.emoji.name) { 151 | case Emojis.One: { 152 | const E1 = new ClientEmbed(message.author) 153 | .addField( 154 | `${Emojis.Robo} Comandos do Bot`, 155 | Bot.map( 156 | (x) => 157 | `\`${prefix}${x.name}${ 158 | !x.aliases.length 159 | ? "" 160 | : ` [${x.aliases.map((x) => x).join(", ")}]` 161 | }\` - ${x.desc}` 162 | ).join("\n") 163 | ) 164 | .setThumbnail( 165 | this.client.user.displayAvatarURL({ size: 2048 }) 166 | ); 167 | 168 | r.users.remove(r.users.cache.last()); 169 | 170 | msg.edit(E1); 171 | break; 172 | } 173 | 174 | case Emojis.Two: { 175 | const E2 = new ClientEmbed(message.author) 176 | .addField( 177 | `${Emojis.Information} Comandos de Informação`, 178 | Information.map( 179 | (x) => 180 | `\`${prefix}${x.name}${ 181 | !x.aliases.length 182 | ? "" 183 | : ` [${x.aliases.map((x) => x).join(", ")}]` 184 | }\` - ${x.desc}` 185 | ).join("\n") 186 | ) 187 | .setThumbnail( 188 | this.client.user.displayAvatarURL({ size: 2048 }) 189 | ); 190 | 191 | r.users.remove(r.users.cache.last()); 192 | 193 | msg.edit(E2); 194 | break; 195 | } 196 | 197 | case Emojis.Three: { 198 | const E3 = new ClientEmbed(message.author) 199 | .addField( 200 | `${Emojis.Economy} Comandos de Economia`, 201 | Economy.map( 202 | (x) => 203 | `\`${prefix}${x.name}${ 204 | !x.aliases.length 205 | ? "" 206 | : ` [${x.aliases.map((x) => x).join(", ")}]` 207 | }\` - ${x.desc}` 208 | ).join("\n") 209 | ) 210 | .setThumbnail( 211 | this.client.user.displayAvatarURL({ size: 2048 }) 212 | ); 213 | 214 | r.users.remove(r.users.cache.last()); 215 | 216 | msg.edit(E3); 217 | break; 218 | } 219 | 220 | case Emojis.Four: { 221 | const E4 = new ClientEmbed(message.author) 222 | .addField( 223 | `${Emojis.Robo} Comandos sem Categoria`, 224 | Misc.map( 225 | (x) => 226 | `\`${prefix}${x.name}${ 227 | !x.aliases.length 228 | ? "" 229 | : ` [${x.aliases.map((x) => x).join(", ")}]` 230 | }\` - ${x.desc}` 231 | ).join("\n") 232 | ) 233 | .setThumbnail( 234 | this.client.user.displayAvatarURL({ size: 2048 }) 235 | ); 236 | 237 | r.users.remove(r.users.cache.last()); 238 | 239 | msg.edit(E4); 240 | break; 241 | } 242 | 243 | case Emojis.Five: { 244 | const E5 = new ClientEmbed(message.author) 245 | .addField( 246 | `${Emojis.Owner} Comandos Restritos`, 247 | Owner.map( 248 | (x) => 249 | `\`${prefix}${x.name}${ 250 | !x.aliases.length 251 | ? "" 252 | : ` [${x.aliases.map((x) => x).join(", ")}]` 253 | }\` - ${x.desc}` 254 | ).join("\n") 255 | ) 256 | .setThumbnail( 257 | this.client.user.displayAvatarURL({ size: 2048 }) 258 | ); 259 | 260 | r.users.remove(r.users.cache.last()); 261 | 262 | msg.edit(E5); 263 | break; 264 | } 265 | 266 | case Emojis.Back: { 267 | r.users.remove(r.users.cache.last()); 268 | 269 | msg.edit(HELP); 270 | break; 271 | } 272 | 273 | case Emojis.Errado: { 274 | msg.delete(); 275 | } 276 | } 277 | }); 278 | }); 279 | } 280 | } 281 | }; 282 | -------------------------------------------------------------------------------- /src/commands/Bot/ping.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | DiscordEmbed = require("../../structure/ClientEmbed"); 3 | 4 | module.exports = class Ping extends ( 5 | Command 6 | ) { 7 | constructor(client) { 8 | super(client); 9 | this.client = client; 10 | 11 | this.name = "ping"; 12 | this.category = "Bot"; 13 | this.description = "Veja a Latência da API"; 14 | this.usage = "ping"; 15 | this.aliases = ["latency"]; 16 | 17 | this.enabled = true; 18 | this.guildOnly = false; 19 | } 20 | async run(message) { 21 | let embed = new DiscordEmbed(message.author).setDescription("Ping!"); 22 | message.channel.send(embed).then((msg) => { 23 | msg.edit( 24 | embed.setDescription(`Pong! ${Math.round(this.client.ws.ping) + "ms"}`) 25 | ); 26 | }); 27 | } 28 | }; 29 | -------------------------------------------------------------------------------- /src/commands/Economy/coins.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | const Emojis = require("../../utils/Emojis"); 4 | const Util = require("../../utils/Util"); 5 | const User = require("../../database/Schemas/User"); 6 | require("moment-duration-format"); 7 | 8 | module.exports = class Coins extends ( 9 | Command 10 | ) { 11 | constructor(client) { 12 | super(client); 13 | this.client = client; 14 | 15 | this.name = "coins"; 16 | this.category = "Economy"; 17 | this.description = "Veja seus coins"; 18 | this.usage = "coins"; 19 | this.aliases = ["money", "dinheiro"]; 20 | 21 | this.enabled = true; 22 | this.guildOnly = false; 23 | } 24 | async run(message, args, prefix) { 25 | const USER = 26 | message.mentions.users.first() || 27 | this.client.users.cache.get(args[0]) || 28 | message.author; 29 | 30 | User.findOne({ _id: USER.id }, async (err, user) => { 31 | if (!args[0]) { 32 | const COINS = new ClientEmbed(message.author) 33 | .setAuthor( 34 | `${USER.username} - Coins`, 35 | USER.displayAvatarURL({ dynamic: true }) 36 | ) 37 | .setThumbnail(USER.displayAvatarURL({ dynamic: true, size: 2048 })) 38 | .addFields( 39 | { 40 | name: `${Emojis.Coins} Carteira`, 41 | value: 42 | user.coins == 0 ? "Nada" : "R$" + Util.toAbbrev(user.coins), 43 | }, 44 | { 45 | name: `${Emojis.Bank} Banco`, 46 | value: user.bank == 0 ? "Nada" : "R$" + Util.toAbbrev(user.bank), 47 | }, 48 | { 49 | name: `${Emojis.Economy} Total`, 50 | value: "R$" + (user.bank + user.coins).toLocaleString(), 51 | } 52 | ); 53 | 54 | return message.channel.send(COINS); 55 | } 56 | 57 | if (message.author.id != process.env.OWNER_ID) 58 | return message.channel.send( 59 | `${Emojis.Errado} - ${message.author}, você não tem permissão bobinho(a). ^^` 60 | ); 61 | 62 | const member = 63 | message.mentions.users.first() || this.client.users.cache.get(args[1]); 64 | 65 | //SET 66 | 67 | if (["set", "setar"].includes(args[0].toLowerCase())) { 68 | let money = parseInt(args[2]); 69 | 70 | if (!args[1]) 71 | return message.channel.send( 72 | `${Emojis.Errado} - ${message.author}, modo correto de usar o comando **\`${prefix}coins set \`**.` 73 | ); 74 | 75 | if (!member) { 76 | return message.channel.send( 77 | `${Emojis.Errado} - ${message.author}, mencione/insira o ID do usuário que deseja setar o dinheiro.` 78 | ); 79 | } else if (isNaN(args[2])) { 80 | return message.channel.send( 81 | `${Emojis.Errado} - ${message.author}, o que você inseriu não é um número, tente novamente.` 82 | ); 83 | } else { 84 | message.channel.send( 85 | `${Emojis.Certo} - ${message.author}, você alterou o dinheiro do(a) **${member}** para **R$${money}** com sucesso.` 86 | ); 87 | await User.findOneAndUpdate( 88 | { _id: member.id }, 89 | { $set: { coins: money } } 90 | ); 91 | } 92 | } 93 | 94 | //ADD 95 | 96 | if (["add", "adicionar"].includes(args[0].toLowerCase())) { 97 | let money = parseInt(args[2]); 98 | 99 | if (!args[1]) 100 | return message.channel.send( 101 | `${Emojis.Errado} - ${message.author}, modo correto de usar o comando **\`${prefix}coins add \`**.` 102 | ); 103 | 104 | if (!member) { 105 | return message.channel.send( 106 | `${Emojis.Errado} - ${message.author}, mencione/insira o ID do usuário que deseja adicionar o dinheiro.` 107 | ); 108 | } else if (isNaN(args[2])) { 109 | return message.channel.send( 110 | `${Emojis.Errado} - ${message.author}, o que você inseriu não é um número, tente novamente.` 111 | ); 112 | } else { 113 | message.channel.send( 114 | `${Emojis.Certo} - ${message.author}, você adicionou **R$${money}** à conta do **${member}** com sucesso.` 115 | ); 116 | await User.findOneAndUpdate( 117 | { _id: member.id }, 118 | { $set: { coins: user.coins + money } } 119 | ); 120 | } 121 | } 122 | 123 | //REMOVE 124 | 125 | if (["remove", "remover"].includes(args[0].toLowerCase())) { 126 | let money = parseInt(args[2]); 127 | 128 | if (!args[1]) 129 | return message.channel.send( 130 | `${Emojis.Errado} - ${message.author}, modo correto de usar o comando **\`${prefix}coins remover \`**.` 131 | ); 132 | 133 | if (!member) { 134 | return message.channel.send( 135 | `${Emojis.Errado} - ${message.author}, mencione/insira o ID do usuário que deseja remover dinheiro.` 136 | ); 137 | } else if (isNaN(args[2])) { 138 | return message.channel.send( 139 | `${Emojis.Errado} - ${message.author}, o que você inseriu não é um número, tente novamente.` 140 | ); 141 | } else if (user.coins < money) { 142 | return message.channel.send( 143 | `${Emojis.Errado} - ${message.author}, a quantia de dinheiro do usuário é menor do que a quantia que você deseja remover, tente novamente.` 144 | ); 145 | } else { 146 | message.channel.send( 147 | `${Emojis.Certo} - ${message.author}, você removeu **R$${money}** da conta do **${member}** com sucesso.` 148 | ); 149 | await User.findOneAndUpdate( 150 | { _id: member.id }, 151 | { $set: { coins: user.coins - money } } 152 | ); 153 | } 154 | } 155 | }); 156 | } 157 | }; 158 | -------------------------------------------------------------------------------- /src/commands/Economy/daily.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | const Emojis = require("../../utils/Emojis"); 4 | const Util = require("../../utils/Util"); 5 | const User = require("../../database/Schemas/User"); 6 | const moment = require("moment"); 7 | require("moment-duration-format"); 8 | 9 | module.exports = class Daily extends ( 10 | Command 11 | ) { 12 | constructor(client) { 13 | super(client); 14 | this.client = client; 15 | 16 | this.name = "daily"; 17 | this.category = "Economy"; 18 | this.description = "Pegue sua recompensa diária"; 19 | this.usage = "daily"; 20 | this.aliases = ["diário"]; 21 | 22 | this.enabled = true; 23 | this.guildOnly = false; 24 | } 25 | async run(message, args, prefix) { 26 | User.findOne({ _id: message.author.id }, async (err, user) => { 27 | let cooldown = 86400000; 28 | let coins = Math.floor(Math.random() * 10000) + 1000; 29 | let daily = user.daily; 30 | let time = cooldown - (Date.now() - daily); 31 | 32 | if (daily !== null && cooldown - (Date.now() - daily) > 0) { 33 | return message.channel.send( 34 | `${Emojis.Cooldown} - ${ 35 | message.author 36 | }, você deve aguardar **${moment 37 | .duration(time) 38 | .format("h [horas], m [minutos] e s [segundos]") 39 | .replace( 40 | "minsutos", 41 | "minutos" 42 | )}** para pegar sua recompensa diária novamente.` 43 | ); 44 | } else { 45 | message.channel.send( 46 | `${Emojis.Coins} - ${ 47 | message.author 48 | }, você conseguiu **R$${Util.toAbbrev( 49 | coins 50 | )}** em seu **daily** hoje.` 51 | ); 52 | await User.findOneAndUpdate( 53 | { _id: message.author.id }, 54 | { $set: { coins: user.coins + coins, daily: Date.now() } } 55 | ); 56 | } 57 | }); 58 | } 59 | }; 60 | -------------------------------------------------------------------------------- /src/commands/Economy/deposity.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | const Emojis = require("../../utils/Emojis"); 4 | const Util = require("../../utils/Util"); 5 | const User = require("../../database/Schemas/User"); 6 | const moment = require("moment"); 7 | require("moment-duration-format"); 8 | 9 | module.exports = class Deposity extends ( 10 | Command 11 | ) { 12 | constructor(client) { 13 | super(client); 14 | this.client = client; 15 | 16 | this.name = "deposity"; 17 | this.category = "Economy"; 18 | this.description = "Deposite seu dinheiro no banco"; 19 | this.usage = "depositar "; 20 | this.aliases = ["depositar", "deep", "dep"]; 21 | 22 | this.enabled = true; 23 | this.guildOnly = false; 24 | } 25 | async run(message, args, prefix) { 26 | User.findOne({ _id: message.author.id }, async (err, user) => { 27 | if (!args[0]) 28 | return message.channel.send( 29 | `${Emojis.Errado} - ${message.author} modo de usar o comando: **${prefix}depositar **` 30 | ); 31 | 32 | if (user.coins == 0) { 33 | return message.channel.send( 34 | `${Emojis.Economy} - ${message.author}, você não tem coins para depositar.` 35 | ); 36 | } 37 | 38 | let aliases = ["tudo", "all"]; 39 | let quantia = parseInt(args[0]); 40 | 41 | if (aliases.some((x) => args[0] == x)) { 42 | return message.channel 43 | .send( 44 | `${Emojis.Certo} - ${ 45 | message.author 46 | }, você depositou **R$${Util.toAbbrev( 47 | user.coins 48 | )}** com sucesso em seu banco.` 49 | ) 50 | .then(async (x) => { 51 | await User.findOneAndUpdate( 52 | { _id: message.author.id }, 53 | { $set: { bank: user.bank + user.coins, coins: 0 } } 54 | ); 55 | }); 56 | } else { 57 | if (!quantia && isNaN(args[0])) { 58 | return message.channel.send( 59 | `${Emojis.Errado} - ${message.author}, você deve inserir quanto deseja depositar.` 60 | ); 61 | } else if (user.coins < quantia) { 62 | return message.channel.send( 63 | `${Emojis.Economy} - ${ 64 | message.author 65 | }, desculpe mas você não possui essa quantia para depositar, no momento você tem **R$${user.coins.toLocaleString()}**.` 66 | ); 67 | } else { 68 | message.channel.send( 69 | `${Emojis.Bank} - ${ 70 | message.author 71 | }, você depositou com sucesso **R$${quantia.toLocaleString()}**.` 72 | ); 73 | await User.findOneAndUpdate( 74 | { _id: message.author.id }, 75 | { $set: { bank: user.bank + quantia, coins: user.coins - quantia } } 76 | ); 77 | } 78 | } 79 | }); 80 | } 81 | }; 82 | -------------------------------------------------------------------------------- /src/commands/Economy/pay.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | const Emojis = require("../../utils/Emojis"); 4 | const Util = require("../../utils/Util"); 5 | const User = require("../../database/Schemas/User"); 6 | const moment = require("moment"); 7 | require("moment-duration-format"); 8 | 9 | module.exports = class Pay extends ( 10 | Command 11 | ) { 12 | constructor(client) { 13 | super(client); 14 | this.client = client; 15 | 16 | this.name = "pay"; 17 | this.category = "Economy"; 18 | this.description = "Envie dinheiro para outros membros"; 19 | this.usage = "pay "; 20 | this.aliases = ["enviar", "pagar"]; 21 | 22 | this.enabled = true; 23 | this.guildOnly = false; 24 | } 25 | async run(message, args, prefix) { 26 | const USER = 27 | this.client.users.cache.get(args[0]) || message.mentions.users.first(); 28 | 29 | if (!USER) 30 | return message.channel.send( 31 | `${Emojis.Errado} - ${message.author}, você deve inserir pra quem deseja enviar dinheiro.` 32 | ); 33 | 34 | User.findOne({ _id: USER.id }, async (err, user) => { 35 | User.findOne({ _id: message.author.id }, async (err, author) => { 36 | let quantia = parseInt(args[1]); 37 | 38 | if (!quantia && isNaN(args[1])) { 39 | return message.channel.send( 40 | `${Emojis.Errado} - ${message.author}, modo correto de usar o comando: **${prefix}pay <@USER/ID> **` 41 | ); 42 | } else if (author.coins < quantia) { 43 | return message.channel.send( 44 | `${Emojis.Errado} - ${message.author}, desculpe mas você não possui essa quantia de dinheiro para enviar.` 45 | ); 46 | } else { 47 | message.channel.send( 48 | `${Emojis.Coins} - ${ 49 | message.author 50 | }, você enviou **R$${Util.toAbbrev( 51 | quantia 52 | )}** para o usuário **${USER}** com sucesso.` 53 | ); 54 | await User.findOneAndUpdate( 55 | { _id: message.author.id }, 56 | { $set: { coins: author.coins - quantia } } 57 | ); 58 | await User.findOneAndUpdate( 59 | { _id: USER.id }, 60 | { $set: { coins: user.coins + quantia } } 61 | ); 62 | } 63 | }); 64 | }); 65 | } 66 | }; 67 | -------------------------------------------------------------------------------- /src/commands/Economy/rank.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | const Emojis = require("../../utils/Emojis"); 4 | const Util = require("../../utils/Util"); 5 | const User = require("../../database/Schemas/User"); 6 | const moment = require("moment"); 7 | require("moment-duration-format"); 8 | 9 | module.exports = class Rank extends ( 10 | Command 11 | ) { 12 | constructor(client) { 13 | super(client); 14 | this.client = client; 15 | 16 | this.name = "rank"; 17 | this.category = "Economy"; 18 | this.description = "Veja o rank de coins"; 19 | this.usage = "rank"; 20 | this.aliases = []; 21 | 22 | this.enabled = true; 23 | this.guildOnly = false; 24 | } 25 | async run(message, args, prefix) { 26 | await require("mongoose") 27 | .connection.collection("users") 28 | .find({ bank: { $gt: 0 } }) 29 | .toArray((err, res) => { 30 | if (err) throw err; 31 | 32 | let top_users = res.sort( 33 | (x, f) => f.bank + (f.coins || 0) - (x.bank + (x.coins || 0)) 34 | ); 35 | 36 | const TOP = new ClientEmbed(message.author) 37 | .setAuthor(`${Emojis.Rank} - Ranking Monetário`) 38 | .setDescription( 39 | `${top_users 40 | .map( 41 | (x, f) => 42 | `${ 43 | f + 1 == 1 44 | ? `${Emojis.First} 1` 45 | : f + 1 == 2 46 | ? `${Emojis.Second} 2` 47 | : f + 1 == 3 48 | ? `${Emojis.Third} 3` 49 | : `${Emojis.Medal} ${f + 1}` 50 | }º: <@${x._id}> - Coins ( **${Util.toAbbrev( 51 | x.bank + x.coins 52 | )}** )` 53 | ) 54 | .join("\n")}` 55 | ); 56 | 57 | message.channel.send(TOP); 58 | }); 59 | } 60 | }; 61 | -------------------------------------------------------------------------------- /src/commands/Economy/steal.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | const Emojis = require("../../utils/Emojis"); 4 | const Util = require("../../utils/Util"); 5 | const User = require("../../database/Schemas/User"); 6 | const moment = require("moment"); 7 | require("moment-duration-format"); 8 | 9 | module.exports = class Steal extends ( 10 | Command 11 | ) { 12 | constructor(client) { 13 | super(client); 14 | this.client = client; 15 | 16 | this.name = "steal"; 17 | this.category = "Economy"; 18 | this.description = "Roube alguém"; 19 | this.usage = "steal "; 20 | this.aliases = ["roubar", "rob"]; 21 | 22 | this.enabled = true; 23 | this.guildOnly = false; 24 | } 25 | async run(message, args, prefix) { 26 | const USER = 27 | this.client.users.cache.get(args[0]) || message.mentions.users.first(); 28 | 29 | if (!USER) 30 | return message.channel.send( 31 | `${Emojis.Errado} - ${message.author}, você deve mencionar quem deseja roubar.` 32 | ); 33 | 34 | User.findOne({ _id: USER.id }, async (err, user) => { 35 | User.findOne({ _id: message.author.id }, async (err, author) => { 36 | let cooldown = 86400000; 37 | let steal = author.steal; 38 | let time = cooldown - (Date.now() - steal); 39 | 40 | if (steal !== null && cooldown - (Date.now() - steal) > 0) { 41 | return message.channel.send( 42 | `${Emojis.Cooldown} - ${ 43 | message.author 44 | }, você deve aguardar **${moment 45 | .duration(time) 46 | .format("h [horas], m [minutos] e s [segundos]") 47 | .replace("minsutos", "minutos")}** para roubar alguém novamente.` 48 | ); 49 | } else { 50 | if (user.coins == 0) 51 | return message.channel.send( 52 | `${Emojis.Errado} - ${message.author}, este usuário não tem nenhum dinheiro em sua carteira, portanto não é possível roubar ele.` 53 | ); 54 | let luck = Math.floor(Math.random() * 4) + 1; 55 | 56 | if (luck == 2) { 57 | let amount = Math.floor(Math.random() * author.coins) + 1; 58 | 59 | const FAIL = new ClientEmbed(message.author) 60 | .setTitle(`${Emojis.Police} - Preso por tentativa de Roubo`) 61 | .setColor("RED") 62 | .setDescription( 63 | `Você tentou realizar um roubo e acabou sendo preso.\nVocê perdeu um total de **R$${Util.toAbbrev( 64 | amount 65 | )}**.` 66 | ); 67 | 68 | await User.findOneAndUpdate( 69 | { _id: message.author.id }, 70 | { $set: { coins: author.coins - amount, steal: Date.now() } } 71 | ); 72 | 73 | return message.channel.send(message.author, FAIL); 74 | } else { 75 | let amount = Math.floor(Math.random() * user.coins) + 1; 76 | 77 | const SUCESS = new ClientEmbed(message.author) 78 | .setTitle(`${Emojis.Gun} - Roubo Realizado`) 79 | .setColor("GREEN") 80 | .setDescription( 81 | `Você roubou o **${USER}** com sucesso.\nVocê conseguiu um total de **R$${Util.toAbbrev( 82 | amount 83 | )}** neste roubo.` 84 | ); 85 | message.channel.send(message.author, SUCESS); 86 | await User.findOneAndUpdate( 87 | { _id: USER.id }, 88 | { $set: { coins: user.coins - amount } } 89 | ); 90 | await User.findOneAndUpdate( 91 | { _id: message.author.id }, 92 | { $set: { coins: author.coins + amount, steal: Date.now() } } 93 | ); 94 | } 95 | } 96 | }); 97 | }); 98 | } 99 | }; 100 | -------------------------------------------------------------------------------- /src/commands/Economy/withdraw.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | const Emojis = require("../../utils/Emojis"); 4 | const Util = require("../../utils/Util"); 5 | const User = require("../../database/Schemas/User"); 6 | require("moment-duration-format"); 7 | 8 | module.exports = class Withdraw extends ( 9 | Command 10 | ) { 11 | constructor(client) { 12 | super(client); 13 | this.client = client; 14 | 15 | this.name = "withdraw"; 16 | this.category = "Economy"; 17 | this.description = "Saque seu dinheiro no banco"; 18 | this.usage = "sacar "; 19 | this.aliases = ["sacar", "tirar"]; 20 | 21 | this.enabled = true; 22 | this.guildOnly = false; 23 | } 24 | async run(message, args, prefix) { 25 | User.findOne({ _id: message.author.id }, async (err, user) => { 26 | if (!args[0]) 27 | return message.channel.send( 28 | `${Emojis.Errado} - ${message.author} modo de usar o comando: **${prefix}sacar **` 29 | ); 30 | 31 | if (user.bank == 0) { 32 | return message.channel.send( 33 | `${Emojis.Economy} - ${message.author}, você não tem coins para sacar.` 34 | ); 35 | } 36 | 37 | let aliases = ["tudo", "all"]; 38 | let quantia = parseInt(args[0]); 39 | 40 | if (aliases.some((x) => args[0] == x)) { 41 | return message.channel 42 | .send( 43 | `${Emojis.Certo} - ${ 44 | message.author 45 | }, você sacou **R$${Util.toAbbrev( 46 | user.bank 47 | )}** com sucesso do seu banco.` 48 | ) 49 | .then(async () => { 50 | await User.findOneAndUpdate( 51 | { _id: message.author.id }, 52 | { $set: { bank: 0, coins: user.bank + user.coins } } 53 | ); 54 | }); 55 | } else { 56 | if (!quantia && isNaN(args[0])) { 57 | return message.channel.send( 58 | `${Emojis.Errado} - ${message.author}, você deve inserir quanto deseja sacar.` 59 | ); 60 | } else if (user.bank < quantia) { 61 | return message.channel.send( 62 | `${Emojis.Economy} - ${ 63 | message.author 64 | }, desculpe mas você não possui essa quantia para sacar, no momento você tem **R$${user.bank.toLocaleString()}**.` 65 | ); 66 | } else { 67 | message.channel.send( 68 | `${Emojis.Bank} - ${ 69 | message.author 70 | }, você sacou com sucesso **R$${quantia.toLocaleString()}**.` 71 | ); 72 | await User.findOneAndUpdate( 73 | { _id: message.author.id }, 74 | { $set: { bank: user.bank - quantia, coins: user.coins + quantia } } 75 | ); 76 | } 77 | } 78 | }); 79 | } 80 | }; 81 | -------------------------------------------------------------------------------- /src/commands/Economy/work.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | const Emojis = require("../../utils/Emojis"); 3 | const Util = require("../../utils/Util"); 4 | const User = require("../../database/Schemas/User"); 5 | const ClientEmbed = require("../../structure/ClientEmbed"); 6 | const moment = require("moment"); 7 | require("moment-duration-format"); 8 | const { MessageAttachment } = require("discord.js"); 9 | 10 | const { loadImage, registerFont, createCanvas } = require("canvas"); 11 | registerFont("src/assets/fonts/Calibri.ttf", { family: "Calibri" }); 12 | registerFont("src/assets/fonts/Montserrat-Black.ttf", { 13 | family: "Monstserrat", 14 | }); 15 | 16 | module.exports = class Work extends ( 17 | Command 18 | ) { 19 | constructor(client) { 20 | super(client); 21 | this.client = client; 22 | 23 | this.name = "work"; 24 | this.category = "Economy"; 25 | this.description = "Trabalhe para ganhar dinheiro"; 26 | this.usage = "work"; 27 | this.aliases = ["trabalhar"]; 28 | 29 | this.enabled = true; 30 | this.guildOnly = false; 31 | } 32 | async run(message, args, prefix, utils) { 33 | const cooldown = 4.32e7; 34 | if (!args[0]) { 35 | User.findOne({ _id: message.author.id }, async (err, author) => { 36 | const work = author.work; 37 | const works = work.cooldown; 38 | let time = cooldown - (Date.now() - works); 39 | 40 | if (!work.register) { 41 | return message.channel.send( 42 | `${Emojis.Errado} - ${message.author}, você ainda não está registrado na empresa, use **${prefix}work registrar** para se registrar e começar a trabalhar.` 43 | ); 44 | } else { 45 | if (works !== null && cooldown - (Date.now() - works) > 0) { 46 | return message.channel.send( 47 | `${Emojis.Errado} - ${ 48 | message.author 49 | }, você deve aguardar **${moment 50 | .duration(time) 51 | .format("h [horas], m [minutos] e s [segundos]") 52 | .replace("minsutos", "minutos")}** para trabalhar novamente` 53 | ); 54 | } else { 55 | const today = Object.values(work.works).filter( 56 | (x, z) => !!x.active 57 | ); 58 | 59 | const cName = today.map((x) => x.name); 60 | const atual = today.map((x) => x.coins); 61 | let xp = Math.round(Math.random() * 50) + 1; 62 | 63 | await User.findOneAndUpdate( 64 | { _id: message.author.id }, 65 | { 66 | $set: { 67 | "work.cooldown": Date.now(), 68 | coins: author.coins + parseInt(atual), 69 | "work.exp": work.exp + xp, 70 | "work.total": author.work.total + parseInt(atual), 71 | }, 72 | } 73 | ).then(async (x) => { 74 | if (x.work.exp > x.work.nextLevel * x.work.level) { 75 | switch (x.work.level + 1) { 76 | case 10: 77 | message.channel.send( 78 | `${Emojis.Certo} - ${message.author}, você upou de nível e agora trabalha como: **Empacotador**. ^^` 79 | ); 80 | await User.findOneAndUpdate( 81 | { _id: message.author.id }, 82 | { 83 | $set: { 84 | "work.level": work.level + 1, 85 | "work.exp": 0, 86 | "work.works.Lixeiro.active": false, 87 | "work.works.Empacotador.active": true, 88 | }, 89 | } 90 | ); 91 | break; 92 | } 93 | switch (x.work.level + 1) { 94 | case 20: 95 | message.channel.send( 96 | `${Emojis.Certo} - ${message.author}, você upou de nível e agora trabalha como: **iFood**. ^^` 97 | ); 98 | await User.findOneAndUpdate( 99 | { _id: message.author.id }, 100 | { 101 | $set: { 102 | "work.level": work.level + 1, 103 | "work.exp": 0, 104 | "work.works.Empacotador.active": false, 105 | "work.works.iFood.active": true, 106 | }, 107 | } 108 | ); 109 | break; 110 | } 111 | switch (x.work.level + 1) { 112 | case 30: 113 | message.channel.send( 114 | `${Emojis.Certo} - ${message.author}, você upou de nível e agora trabalha como: **Administração**. ^^` 115 | ); 116 | await User.findOneAndUpdate( 117 | { _id: message.author.id }, 118 | { 119 | $set: { 120 | "work.level": work.level + 1, 121 | "work.exp": 0, 122 | "work.works.iFood.active": false, 123 | "work.works.Administracao.active": true, 124 | }, 125 | } 126 | ); 127 | break; 128 | } 129 | switch (x.work.level + 1) { 130 | case 40: 131 | message.channel.send( 132 | `${Emojis.Certo} - ${message.author}, você upou de nível e agora trabalha como: **Policial**. ^^` 133 | ); 134 | await User.findOneAndUpdate( 135 | { _id: message.author.id }, 136 | { 137 | $set: { 138 | "work.level": work.level + 1, 139 | "work.exp": 0, 140 | "work.works.Administracao.active": false, 141 | "work.works.Policial.active": true, 142 | }, 143 | } 144 | ); 145 | break; 146 | } 147 | switch (x.work.level + 1) { 148 | case 50: 149 | message.channel.send( 150 | `${Emojis.Certo} - ${message.author}, você upou de nível e agora trabalha como: **Advogado**. ^^` 151 | ); 152 | await User.findOneAndUpdate( 153 | { _id: message.author.id }, 154 | { 155 | $set: { 156 | "work.level": work.level + 1, 157 | "work.exp": 0, 158 | "work.works.Policial.active": false, 159 | "work.works.Advogado.active": true, 160 | }, 161 | } 162 | ); 163 | break; 164 | } 165 | switch (x.work.level + 1) { 166 | case 60: 167 | message.channel.send( 168 | `${Emojis.Certo} - ${message.author}, você upou de nível e agora trabalha como: **Engenheiro**. ^^` 169 | ); 170 | await User.findOneAndUpdate( 171 | { _id: message.author.id }, 172 | { 173 | $set: { 174 | "work.level": work.level + 1, 175 | "work.exp": 0, 176 | "work.works.Advogado.active": false, 177 | "work.works.Engenheiro.active": true, 178 | }, 179 | } 180 | ); 181 | break; 182 | } 183 | switch (x.work.level + 1) { 184 | case 70: 185 | message.channel.send( 186 | `${Emojis.Certo} - ${message.author}, você upou de nível e agora trabalha como: **Progamador**. ^^` 187 | ); 188 | await User.findOneAndUpdate( 189 | { _id: message.author.id }, 190 | { 191 | $set: { 192 | "work.level": work.level + 1, 193 | "work.exp": 0, 194 | "work.works.Engenheiro.active": false, 195 | "work.works.Progamador.active": true, 196 | }, 197 | } 198 | ); 199 | break; 200 | } 201 | switch (x.work.level + 1) { 202 | case 80: 203 | message.channel.send( 204 | `${Emojis.Certo} - ${message.author}, você upou de nível e agora trabalha como: **Medico**. ^^` 205 | ); 206 | await User.findOneAndUpdate( 207 | { _id: message.author.id }, 208 | { 209 | $set: { 210 | "work.level": work.level + 1, 211 | "work.exp": 0, 212 | "work.works.Progamador.active": false, 213 | "work.works.Medico.active": true, 214 | }, 215 | } 216 | ); 217 | break; 218 | } 219 | return message.channel.send( 220 | `${Emojis.Certo} - ${ 221 | message.author 222 | }, você acaba de subir para o level **${work.level + 1}**. ^^` 223 | ); 224 | } else { 225 | return message.channel.send( 226 | `${Emojis.Certo} - ${message.author}, você trabalhou como **${cName}** com sucesso e recebeu **R$${atual}**` 227 | ); 228 | } 229 | }); 230 | } 231 | } 232 | }); 233 | return; 234 | } 235 | 236 | if (["name", "nome"].includes(args[0].toLowerCase())) { 237 | User.findOne({ _id: message.author.id }, async (err, author) => { 238 | let name = args.slice(1).join(" "); 239 | if ( 240 | message.content.includes("*") || 241 | message.content.includes("_") || 242 | message.content.includes("`") 243 | ) { 244 | return message.channel.send( 245 | `${Emojis.Errado} - ${message.author}, não é possível usar os seguintes símbolos no nome da empresa:\`* - _ e ASPAS\`` 246 | ); 247 | } 248 | 249 | if (!name) { 250 | return message.channel.send( 251 | `${Emojis.Errado} - ${message.author}, você não digitou nenhum nome para eu setar no nome da sua empresa.` 252 | ); 253 | } else if (name.length > 20) { 254 | return message.channel.send( 255 | `${Emojis.Errado} - ${message.author}, o nome inserido é muito grande, insira um com até **20 caracteres**.` 256 | ); 257 | } else { 258 | message.channel.send( 259 | `${Emojis.Certo} - ${message.author}, nome da sua fazenda alterado para **\`${name}\`** com sucesso.` 260 | ); 261 | await User.findOneAndUpdate( 262 | { _id: message.author.id }, 263 | { 264 | $set: { 265 | "work.name": name, 266 | }, 267 | } 268 | ); 269 | } 270 | }); 271 | return; 272 | } 273 | 274 | if (["registrar", "register"].includes(args[0].toLowerCase())) { 275 | User.findOne({ _id: message.author.id }, async (err, author) => { 276 | const work = author.work; 277 | 278 | if (work.register) { 279 | return message.channel.send( 280 | `${Emojis.Errado} - ${message.author}, você já está registrado, portanto não é possível registrar novamente.` 281 | ); 282 | } else { 283 | message.channel.send( 284 | `${Emojis.Certo} - ${message.author}, parabéns por se registrar na empresa, hoje começa seus dias de sofrência, você está começando como **Lixeiro** no Level **1** com o salário de **R$${work.works.Lixeiro.coins}**, com o tempo irá upar e receber mais dinheiro em empregos melhores.` 285 | ); 286 | await User.findOneAndUpdate( 287 | { _id: message.author.id }, 288 | { 289 | $set: { 290 | "work.register": true, 291 | "work.works.Lixeiro.active": true, 292 | }, 293 | } 294 | ); 295 | } 296 | }); 297 | return; 298 | } 299 | 300 | const users = 301 | this.client.users.cache.get(args[1]) || 302 | message.mentions.users.first() || 303 | message.author; 304 | 305 | User.findOne({ _id: users.id }, async (err, user) => { 306 | const worke = user.work; 307 | const workes = worke.cooldown; 308 | let time = cooldown - (Date.now() - workes); 309 | 310 | if (["empregos"].includes(args[0].toLowerCase())) { 311 | const today = Object.values(worke.works).filter((x) => !!x.active); 312 | 313 | const INFO = new ClientEmbed(message.author).setAuthor( 314 | `Lista de Empregos`, 315 | this.client.user.displayAvatarURL() 316 | ).setDescription(`Informações sobre: **${ 317 | users.tag 318 | }**\n\n${Object.values(worke.works) 319 | .map( 320 | (key) => 321 | `Emprego: **${key.name}** | Level: **${ 322 | key.level <= user.work.level 323 | ? `${key.level} ${Emojis.Certo}` 324 | : key.level 325 | }**\nSalário: **R$ ${Util.toAbbrev(key.coins)}**` 326 | ) 327 | .slice(1, 10) 328 | .join("\n\n")}\n\n 329 | ${ 330 | !today.length 331 | ? `> Não possui emprego ainda, use **${prefix}work registrar** para se registrar na empresa` 332 | : `> Level **${worke.level} ( XP: ${worke.exp}/${ 333 | worke.level * worke.nextLevel 334 | } )** e está trabalhando como **${today.map( 335 | (x) => x.name 336 | )}**.\n> Já recebeu um total de **R$${Util.toAbbrev( 337 | worke.total 338 | )}**.\n${ 339 | workes !== null && cooldown - (Date.now() - workes) > 0 340 | ? `> Aguarde **${moment 341 | .duration(time) 342 | .format("h [horas], m [minutos] e s [segundos]") 343 | .replace( 344 | "minsutos", 345 | "minutos" 346 | )}** até poder trabalhar novamente.` 347 | : "> Já pode trabalhar novamente." 348 | }` 349 | }`); 350 | 351 | message.channel.send(INFO); 352 | return; 353 | } 354 | 355 | if (["info"].includes(args[0].toLowerCase())) { 356 | const today = Object.values(worke.works).filter((x) => !!x.active); 357 | 358 | const canvas = createCanvas(400, 500); 359 | const ctx = canvas.getContext("2d"); 360 | 361 | const background = await loadImage("./src/assets/img/Work_Info.png"); 362 | ctx.drawImage(background, 0, 0, 400, 500); 363 | 364 | ctx.textAlign = "center"; 365 | ctx.font = "50px 'Montserrat'"; 366 | ctx.fillStyle = "#fbfbfb"; 367 | await utils.renderEmoji( 368 | ctx, 369 | users.username.length > 15 370 | ? users.username.slice(0, 15) + "..." 371 | : users.username, 372 | 200, 373 | 200 374 | ); 375 | 376 | ctx.textAlign = "right"; 377 | ctx.font = "28px 'Montserrat'"; 378 | ctx.fillStyle = "#070000"; 379 | await utils.renderEmoji( 380 | ctx, 381 | user.work.name.length > 15 382 | ? user.work.name.slice(0, 15) + "..." 383 | : user.work.name, 384 | 395, 385 | 250 386 | ); 387 | ctx.fillText( 388 | today.map((x) => x.name), 389 | 395, 390 | 285 391 | ); 392 | ctx.fillText("R$" + Util.toAbbrev(today.map((x) => x.coins)), 395, 320); 393 | ctx.fillText(user.work.level, 395, 355); 394 | 395 | //========================// Import ProgressBar //========================// 396 | 397 | const need = user.work.level * user.work.nextLevel; 398 | 399 | let widthXp = (user.work.exp * 335) / need; 400 | if (user.work.exp > 335 - 18.5) user.work.xp = 200 - 18.5; 401 | 402 | ctx.beginPath(); 403 | ctx.fillStyle = "#404040"; 404 | ctx.arc( 405 | 15 + 18.5, 406 | 360 + 18.5 + 36.25, 407 | 18.5, 408 | 1.5 * Math.PI, 409 | 0.5 * Math.PI, 410 | true 411 | ); 412 | ctx.fill(); 413 | ctx.fillRect(15 + 18.5, 360 + 36.25, 350 - 18.5, 37.5); 414 | ctx.arc( 415 | 15 + 350, 416 | 360 + 18.5 + 36.25, 417 | 18.75, 418 | 1.5 * Math.PI, 419 | 0.5 * Math.PI, 420 | false 421 | ); 422 | ctx.fill(); 423 | 424 | ctx.beginPath(); 425 | ctx.fillStyle = "#88e8ff"; 426 | ctx.arc( 427 | 15 + 18.5, 428 | 360 + 18.5 + 36.25, 429 | 18.5, 430 | 1.5 * Math.PI, 431 | 0.5 * Math.PI, 432 | true 433 | ); 434 | ctx.fill(); 435 | ctx.fillRect(15 + 18.5, 360 + 36.25, widthXp, 37.5); 436 | ctx.arc( 437 | 15 + 18.5 + widthXp, 438 | 360 + 18.5 + 36.25, 439 | 18.75, 440 | 1.5 * Math.PI, 441 | 0.5 * Math.PI, 442 | false 443 | ); 444 | ctx.fill(); 445 | 446 | //========================// Import Info Xp Progress Bar //========================// 447 | 448 | ctx.textAlign = "center"; 449 | ctx.font = "25px 'Calibri'"; 450 | ctx.fillStyle = "#fbfbfb"; 451 | ctx.fillText( 452 | `${Util.toAbbrev(user.work.exp)}/${Util.toAbbrev( 453 | user.work.level * user.work.nextLevel 454 | )}`, 455 | 200, 456 | 425 457 | ); 458 | //========================// Import Avatar //========================// 459 | 460 | ctx.beginPath(); 461 | ctx.arc(200, 70, 65, 0, Math.PI * 2, true); 462 | ctx.lineWidth = 6; 463 | ctx.strokeStyle = "#88e8ff"; 464 | ctx.stroke(); 465 | ctx.closePath(); 466 | ctx.clip(); 467 | 468 | const avatar = await loadImage( 469 | users.displayAvatarURL({ format: "jpeg" }) 470 | ); 471 | ctx.drawImage(avatar, 135, 5, 130, 130); 472 | 473 | const attach = new MessageAttachment( 474 | canvas.toBuffer(), 475 | `Work_Info(${users.tag})--.png` 476 | ); 477 | 478 | message.channel.send(attach); 479 | } 480 | }); 481 | } 482 | }; 483 | -------------------------------------------------------------------------------- /src/commands/Information/avatar.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | Emojis = require("../../utils/Emojis"); 4 | const Gamedig = require("gamedig"); 5 | const Util = require("../../utils/Util"); 6 | const { User } = require("discord.js"); 7 | module.exports = class Help extends ( 8 | Command 9 | ) { 10 | constructor(client) { 11 | super(client); 12 | this.client = client; 13 | 14 | this.name = "avatar"; 15 | this.category = "Information"; 16 | this.description = "Veja o avatar do usuário."; 17 | this.usage = "avatar [user]"; 18 | this.aliases = ["avt"]; 19 | 20 | this.enabled = true; 21 | this.guildOnly = false; 22 | } 23 | async run(message, args, prefix) { 24 | const USER = 25 | this.client.users.cache.get(args[0]) || 26 | message.mentions.users.first() || 27 | message.author; 28 | 29 | const EMBED = new ClientEmbed(message.author) 30 | .addFields({ 31 | name: USER.username, 32 | value: `Clique **[aqui](${USER.displayAvatarURL({ 33 | dynamic: true, 34 | size: 2048, 35 | format: "jpg", 36 | })})** para baixar o avatar`, 37 | }) 38 | .setImage( 39 | USER.displayAvatarURL({ dynamic: true, size: 2048, format: "jpg" }) 40 | ); 41 | 42 | message.channel.send(EMBED); 43 | } 44 | }; 45 | -------------------------------------------------------------------------------- /src/commands/Information/server.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | Emojis = require("../../utils/Emojis"); 4 | const Gamedig = require("gamedig"); 5 | const Util = require("../../utils/Util"); 6 | module.exports = class Help extends ( 7 | Command 8 | ) { 9 | constructor(client) { 10 | super(client); 11 | this.client = client; 12 | 13 | this.name = "server"; 14 | this.category = "Information"; 15 | this.description = "Veja as informações do servidor."; 16 | this.usage = "server"; 17 | this.aliases = ["servidor"]; 18 | 19 | this.enabled = true; 20 | this.guildOnly = false; 21 | } 22 | async run(message, args, prefix) { 23 | const SERVER = new ClientEmbed(message.author); 24 | 25 | Gamedig.query({ 26 | type: "minecraft", 27 | host: `redespecter.com`, 28 | }).then((state) => { 29 | message.channel.send( 30 | SERVER.addFields( 31 | { 32 | name: `MOTD`, 33 | value: state.name, 34 | }, 35 | { 36 | name: `Players Online`, 37 | value: !state.players.length 38 | ? "Nenhum Player Online no Momento" 39 | : state.players.length, 40 | }, 41 | { 42 | name: `Ping`, 43 | value: state.raw.vanilla.ping + "ms", 44 | } 45 | ) 46 | .setAuthor( 47 | `Informações do Servidor`, 48 | "https://cdn.discordapp.com/icons/794641040631005215/8a1a250f187969a9dbfcec198b8afebe.webp?size=2048" 49 | ) 50 | .setThumbnail( 51 | "https://cdn.discordapp.com/icons/794641040631005215/8a1a250f187969a9dbfcec198b8afebe.webp" 52 | ) 53 | ); 54 | }); 55 | } 56 | }; 57 | -------------------------------------------------------------------------------- /src/commands/Miscellaneous/hug.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | const Emojis = require("../../utils/Emojis"); 4 | const fetch = require("node-fetch"); 5 | 6 | module.exports = class Coins extends ( 7 | Command 8 | ) { 9 | constructor(client) { 10 | super(client); 11 | this.client = client; 12 | 13 | this.name = "hug"; 14 | this.category = "Misc"; 15 | this.description = 16 | "Abrace alguém e mostre o carinho que você tem por ele(a) ^^"; 17 | this.usage = "hug "; 18 | this.aliases = ["abraçar", "abraço"]; 19 | 20 | this.enabled = true; 21 | this.guildOnly = false; 22 | } 23 | async run(message, args, prefix, utils) { 24 | const USER = 25 | message.mentions.users.first() || this.client.users.cache.get(args[0]); 26 | if (!USER) { 27 | return message.channel.send( 28 | `${Emojis.Errado} - ${message.author}, você deve mencionar/inserir o ID de quem deseja dar um abraço.` 29 | ); 30 | } else if (USER.id == message.author.id) 31 | return message.channel.send( 32 | `${Emojis.Errado} - ${message.author}, vá abraçar outra pessoa seu carente. ^^` 33 | ); 34 | 35 | const body = await fetch("https://nekos.life/api/v2/img/hug").then((res) => 36 | res.json() 37 | ); 38 | 39 | const EMBED = new ClientEmbed(message.author) 40 | .setDescription(`${message.author} deu um abraço no(a) ${USER}`) 41 | .setImage(body.url); 42 | 43 | message.channel.send(EMBED); 44 | } 45 | }; 46 | -------------------------------------------------------------------------------- /src/commands/Miscellaneous/kiss.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | const Emojis = require("../../utils/Emojis"); 4 | const fetch = require("node-fetch"); 5 | 6 | module.exports = class Coins extends ( 7 | Command 8 | ) { 9 | constructor(client) { 10 | super(client); 11 | this.client = client; 12 | 13 | this.name = "kiss"; 14 | this.category = "Misc"; 15 | this.description = 16 | "De um beijo em alguém e mostre o carinho que você tem por ele(a) ^^"; 17 | this.usage = "kiss "; 18 | this.aliases = ["beijar", "beijo"]; 19 | 20 | this.enabled = true; 21 | this.guildOnly = false; 22 | } 23 | async run(message, args, prefix, utils) { 24 | const USER = 25 | message.mentions.users.first() || this.client.users.cache.get(args[0]); 26 | 27 | if (!USER) { 28 | return message.channel.send( 29 | `${Emojis.Errado} - ${message.author}, você deve mencionar/inserir o ID de quem deseja dar um beijo.` 30 | ); 31 | } else if (USER.id == message.author.id) 32 | return message.channel.send( 33 | `${Emojis.Errado} - ${message.author}, vá beijar outra pessoa seu carente. ^^` 34 | ); 35 | 36 | const body = await fetch("https://nekos.life/api/v2/img/kiss").then((res) => 37 | res.json() 38 | ); 39 | 40 | const EMBED = new ClientEmbed(message.author) 41 | .setDescription(`${message.author} deu um beijo no(a) ${USER}`) 42 | .setImage(body.url); 43 | 44 | message.channel.send(EMBED); 45 | } 46 | }; 47 | -------------------------------------------------------------------------------- /src/commands/Miscellaneous/profile.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | const Emojis = require("../../utils/Emojis"); 4 | // const Util = require("../../utils/Util"); 5 | const User = require("../../database/Schemas/User"); 6 | const moment = require("moment"); 7 | require("moment-duration-format"); 8 | const { MessageAttachment } = require("discord.js"); 9 | 10 | const { loadImage, registerFont, createCanvas } = require("canvas"); 11 | registerFont("src/assets/fonts/Calibri.ttf", { family: "Calibri" }); 12 | registerFont("src/assets/fonts/Montserrat-Black.ttf", { 13 | family: "Monstserrat", 14 | }); 15 | 16 | module.exports = class Coins extends ( 17 | Command 18 | ) { 19 | constructor(client) { 20 | super(client); 21 | this.client = client; 22 | 23 | this.name = "profile"; 24 | this.category = "Misc"; 25 | this.description = "Veja seu perfil"; 26 | this.usage = "profile [user]"; 27 | this.aliases = ["p", "perfil"]; 28 | 29 | this.enabled = true; 30 | this.guildOnly = false; 31 | } 32 | async run(message, args, prefix, utils) { 33 | moment.locale("pt-BR"); 34 | 35 | const USER = 36 | message.mentions.users.first() || 37 | this.client.users.cache.get(args[0]) || 38 | message.author; 39 | 40 | User.findOne({ _id: USER.id }, async (err, user) => { 41 | await require("mongoose") 42 | .connection.collection("users") 43 | .find({ bank: { $gt: 0 } }) 44 | .toArray(async (err, res) => { 45 | if (err) throw err; 46 | 47 | let top_users = res.sort((x, f) => f.bank - x.bank); 48 | 49 | var top = 50 | [...top_users.values()].findIndex((x) => x._id === USER.id) + 1; 51 | 52 | if (!user) 53 | return message.channel 54 | .send( 55 | `${Emojis.Errado} - ${message.author}, o membro não estava registrado em minha **DataBase**, vou registra-lo.` 56 | ) 57 | .then(async (x) => { 58 | User.create({ _id: USER.id }); 59 | }); 60 | 61 | const status = { 62 | online: Emojis.Online + "Online", 63 | idle: Emojis.Ausente + "Ausente", 64 | dnd: Emojis.Ocupado + "Ocupado", 65 | offline: Emojis.Offline + "Offline", 66 | }; 67 | 68 | let flags; 69 | if (this.client.users.cache.get(USER.id).flags == null) flags = ""; 70 | else 71 | flags = this.client.users.cache 72 | .get(USER.id) 73 | .flags.toArray() 74 | .join("") 75 | .replace("EARLY_VERIFIED_DEVELOPER", Emojis.Developer) 76 | .replace("HOUSE_BRILLIANCE", Emojis.Brilliance) 77 | .replace("VERIFIED_DEVELOPER", "") 78 | .replace("HOUSE_BRAVERY", Emojis.Bravery) 79 | .replace("HOUSE_BALANCE", Emojis.Balance) 80 | .replace("EARLY_SUPPORTER", Emojis.Early) 81 | .replace("VERIFIED_BOT", Emojis.BotVerificado); 82 | 83 | const canvas = createCanvas(800, 600); 84 | const ctx = canvas.getContext("2d"); 85 | 86 | const background = await loadImage("./src/assets/img/Profile_2.jpg"); 87 | 88 | ctx.drawImage(background, 0, 0, 800, 600); 89 | 90 | ctx.textAlign = "left"; 91 | ctx.font = "30px 'Monstserrat'"; 92 | ctx.fillStyle = "#ffffFf"; 93 | await utils.renderEmoji( 94 | ctx, 95 | `${Emojis.Coins} ${utils.toAbbrev(user.coins)}`, 96 | 10, 97 | 40 98 | ); 99 | await utils.renderEmoji( 100 | ctx, 101 | `${Emojis.Bank} ${utils.toAbbrev(user.bank)}`, 102 | 10, 103 | 90 104 | ); 105 | await utils.renderEmoji( 106 | ctx, 107 | `${Emojis.Economy} ${utils.toAbbrev(user.bank + user.coins)}`, 108 | 10, 109 | 140 110 | ); 111 | 112 | ctx.font = "30px 'Monstserrat'"; 113 | 114 | await utils.renderEmoji( 115 | ctx, 116 | USER.username.length > 20 117 | ? USER.username.slice(0, 20) + "..." 118 | : USER.username, 119 | 400, 120 | 580 121 | ); 122 | 123 | ctx.font = "25px 'Monstserrat'"; 124 | 125 | await utils.renderEmoji( 126 | ctx, 127 | `${Emojis.Medal} Ranking Monetário: ${top == 0 ? "0" : `${top}º`}`, 128 | 430, 129 | 530 130 | ); 131 | await utils.renderEmoji( 132 | ctx, 133 | `${Emojis.Status} Status: ${status[USER.presence.status]}`, 134 | 440, 135 | 480 136 | ); 137 | await utils.renderEmoji( 138 | ctx, 139 | `${Emojis.Date} C. Conta: ${moment(USER.createdAt).format("L")}`, 140 | 450, 141 | 430 142 | ); 143 | await utils.renderEmoji( 144 | ctx, 145 | `${Emojis.Date} Entrada: ${moment( 146 | message.guild.member(USER.id).joinedAt 147 | ).format("L")}`, 148 | 490, 149 | 380 150 | ); 151 | await utils.renderEmoji( 152 | ctx, 153 | `${!flags.length ? "Sem Badge" : flags}`, 154 | 520, 155 | 330 156 | ); 157 | 158 | ctx.arc(115, 500, 85, 0, Math.PI * 2, true); 159 | ctx.lineWidth = 6; 160 | ctx.strokeStyle = "#88e8ff"; 161 | ctx.stroke(); 162 | ctx.closePath(); 163 | ctx.clip(); 164 | 165 | const avatar = await loadImage( 166 | USER.displayAvatarURL({ format: "jpeg" }) 167 | ); 168 | ctx.drawImage(avatar, 30, 415, 170, 170); 169 | 170 | const attach = new MessageAttachment( 171 | canvas.toBuffer(), 172 | `Specter_Profile--(${USER.tag})--.png` 173 | ); 174 | 175 | message.channel.send(attach); 176 | }); 177 | }); 178 | } 179 | }; 180 | -------------------------------------------------------------------------------- /src/commands/Miscellaneous/sugerir.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | const Emojis = require("../../utils/Emojis"); 4 | 5 | module.exports = class Coins extends ( 6 | Command 7 | ) { 8 | constructor(client) { 9 | super(client); 10 | this.client = client; 11 | 12 | this.name = "sugerir"; 13 | this.category = "Misc"; 14 | this.description = "Faça uma sugestão para o servidor"; 15 | this.usage = "sugerir"; 16 | this.aliases = ["sugestão"]; 17 | 18 | this.enabled = true; 19 | this.guildOnly = false; 20 | } 21 | async run(message, args, prefix, utils) { 22 | message.channel 23 | .send( 24 | `${Emojis.Certo} - ${message.author}, qual a sugestão que você deseja enviar?\n\nCaso deseje cancelar a ação basta digitar: **\`cancelar\`**.` 25 | ) 26 | .then(async (msg) => { 27 | let collector = msg.channel.createMessageCollector( 28 | (m) => m.author.id === message.author.id, 29 | { max: 1, time: 600000 } 30 | ); 31 | 32 | collector.on("collect", async (collected) => { 33 | if ( 34 | ["cancelar", "cancel"].includes(collected.content.toLowerCase()) 35 | ) { 36 | message.channel.send( 37 | `${Emojis.Certo} - ${message.author}, ação cancelada com sucesso.` 38 | ); 39 | 40 | return collector.stop(); 41 | } 42 | message.channel.send( 43 | `${Emojis.Certo} - ${message.author}, sugestão enviada com sucesso.` 44 | ); 45 | 46 | const EMBED = new ClientEmbed(this.client.user) 47 | .setAuthor(`${Emojis.Find} || Sugestões`) 48 | .addFields( 49 | { 50 | name: `${Emojis.User} Autor`, 51 | value: message.author.tag, 52 | }, 53 | { 54 | name: `${Emojis.Sugestion} Sugestão`, 55 | value: collected.content, 56 | } 57 | ) 58 | .setThumbnail( 59 | message.author.displayAvatarURL({ dynamic: true, size: 2048 }) 60 | ) 61 | .setFooter(`Enviada em`) 62 | .setTimestamp(); 63 | 64 | await this.client.channels.cache 65 | .get(process.env.SUGESTION) 66 | .send(EMBED) 67 | .then(async (msg) => { 68 | await msg.react(Emojis.reactions.yes); 69 | await msg.react(Emojis.reactions.no); 70 | }); 71 | msg.delete(); 72 | }); 73 | msg.delete(); 74 | }); 75 | message.delete().catch(() => {}); 76 | } 77 | }; 78 | -------------------------------------------------------------------------------- /src/commands/Owner/eval.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | DiscordEmbed = require("../../structure/ClientEmbed"); 3 | 4 | module.exports = class Eval extends ( 5 | Command 6 | ) { 7 | constructor(client) { 8 | super(client); 9 | this.client = client; 10 | 11 | this.name = "eval"; 12 | this.category = "Owner"; 13 | this.description = "Eval do Bot"; 14 | this.aliases = []; 15 | 16 | this.enabled = true; 17 | this.guildOnly = false; 18 | } 19 | async run(message, args) { 20 | if (message.author.id !== "600804786492932101") 21 | return message.channel.send("Sem permissão"); 22 | try { 23 | let argumentos = args.join(" "); 24 | if (!argumentos) 25 | return message.channel.send( 26 | `${message.author}, escreve algo primeiro.` 27 | ); 28 | let code = eval(argumentos); 29 | 30 | if (typeof code !== "string") 31 | code = require("util").inspect(code, { depth: 0 }); 32 | let embed = new DiscordEmbed(message.author) 33 | .addField("Entrada", `\`\`\`js\n${argumentos}\`\`\``) 34 | .addField("Saída", `\`\`\`js\n${code}\n\`\`\``); 35 | message.channel.send(embed); 36 | } catch (e) { 37 | message.channel.send(`\`\`\`js\n${e}\n\`\`\``); 38 | } 39 | } 40 | }; 41 | -------------------------------------------------------------------------------- /src/commands/Staff/ban.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | Emojis = require("../../utils/Emojis"); 4 | 5 | const Guild = require("../../database/Schemas/Guild"); 6 | 7 | module.exports = class Ban extends ( 8 | Command 9 | ) { 10 | constructor(client) { 11 | super(client); 12 | this.client = client; 13 | 14 | this.name = "ban"; 15 | this.category = "Owner"; 16 | this.description = "Banir usuários do seu servidor"; 17 | this.aliases = ["banir"]; 18 | 19 | this.enabled = true; 20 | this.guildOnly = false; 21 | } 22 | async run(message, args, prefix) { 23 | if (!message.member.hasPermission("BAN_MEMBERS")) 24 | return message.channel.send( 25 | `${Emojis.Errado} - ${message.author}, você não tem permissão de executar este comando.` 26 | ); 27 | 28 | var membro = 29 | message.mentions.members.first() || 30 | message.guild.members.cache.get(args[0]); 31 | if (!membro) 32 | return message.channel.send( 33 | `${Emojis.Errado} - ${message.author}, formato correto de executar o comando: **\`${prefix}ban \`**.` 34 | ); 35 | if (membro === message.member) 36 | return message.channel.send( 37 | `${Emojis.Errado} - ${message.author}, você não pode se banir.` 38 | ); 39 | 40 | var motivo = !args[1] ? "Não informado" : args.slice(1).join(" "); 41 | 42 | const ban = new ClientEmbed(message.author).setDescription( 43 | `${Emojis.Certo} - ${message.author}, você dejesa banir o usuário: **${membro.user.username}** ?` 44 | ); 45 | 46 | message.channel.send(ban).then((msg) => { 47 | msg.react("✅"); 48 | 49 | let filtro = (reaction, usuario) => 50 | reaction.emoji.name === "✅" && usuario.id === message.author.id; 51 | let coletor = msg.createReactionCollector(filtro, { max: 1 }); 52 | 53 | ban.setAuthor( 54 | `Punição`, 55 | membro.user.displayAvatarURL({ dynamic: true, size: 4096 }) 56 | ); 57 | ban.setDescription(`${membro} foi banido!`); 58 | ban.addField("Motivo", motivo); 59 | ban.addField("Duração", "Permanentemente", true); 60 | ban.addField("Aplicado por", message.author, true); 61 | 62 | coletor.on("collect", (cp) => { 63 | cp.remove(message.author.id); 64 | message.channel.bulkDelete(2); 65 | this.client.channels.cache.get(process.env.LOGS).send(ban); 66 | membro.ban(); 67 | }); 68 | }); 69 | } 70 | }; 71 | -------------------------------------------------------------------------------- /src/commands/Staff/cmdblock.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | Emojis = require("../../utils/Emojis"); 4 | 5 | const Guild = require("../../database/Schemas/Guild"); 6 | 7 | module.exports = class CmdBlock extends Command { 8 | constructor(client) { 9 | super(client); 10 | this.client = client; 11 | 12 | this.name = "cmdblock"; 13 | this.category = "Owner"; 14 | this.description = "Bloquear comandos do Bot"; 15 | this.aliases = ["cblock", "cmd-block", "cmd-b"]; 16 | 17 | this.enabled = true; 18 | this.guildOnly = false; 19 | } 20 | async run(message, args, prefix) { 21 | if (!message.member.hasPermission("MANAGE_CHANNELS")) 22 | return message.channel.send( 23 | `${Emojis.Errado} - ${messaFge.author}, você precisa da permissão **MANAGE_CHANNELS** para executar este comando.` 24 | ); 25 | 26 | Guild.findOne({ _id: message.guild.id }, async (err, server) => { 27 | if (!args[0]) 28 | return message.channel.send( 29 | `${Emojis.Uso} - ${message.author}, use **${prefix}cmdblock help** para saber informações sobre o comando.` 30 | ); 31 | 32 | const cmdblock = server.cmdblock; 33 | 34 | if (["status", "info", "help", "ajuda"].includes(args[0].toLowerCase())) { 35 | const EMBED = new ClientEmbed(message.author) 36 | 37 | .setAuthor( 38 | `${message.guild.name} - Bloqueador de Comandos`, 39 | message.guild.iconURL({ dynamic: true }) 40 | ) 41 | .addFields( 42 | { 43 | name: "Canais adicionados", 44 | value: !cmdblock.channels.length 45 | ? "Nenhu canal adicionado" 46 | : cmdblock.channels.map((x) => `<#${x}>`).join(", "), 47 | }, 48 | { 49 | name: `Comandos liberados`, 50 | value: !cmdblock.enable.length 51 | ? "Nenhum comando liberado" 52 | : cmdblock.enable.map((x) => `**${x}**`).join(", "), 53 | }, 54 | { 55 | name: `Status do Sistema`, 56 | value: `No momento o sistema se encontra **${ 57 | cmdblock.status ? "ATIVADO" : "DESATIVADO" 58 | }**`, 59 | }, 60 | { 61 | name: "Comandos", 62 | value: `${prefix}cmdblock add - Adiciona um canal à lista.\n${prefix}cmdblock remove - Remove um canal da lista.\n${prefix}cmdblock cmd - Adiciona/Remove um comando da lista\n${prefix}cmdblock on/off - Ativa/Desativa o sistema.`, 63 | } 64 | ); 65 | message.channel.send(EMBED); 66 | } 67 | 68 | if (["add", "adicionar"].includes(args[0].toLowerCase())) { 69 | const channel = 70 | message.mentions.channels.first() || 71 | message.guild.channels.cache.find((x) => x.id === args[1]) || 72 | message.channel; 73 | 74 | if (cmdblock.channels.find((x) => x === channel.id)) { 75 | return message.channel.send( 76 | `${Emojis.Errado} - ${message.author}, o canal já se encontra adicionado ao sistema.` 77 | ); 78 | } else { 79 | message.channel.send( 80 | `${Emojis.Certo} - ${message.author}, adicionei o canal ${channel} a lista de canais bloqueados com sucesso.` 81 | ); 82 | 83 | await Guild.findOneAndUpdate( 84 | { _id: message.guild.id }, 85 | { $push: { "cmdblock.channels": channel.id } } 86 | ); 87 | } 88 | } 89 | 90 | if (["remove", "remover"].includes(args[0].toLowerCase())) { 91 | const channel = 92 | message.mentions.channels.first() || 93 | message.guild.channels.cache.find((x) => x.id === args[1]) || 94 | message.channel; 95 | 96 | if (!cmdblock.channels.find((x) => x === channel.id)) { 97 | return message.channel.send( 98 | `${Emojis.Errado} - ${message.author}, este canal não está adicionado à lista.` 99 | ); 100 | } else { 101 | message.channel.send( 102 | `${Emojis.Certo} - ${message.author}, removi o canal ${channel} da lista de canais bloqueados com sucesso.` 103 | ); 104 | 105 | await Guild.findOneAndUpdate( 106 | { _id: message.guild.id }, 107 | { $pull: { "cmdblock.channels": channel.id } } 108 | ); 109 | } 110 | } 111 | 112 | if (["off", "desligar", "desativar"].includes(args[0].toLowerCase())) { 113 | if (!cmdblock.status) { 114 | return message.channel.send( 115 | `${Emojis.Errado} - ${message.author}, o sistema já se encontra desligado.` 116 | ); 117 | } else { 118 | message.channel.send( 119 | `${Emojis.Certo} - ${message.author}, o sistema foi desligado com sucesso.` 120 | ); 121 | 122 | await Guild.findOneAndUpdate( 123 | { _id: message.guild.id }, 124 | { $set: { "cmdblock.status": false } } 125 | ); 126 | } 127 | } 128 | 129 | if (["on", "ligar", "ativar"].includes(args[0].toLowerCase())) { 130 | if (cmdblock.status) { 131 | return message.channel.send( 132 | `${Emojis.Errado} - ${message.author}, o sistema já se encontra ligado.` 133 | ); 134 | } else { 135 | message.channel.send( 136 | `${Emojis.Certo} - ${message.author}, o sistema foi ligado com sucesso.` 137 | ); 138 | 139 | await Guild.findOneAndUpdate( 140 | { _id: message.guild.id }, 141 | { $set: { "cmdblock.status": true } } 142 | ); 143 | } 144 | } 145 | 146 | if (["cmd", "comando"].includes(args[0].toLowerCase())) { 147 | let cmds = 148 | this.client.commands.get(args[1]) || 149 | this.client.commands.find( 150 | (a) => a && a.aliases && a.aliases.includes(args[1]) 151 | ); 152 | 153 | let cmd = await cmds.name; 154 | 155 | if (cmdblock.enable.find((x) => x === cmd)) { 156 | return message.channel 157 | .send( 158 | `${Emojis.Certo} - ${message.author}, o comando já se encontrava na lista de comandos liberados, portanto eu o removi.` 159 | ) 160 | .then(async (x) => { 161 | await Guild.findOneAndUpdate( 162 | { _id: message.guild.id }, 163 | { $pull: { "cmdblock.enable": cmd } } 164 | ); 165 | }); 166 | } else { 167 | message.channel.send( 168 | `${Emojis.Certo} - ${message.author}, comando **\`${cmd}\`** adicionado à lista com sucesso.` 169 | ); 170 | await Guild.findOneAndUpdate( 171 | { _id: message.guild.id }, 172 | { $push: { "cmdblock.enable": cmd } } 173 | ); 174 | } 175 | } 176 | }); 177 | } 178 | }; 179 | -------------------------------------------------------------------------------- /src/commands/Staff/kick.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | Emojis = require("../../utils/Emojis"); 4 | 5 | const Guild = require("../../database/Schemas/Guild"); 6 | 7 | module.exports = class Kick extends ( 8 | Command 9 | ) { 10 | constructor(client) { 11 | super(client); 12 | this.client = client; 13 | 14 | this.name = "kick"; 15 | this.category = "Owner"; 16 | this.description = "Kickar usuários do seu servidor"; 17 | this.aliases = ["kickar"]; 18 | 19 | this.enabled = true; 20 | this.guildOnly = false; 21 | } 22 | async run(message, args, prefix) { 23 | if (!message.member.hasPermission("KICK_MEMBERS")) 24 | return message.channel.send( 25 | `${Emojis.Errado} - ${message.author}, você não tem permissão de executar este comando.` 26 | ); 27 | 28 | var membro = 29 | message.mentions.members.first() || 30 | message.guild.members.cache.get(args[0]); 31 | if (!membro) 32 | return message.channel.send( 33 | `${Emojis.Errado} - ${message.author}, formato correto de executar o comando: **\`${prefix}kick \`**.` 34 | ); 35 | if (membro === message.member) 36 | return message.channel.send( 37 | `${Emojis.Errado} - ${message.author}, você não pode se expulsar.` 38 | ); 39 | 40 | var motivo = !args[1] ? "Não informado" : args.slice(1).join(" "); 41 | 42 | const kick = new ClientEmbed(message.author).setDescription( 43 | `${Emojis.Certo} - ${message.author}, você dejesa expulsar o usuário: **${membro.user.username}** ?` 44 | ); 45 | 46 | message.channel.send(kick).then((msg) => { 47 | msg.react("✅"); 48 | 49 | let filtro = (reaction, usuario) => 50 | reaction.emoji.name === "✅" && usuario.id === message.author.id; 51 | let coletor = msg.createReactionCollector(filtro, { max: 1 }); 52 | 53 | kick.setAuthor( 54 | `Punição`, 55 | membro.user.displayAvatarURL({ dynamic: true, size: 4096 }) 56 | ); 57 | kick.setDescription(`${membro} foi expulso!`); 58 | kick.addField("Motivo", motivo); 59 | kick.addField("Duração", "Permanentemente", true); 60 | kick.addField("Aplicado por", message.author, true); 61 | 62 | coletor.on("collect", (cp) => { 63 | cp.remove(message.author.id); 64 | message.channel.bulkDelete(2); 65 | this.client.channels.cache.get(process.env.LOGS).send(kick); 66 | membro.kick(); 67 | }); 68 | }); 69 | } 70 | }; 71 | -------------------------------------------------------------------------------- /src/commands/Staff/ticket.js: -------------------------------------------------------------------------------- 1 | const Command = require("../../structure/Command"); 2 | ClientEmbed = require("../../structure/ClientEmbed"); 3 | Emojis = require("../../utils/Emojis"); 4 | 5 | module.exports = class Ticket extends ( 6 | Command 7 | ) { 8 | constructor(client) { 9 | super(client); 10 | this.client = client; 11 | 12 | this.name = "ticket"; 13 | this.category = "Owner"; 14 | this.description = "Envia a mensagem de ticket"; 15 | this.aliases = []; 16 | 17 | this.enabled = true; 18 | this.guildOnly = false; 19 | } 20 | async run(message, args, prefix) { 21 | if (!args[0]) { 22 | const embeds = new ClientEmbed(message.author) 23 | 24 | .setDescription("`Carregando sistema de tickets, em andamento!`") 25 | .setTimestamp(); 26 | 27 | message.channel.send(embeds); 28 | 29 | setTimeout(() => { 30 | const embed = new ClientEmbed(message.author) 31 | 32 | .setDescription( 33 | "`Sistema de tickets carregado, envio de mensagem em andamento!`" 34 | ) 35 | .setTimestamp(); 36 | 37 | message.channel.send(embed); 38 | 39 | setTimeout(() => { 40 | const embed = new ClientEmbed(message.author) 41 | 42 | .setTitle("Rede Specter - Ticket") 43 | .setDescription( 44 | `󠂪󠂪 󠂪󠂪 󠂪󠂪󠂪 󠂪󠂪 󠂪󠂪 45 | > Clique no emoji abaixo para ser redirecionado a criação de seu ticket. 46 | 󠂪󠂪 󠂪󠂪 󠂪󠂪󠂪 󠂪󠂪 󠂪󠂪` 47 | ) 48 | .setTimestamp(); 49 | 50 | this.client.channels.cache 51 | .get(process.env.CHANNEL_ID) 52 | .send(embed) 53 | .then(function (message) { 54 | message.react("✅"); 55 | }); 56 | 57 | const embede = new ClientEmbed(message.author) 58 | 59 | .setDescription("`Mensagem enviada com sucesso!`") 60 | .setTimestamp(); 61 | 62 | message.channel.send(embede); 63 | }, 5000); 64 | }, 6000); 65 | return; 66 | } 67 | 68 | if (["fechar", "close"].includes(args[0].toLowerCase())) { 69 | if (this.client.tickets.includes(message.channel.id)) { 70 | CloseTicket(message); 71 | } 72 | } 73 | } 74 | }; 75 | 76 | async function AwaitReact(message, author, time, validReactions) { 77 | time *= 1000; 78 | for (const reaction of validReactions) await message.react(reaction); 79 | const filter = (reaction, user) => 80 | validReactions.includes(reaction.emoji.name) && user.id === author.id; 81 | return message 82 | .awaitReactions(filter, { max: 1, time: time }) 83 | .then((collected) => collected.first() && collected.first().emoji.name); 84 | } 85 | 86 | async function CloseTicket(message) { 87 | const chooseArr = ["✅", "❎"]; 88 | 89 | const embed = new ClientEmbed(message.author) 90 | 91 | .setDescription("`Você quer fechar o ticket ?`") 92 | .setTimestamp(); 93 | 94 | const m = await message.channel.send(embed); 95 | const reacted = await AwaitReact(m, message.author, 10, chooseArr); 96 | const result = await getResult(reacted); 97 | 98 | message.channel.send(result); 99 | m.reactions.removeAll(); 100 | 101 | function getResult(me) { 102 | if (me === "❎") { 103 | const embed = new ClientEmbed(message.author) 104 | 105 | .setDescription("`Ação cancelada`") 106 | .setTimestamp(); 107 | 108 | return embed; 109 | } else if (me === "✅") { 110 | const embed = new ClientEmbed(message.author) 111 | 112 | .setDescription("`O ticket fechará em 5 segundos`") 113 | .setTimestamp(); 114 | 115 | message.channel.setName("ticket-fechado"); 116 | 117 | setTimeout(() => { 118 | message.channel.delete(); 119 | }, 5000); 120 | return embed; 121 | } 122 | } 123 | } 124 | -------------------------------------------------------------------------------- /src/database/Schemas/Client.js: -------------------------------------------------------------------------------- 1 | const mongoose = require("mongoose"); 2 | const Schema = mongoose.Schema; 3 | 4 | let clientSchema = new Schema({ 5 | _id: { type: String, required: true }, 6 | Staff: { type: Array, default: [] }, 7 | }); 8 | 9 | let Client = mongoose.model("Clients", clientSchema); 10 | module.exports = Client; 11 | -------------------------------------------------------------------------------- /src/database/Schemas/Guild.js: -------------------------------------------------------------------------------- 1 | const mongoose = require("mongoose"); 2 | const Schema = mongoose.Schema; 3 | 4 | let guildSchema = new Schema({ 5 | _id: { type: String, required: true }, 6 | cmdblock: { 7 | channels: { type: Array, default: [] }, 8 | enable: { type: Array, default: [] }, 9 | status: { type: Boolean, default: false }, 10 | }, 11 | }); 12 | 13 | let Guild = mongoose.model("Guilds", guildSchema); 14 | module.exports = Guild; 15 | -------------------------------------------------------------------------------- /src/database/Schemas/User.js: -------------------------------------------------------------------------------- 1 | const mongoose = require("mongoose"); 2 | const Schema = mongoose.Schema; 3 | 4 | let userSchema = new Schema({ 5 | _id: { type: String }, 6 | // ------------------> Economy <----------------------- 7 | coins: { type: Number, default: 0 }, 8 | daily: { type: String }, 9 | bank: { type: Number, default: 0 }, 10 | // ------------------> Steal <----------------------- 11 | steal: { type: String }, 12 | // ------------------> Work <----------------------- 13 | work: { 14 | name: { type: String, default: "Não definido" }, 15 | register: { type: Boolean, default: false }, 16 | exp: { type: Number, default: 0 }, 17 | level: { type: Number, default: 1 }, 18 | nextLevel: { type: Number, default: 150 }, 19 | cooldown: { type: Number, default: 0 }, 20 | total: { type: Number, default: 0 }, 21 | works: { 22 | Lixeiro: { 23 | name: { type: String, default: "Lixeiro" }, 24 | level: { type: Number, default: 1 }, 25 | coins: { type: Number, default: 100 }, 26 | active: { type: Boolean, default: false }, 27 | }, 28 | Empacotador: { 29 | name: { type: String, default: "Empacotador" }, 30 | level: { type: Number, default: 10 }, 31 | coins: { type: Number, default: 200 }, 32 | active: { type: Boolean, default: false }, 33 | }, 34 | iFood: { 35 | name: { type: String, default: "iFood" }, 36 | level: { type: Number, default: 20 }, 37 | coins: { type: Number, default: 300 }, 38 | active: { type: Boolean, default: false }, 39 | }, 40 | Administracao: { 41 | name: { type: String, default: "Administração" }, 42 | level: { type: Number, default: 30 }, 43 | coins: { type: Number, default: 400 }, 44 | active: { type: Boolean, default: false }, 45 | }, 46 | Policial: { 47 | name: { type: String, default: "Policial" }, 48 | level: { type: Number, default: 40 }, 49 | coins: { type: Number, default: 500 }, 50 | active: { type: Boolean, default: false }, 51 | }, 52 | Advogado: { 53 | name: { type: String, default: "Advogado" }, 54 | level: { type: Number, default: 50 }, 55 | coins: { type: Number, default: 1000 }, 56 | active: { type: Boolean, default: false }, 57 | }, 58 | Engenheiro: { 59 | name: { type: String, default: "Engenheiro" }, 60 | level: { type: Number, default: 60 }, 61 | coins: { type: Number, default: 1500 }, 62 | active: { type: Boolean, default: false }, 63 | }, 64 | Progamador: { 65 | name: { type: String, default: "Progamador" }, 66 | level: { type: Number, default: 70 }, 67 | coins: { type: Number, default: 2000 }, 68 | active: { type: Boolean, default: false }, 69 | }, 70 | Medico: { 71 | name: { type: String, default: "Médico" }, 72 | level: { type: Number, default: 80 }, 73 | coins: { type: Number, default: 2500 }, 74 | active: { type: Boolean, default: false }, 75 | }, 76 | }, 77 | }, 78 | }); 79 | 80 | const User = mongoose.model("Users", userSchema); 81 | module.exports = User; 82 | -------------------------------------------------------------------------------- /src/database/index.js: -------------------------------------------------------------------------------- 1 | const mongoose = require("mongoose"); 2 | 3 | module.exports = { 4 | start() { 5 | try { 6 | mongoose.connect(process.env.MONGODB_URI, { 7 | useNewUrlParser: true, 8 | useUnifiedTopology: true, 9 | useFindAndModify: false, 10 | }); 11 | 12 | console.log(`(DATABASE) - Conectado com Sucesso ao Banco de Dados.`); 13 | } catch (err) { 14 | if (err) return console.log(`(DATABASE) - ERROR: ${err}`); 15 | } 16 | }, 17 | }; 18 | -------------------------------------------------------------------------------- /src/index.js: -------------------------------------------------------------------------------- 1 | const { Client, Collection } = require("discord.js"); 2 | const klaw = require("klaw"); 3 | const path = require("path"); 4 | const { promisify } = require("util"); 5 | const readdir = promisify(require("fs").readdir); 6 | 7 | class Main extends Client { 8 | constructor(options) { 9 | super(options); 10 | this.commands = new Collection(); 11 | this.aliases = new Collection(); 12 | this.tickets = new Array(); 13 | } 14 | 15 | login(token) { 16 | token = process.env.TOKEN; 17 | return super.login(token); 18 | } 19 | 20 | load(commandPath, commandName) { 21 | const props = new (require(`${commandPath}/${commandName}`))(this); 22 | props.location = commandPath; 23 | if (props.init) { 24 | props.init(this); 25 | } 26 | this.commands.set(props.name, props); 27 | props.aliases.forEach((aliases) => { 28 | this.aliases.set(aliases, props.name); 29 | }); 30 | return false; 31 | } 32 | } 33 | 34 | const dbIndex = require("./database/index"); 35 | dbIndex.start(); 36 | const client = new Main(); 37 | 38 | const onLoad = async () => { 39 | klaw("src/commands").on("data", (item) => { 40 | const cmdFile = path.parse(item.path); 41 | if (!cmdFile.ext || cmdFile.ext !== ".js") return; 42 | const response = client.load(cmdFile.dir, `${cmdFile.name}${cmdFile.ext}`); 43 | if (response) return; 44 | }); 45 | 46 | const evtFiles = await readdir("./src/client/listeningIn/"); 47 | evtFiles.forEach((file) => { 48 | const eventName = file.split(".")[0]; 49 | const event = new (require(`./client/listeningIn/${file}`))(client); 50 | client.on(eventName, (...args) => event.run(...args)); 51 | delete require.cache[require.resolve(`./client/listeningIn/${file}`)]; 52 | }); 53 | 54 | client.login(); 55 | }; 56 | onLoad(); 57 | 58 | module.exports = { 59 | Util: require("./utils/index.js"), 60 | }; 61 | -------------------------------------------------------------------------------- /src/structure/ClientEmbed.js: -------------------------------------------------------------------------------- 1 | const Discord = require("discord.js"); 2 | 3 | module.exports = class ClientEmbed extends ( 4 | Discord.MessageEmbed 5 | ) { 6 | constructor(user, data = {}) { 7 | super(data); 8 | this.setFooter( 9 | "Executado por " + user.tag, 10 | user.displayAvatarURL({ dynamic: true }) 11 | ); 12 | this.setColor(process.env.EMBED_COLOR); 13 | this.setTimestamp(); 14 | } 15 | }; 16 | -------------------------------------------------------------------------------- /src/structure/Command.js: -------------------------------------------------------------------------------- 1 | module.exports = class Command { 2 | constructor(client) { 3 | this.client = client; 4 | 5 | this.name = "Nome"; 6 | this.category = "Categoria"; 7 | this.description = "Sem Descrição"; 8 | this.usage = "Sem Informação"; 9 | this.aliases = []; 10 | 11 | this.enabled = true; 12 | this.guildOnly = false; 13 | } 14 | 15 | async run() {} 16 | }; 17 | -------------------------------------------------------------------------------- /src/utils/Emojis.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | Robo: "🤖", 3 | Certo: "✅", 4 | Errado: "❌", 5 | Owner: "👑", 6 | Desc: "📰", 7 | Aliases: "🌀", 8 | Comando: "🔨", 9 | Uso: "⚙️", 10 | User: "👤", 11 | Information: "📝", 12 | Economy: "💰", 13 | Bank: "🏦", 14 | Cooldown: "⏳", 15 | Coins: "💵", 16 | Medal: "🏅", 17 | First: "🥇", 18 | Second: "🥈", 19 | Third: "🥉", 20 | Rank: "🎖️", 21 | Police: "👮", 22 | Gun: "🔫", 23 | Online: "<:online:687577164702679068>", 24 | Ocupado: "<:dnd:687577184092946467>", 25 | Ausente: "<:idle:687577177943965696>", 26 | Offline: "<:offline:687577171182616596>", 27 | Status: "🔖", 28 | Date: "📅", 29 | Early: "<:early:782734021217878076>", 30 | Brilliance: "<:brilliance:782733731516907540>", 31 | Bravery: "<:bravery:782733948588916758>", 32 | Balance: "<:balance:782733984206946304>", 33 | Developer: "<:developer:782733790426300456>", 34 | BotVerificado: "<:botverificado:782739117360021544>", 35 | Misc: "🪢", 36 | Sugestion: "📋", 37 | Find: "🔎", 38 | JavaScript: "<:javascript:805169211911307304>", 39 | Zero: "0️⃣", 40 | One: "1️⃣", 41 | Two: "2️⃣", 42 | Three: "3️⃣", 43 | Four: "4️⃣", 44 | Five: "5️⃣", 45 | Six: "6️⃣", 46 | Seven: "7️⃣", 47 | Eight: "8️⃣", 48 | Nine: "9️⃣", 49 | Back: "◀️", 50 | 51 | reactions: { 52 | yes: "👍🏻", 53 | no: "👎🏻", 54 | }, 55 | }; 56 | -------------------------------------------------------------------------------- /src/utils/Plugins.js: -------------------------------------------------------------------------------- 1 | const data = { 2 | abbrev: require("../utils/plugins/abbrev"), 3 | renderEmoji: require("../utils/plugins/renderEmoji.js"), 4 | }; 5 | 6 | module.exports = data; 7 | -------------------------------------------------------------------------------- /src/utils/Util.js: -------------------------------------------------------------------------------- 1 | const abbrev = require("./plugins/abbrev.js"), 2 | renderEmoji = require("./plugins/renderEmoji.js"); 3 | 4 | module.exports = class Util { 5 | static toAbbrev(num) { 6 | return abbrev(num); 7 | } 8 | 9 | static renderEmoji(ctx, msg, x, y) { 10 | return renderEmoji(ctx, msg, x, y); 11 | } 12 | }; 13 | -------------------------------------------------------------------------------- /src/utils/bdd.json: -------------------------------------------------------------------------------- 1 | { 2 | "ChannelSet": false, 3 | "Status": true, 4 | "NumberTicket": 0, 5 | "NumbersTicket": "000" 6 | } 7 | -------------------------------------------------------------------------------- /src/utils/index.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | Util: require("../utils/Util.js"), 3 | }; 4 | -------------------------------------------------------------------------------- /src/utils/plugins/abbrev.js: -------------------------------------------------------------------------------- 1 | module.exports = (num) => { 2 | if (!num || isNaN(num)) return "0"; 3 | if (typeof num === "string") num = parseInt(num); 4 | let decPlaces = Math.pow(10, 1); 5 | var abbrev = ["K", "M", "B", "T"]; 6 | for (var i = abbrev.length - 1; i >= 0; i--) { 7 | var size = Math.pow(10, (i + 1) * 3); 8 | if (size <= num) { 9 | num = Math.round((num * decPlaces) / size) / decPlaces; 10 | if (num == 1000 && i < abbrev.length - 1) { 11 | num = 1; 12 | i++; 13 | } 14 | num += abbrev[i]; 15 | break; 16 | } 17 | } 18 | return num; 19 | }; 20 | -------------------------------------------------------------------------------- /src/utils/plugins/renderEmoji.js: -------------------------------------------------------------------------------- 1 | const emoji = require("node-canvas-with-twemoji-and-discord-emoji"); 2 | 3 | module.exports = async (ctx, message, x, y) => { 4 | return await emoji.fillTextWithTwemoji(ctx, message, x, y); 5 | }; 6 | --------------------------------------------------------------------------------