aboutsummaryrefslogtreecommitdiffstats
path: root/bot/utils (follow)
Commit message (Collapse)AuthorAgeLines
* Deseasonify: move current month resolver to utilsGravatar kwzrd2020-03-30-18/+19
| | | | | The function is useful to other modules as well - not only decorators. This declares it as public and moves it to a more accessible place.
* Deseasonify: add helper func to resolve current monthGravatar kwzrd2020-03-29-3/+17
| | | | See docstring for details.
* Deseasonify: rename utility functionGravatar kwzrd2020-03-28-2/+2
| | | | | To avoid confusion, the packages should no longer be referred to as 'seasons'.
* Deseasonify: rename `seasons` pkg to `exts`Gravatar kwzrd2020-03-28-1/+1
| | | | | | | | | It is believed that this is now a more logical name for the package, as extensions no longer bind to seasons. Internally, packages are still grouped into seasonal sub-packages. There are quite a few, and it makes sense to group them by a common theme that inspired their functionality.
* Deseasonify: move decorators module under utilsGravatar kwzrd2020-03-28-0/+321
|
* Deseasonify: move pagination module under utilsGravatar kwzrd2020-03-26-1/+431
|
* Deseasonify: move exceptions module under utilsGravatar kwzrd2020-03-26-0/+4
|
* Deseasonify: improve `get_seasons` convenience functionGravatar kwzrd2020-03-21-2/+2
|
* Deseasonify: move `get_seasons` util function to package initGravatar kwzrd2020-03-07-1/+1
|
* Add context manager to safely unlock role mentionabilityGravatar Sebastiaan Zeeff2019-12-04-0/+23
| | | | | | | | | | | | | | | | | | | | Currently, our regualar roles are not mentionable by default. This means that features that rely on roles to keep track of users that want to receive announcements, like the AoC Day Countdown, don't actually ping the users subscribed to it. The solution is obviously that the bot should unlock prior to making the announcement. However, this is complicated by the fact that there needs to be a sufficient delay. both between unlocking and sending the message and between sending the message and locking the role again. If not, Discord's not done synchronizing across all servers and some users won't receive a ping. To make this easier, I have implemented a context manager that takes an instance of `discord.Role` and an optional `delay` (default: 5s) that yields a context in which the role is unlocked. This context manager also makes sure that the role is locked even if an exception occured within the unlocked context.
* Use mkdir exists kwarg instead of checking existing ahead of time.Gravatar scragly2019-09-23-4/+2
|
* Improve func name, example, directory managementGravatar scragly2019-09-23-9/+37
| | | | | | | | | | | | | | | | | | | | Function name has been changed to `make_persistent` after prompt by @lemonsaurus asking for a more descriptive name. Thanks @MarkKoz for providing the alternate name. During local testing, the `data` directory doesn't exist yet. In prod, this isn't an issue as the persistent volume is mounted at that location. To make local testing more convenient, the directory is checked and made if not found. Persistent data files will be placed in a seasonal subdirectory so long as they have a valid season name somewhere in their path, otherwise they will be placed directly in the data directory. Added a note to docstring to avoid same-named files in the same seasons or it will conflict with each other in the persistent data directory. The example was extended a little bit to make it both actually valid if tested and hopefully make it easier to understand what's going on.
* Check explicitly if file exists rather than any existing path.Gravatar scragly2019-09-23-1/+1
| | | Co-Authored-By: Mark <[email protected]>
* Add better explanatory docstring and example for persist.datafile.Gravatar scragly2019-09-20-1/+17
|
* Add persistent datafile utils.Gravatar scragly2019-09-19-0/+24
|
* Fix incorrect merge conflict resolutions, lint remaining itemsGravatar S. Co12019-09-11-1/+1
|
* Lint remaining filesGravatar S. Co12019-09-09-6/+6
| | | hacktoberstats cog handled in separate PR
* Merge pull request #260 from kosayoda/text-modifyGravatar Mark2019-09-03-0/+56
|\ | | | | Modify text :-)
| * Add utils function to replace multiple words in a given stringGravatar kosayoda2019-08-18-0/+56
| |
* | Replace paramater and return value docstring documentation with an extended ↵Gravatar kosayoda2019-08-19-11/+5
|/ | | | summary
* Relint Seasonalbot with new linting rulesGravatar sco12019-04-24-4/+0
|
* Docstring pass for Halloween cogsGravatar sco12019-03-19-5/+12
|
* Formating and linter fixesGravatar Christopher Goes2019-03-05-2/+1
|
* Initial move of Snakes cog from the bot to seasonalbotGravatar Chris Goes2019-03-04-0/+80
|
* Allows you to create Seasons. (#64)Gravatar Leon Sandøy2018-11-27-0/+0
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Allows you to create Season objects which change the bots behavior. For example, a season can determine things like the avatar, the nickname, and which cogs are loaded. Season automatically changes according to the date range you specify when you create it. * removing some hungarian notation. * Automatic season changes will now always happen at a minute past midnight, no matter when the bot started. * catching dunders in the glob. * Refine Season Creation behaviour and structure. * Added channel and role constants, refactored roles into NamedTuples, added role check decorators from the main bot, and added role checks for the season change feature. Yes this is duplicate code from our main bot, but it will just have to be like that for now until we get a bot core running. * replacing the or with an xor and switching out the assert for a UserWarning * New lockfile * changing discord.py to discord-py to prevent pip bug from putting two of them in our lockfile * fixing flake errors * flake8 * Cleaned everything up, but I seem to have introduced some sort of infinite load loop? o.O * Fixing up all bugs in the halloween cogs. This should be ready for merge now. * Add avatar_path baseclass method for consistency. While making it simpler to add avatar urls in new season extensions, it also allows the avatar resource path to be changed in a single place if needed in future. * Avoid shadowing builtin `object`. * Add debug mode, refine bot user editing on season load. The changing of a bot's username and avatar is heavily ratelimited. While testing, restarting the bot and changing seasons is required, and hitting these limits are typical. Instead, when in debug mode, the avatar isn't set and only the nickname is changed to prevent unnecessary account edit requests. In the case that the rate limit is hit when not in debug mode, there's an added fallback to use the nickname instead. * Add cancel load_seasons task on SeasonManager un/reload. Previously the load_seasons task was loaded and looping forever. Even if the cog was unloaded for some reason, it would still be running. On loading the SeasonManager again, it would create a new load_seasons task, while the old one still existed. Adding the cancellation allows the task to end when the cog is unloaded or reloaded, and will help assist with live code changes during development at a later time where it's possible to reload this extension (perhaps when the pending bot core is implemented). * get_season_class helper, season class attribs, fix admin id Changes `get_season`'s date check to not initialise unwanted classes (to avoid needless loading of tasks which would otherwise cause unexpected behaviour). To do this, defining attributes of season classes have been moved from `__init__` as an instance variable, to the class variable level. This also results in `__init__` not needing to be defined for the `SeasonBase` class, and `super().__init__()` not needing to be called in individual season classes, making things cleaner/simpler for them. Adds a helper function for retrieving a season class and combines two unnecessarily separate if statements. Credits to @MarkKoz for the suggestions. Reverts the admin ID mistakenly changed in a previous commit. * Update bot/seasons/halloween/hacktoberstats.py Co-Authored-By: heavysaturn <[email protected]> * Update bot/seasons/halloween/halloween_facts.py Co-Authored-By: heavysaturn <[email protected]> * No more property in halloweenfacts * Changed all aliases to tuples * Made tokens a seperate namedtuple * Update bot/seasons/halloween/spookyavatar.py Co-Authored-By: heavysaturn <[email protected]>
* Cleaning up bats a bitGravatar Leon Sandøy2018-11-20-5/+7
|
* Solved merge conflictsGravatar Leon Sandøy2018-11-20-0/+53