UNPKG

dbmmods

Version:

A free open source modification collection for Discord Bot Maker.

154 lines (129 loc) 5.71 kB
module.exports = { //--------------------------------------------------------------------- // Action Name // // This is the name of the action displayed in the editor. //--------------------------------------------------------------------- name: "Delete File", //--------------------------------------------------------------------- // Action Section // // This is the section the action will fall into. //--------------------------------------------------------------------- section: "Other Stuff", //--------------------------------------------------------------------- // Action Subtitle // // This function generates the subtitle displayed next to the name. //--------------------------------------------------------------------- subtitle: function(data) { return `Delete [${data.filePath}]`; }, //--------------------------------------------------------------------- // DBM Mods Manager Variables (Optional but nice to have!) // // These are variables that DBM Mods Manager uses to show information // about the mods for people to see in the list. //--------------------------------------------------------------------- // Who made the mod (If not set, defaults to "DBM Mods") author: "EGGSY", // The version of the mod (Defaults to 1.0.0) version: "1.8.6", // A short description to show on the mod line for this mod (Must be on a single line) short_description: "Deletes files -_-", // If it depends on any other mods by name, ex: WrexMODS if the mod uses something from WrexMods //--------------------------------------------------------------------- //--------------------------------------------------------------------- // Action Fields // // These are the fields for the action. These fields are customized // by creating elements with corresponding IDs in the HTML. These // are also the names of the fields stored in the action's JSON data. //--------------------------------------------------------------------- fields: ["filePath"], //--------------------------------------------------------------------- // Command HTML // // This function returns a string containing the HTML used for // editting actions. // // The "isEvent" parameter will be true if this action is being used // for an event. Due to their nature, events lack certain information, // so edit the HTML to reflect this. // // The "data" parameter stores constants for select elements to use. // Each is an array: index 0 for commands, index 1 for events. // The names are: sendTargets, members, roles, channels, // messages, servers, variables //--------------------------------------------------------------------- html: function(isEvent, data) { return ` <div> <p> <u>Mod Info:</u><br> Made by EGGSY<br> </p><br> <div style="float: left; width: 99%"> File Path:<br> <textarea id="filePath" class="round" style="width 99%; resize: none;" type="textarea" rows="2" cols="60"></textarea><br> </div><br> <p> If you want to delete something in current directory, you can add '.' (dot) before '/':<br> e.g:<br> My bot directory is: "<b>/root/myBot/</b>"<br> I want to delete: "<b>/root/myBot/delete.txt</b>"<br> Then I need to write "<b>./delete.txt</b>" in the field.<br><br> <i>Please be careful while using this mod. Don't forget there is no turning back after deleting the file.</i><br> </p><br> </div>` }, //--------------------------------------------------------------------- // Action Editor Init Code // // When the HTML is first applied to the action editor, this code // is also run. This helps add modifications or setup reactionary // functions for the DOM elements. //--------------------------------------------------------------------- init: function() {}, //--------------------------------------------------------------------- // Action Bot Function // // This is the function for the action within the Bot's Action class. // Keep in mind event calls won't have access to the "msg" parameter, // so be sure to provide checks for variable existance. //--------------------------------------------------------------------- action: function (cache) { const data = cache.actions[cache.index]; try { const fs = require('fs'); const filePath = this.evalMessage(data.filePath, cache); if (filePath) { fs.exists(`${filePath}`, function(exists) { if(exists) { fs.unlink(`${filePath}`, (err) => { if (err) return console.log(`Something went wrong while deleting: [${err}]`); console.log(`Sucessfully deleted [${filePath}].`); }); } else { console.log('File not found, nothing to delete.'); } }); } else { console.log(`File path is missing.`); } } catch (err) { console.log("ERROR!" + err.stack ? err.stack : err); } this.callNextAction(cache); }, //--------------------------------------------------------------------- // Action Bot Mod // // Upon initialization of the bot, this code is run. Using the bot's // DBM namespace, one can add/modify existing functions if necessary. // In order to reduce conflictions between mods, be sure to alias // functions you wish to overwrite. //--------------------------------------------------------------------- mod: function(DBM) { } }; // End of module