Contributions are very welcome for bug fixes particularly but also features that make sense to the project. Any existing issues labeled "help wanted" and "good first issue" are free to be pursued. And don't hesitate to open new issues.
Before opening a pull request, please first run make check
to make sure the environment, style, and commands are valid, especially the one you're making.
We also have a Slacker Slack workspace if you have any questions.
We follow PEP8 as the general style guide with a few extra items:
- 2 spaces instead of a tab character
- Double quotes around strings and single quotes for substrings:
"Hello 'world'!"
The following guidelines are ignored and not checked for:
- E111 indentation is not a multiple of four
- E114 indentation is not a multiple of four (comment)
- E121 continuation line under-indented for hanging indent
- E126 continuation line over-indented for hanging indent
- E302 expected 2 blank lines
Commands reside in slacker.commands
under the their category, like "files/" or "chat/". "general/" is reserved for commands that aren't related to Slack API methods directly.
When adding a new command, follow these steps:
- Implement
"slacker/commands/CATEGORY/name_command.py"
- In
"slacker/commands/__init__.py"
, import the new command, likefrom .CATEGORY import name_command
, and add its name to__all__
- Add to vulture whitelist in
".vulture_whitelist.py"
, likewl.NewCommand
, to not give false positives in static analysis
Notes and requirements:
- The file name of the command must follow the name of the API method, like
files.list
->files_list_command.py
- The command name must match
"([\w\d][\w\d\.]*)?[\w\d]+"
, which means it can be letters and digits with periods in between but not at the ends slacker.commands.argument_parser.ArgumentParser
is required when needing command arguments so that the argument names and meta can be used in the REPL for auto-completion- If
Command.requires_token
isn't overridden, it will default toFalse
and the active workspace token isn't included when using Slack API methods in the command withCommand.slack_api_post
orCommand.slack_api_download_file
, for instance - If
Command.is_destructive
isn't overridden, it will default toTrue
and the command will not be run if read-only mode is active