| Commit message (Collapse) | Author | Lines |
|
Return a dormant channel to turn into an available channel, waiting
indefinitely until one becomes available in the queue.
|
|
Create and return a new channel in the Dormant category or return
None if no names remain. The overwrites get synced with the category if
none are explicitly specified for the channel.
|
|
A design change was made to account for a channel being empty i.e. no
messages ever sent. In such case, the function will return None.
* Move a channel to the Dormant category if the channel has no messages
|
|
This function will get re-used in _scheduled_task, but it will only
need to move a single channel. Therefore, to promote code re-use, this
change was made. The init_cog will instead do a loop to call this on
all channels in the in-use category.
|
|
* Remove await from create_channel_queue
* Call the correct function to create the name queue
|
|
Make all in-use channels dormant if idle or schedule the move if still
active. This is intended to clean up the in-use channels when the bot
restarts and has lost the tasks it had scheduled in another life.
|
|
|
|
Initialises the Available category with channels if any are missing.
|
|
|
|
It returns a queue of dormant channels in random order. The queue will
be used to get the next available channel.
Using a random order is simpler than trying to sort by the timestamp
of the most recent message in each channel and this decision will only
"negatively" impact the system when the bot restarts or the extension
is reloaded. Ultimately, it just means in such events some dormant
channels may chosen to become active again sooner than expected.
|
|
|
|
The channels property of categories sorts the channels before returning
them.
* Add a generator function to get category channels
|
|
It returns a queue of element names to use for creating new channels,
taking into account which names are already being used.
|
|
|
|
|
|
This will prevent initialisation from proceeding when the category
channels fail to be retrieved.
|
|
It's created as a task in __init__ because coroutines cannot be awaited
in there.
|
|
As the categories are essential for the functionality of the cog, if
this function fails to get a category, it will remove/unload the cog.
|
|
|
|
|
|
|
|
The original category was re-purposed as the "in-use" category so that
deployment of the new system will not interrupt ongoing help sessions.
|
|
|
|
|
|
|