Name | pystodon JSON |
Version |
0.1.0
JSON |
| download |
home_page | None |
Summary | None |
upload_time | 2024-06-06 00:34:22 |
maintainer | None |
docs_url | None |
author | slashtechno |
requires_python | <4.0,>=3.11 |
license | None |
keywords |
|
VCS |
|
bugtrack_url |
|
requirements |
No requirements were recorded.
|
Travis-CI |
No Travis.
|
coveralls test coverage |
No coveralls.
|
# Pystodon
<!-- Someone on the Python Discord (with the username briskettaco at the time) pitched the name since I was looking to move away from the name "rathercurious-mastodon" for this project. -->
A hybrid between a framework for building Mastodon bots and a standalone bot. You can see this bot in action on [Mastodon](https://botsin.space/@rathercurious) (not always running).
## Usage
### Prerequisites
- A Mastodon account
- Preferably a bot account, but a normal account will work as well
- A Mastodon application
1. Log into your Mastodon account on the respective instance's web interface
2. Navigate to Preferences > Development > Your applications
3. Click "New application"
4. Set an application name (e.g. "Rather Curious Bot")
5. For basic usage, allow the application to read and write to your account
- You can also try specifying more granular permissions but this is not tested (yet)
6. Click "Submit"
7. Make sure you are in the respective application's details page
8. Copy "Your access token"
- This is your bot's access token
- You will need this later
- Do not share this token as it allows access to your account
### Basic Configuration
- Configuration is handled through environment variables, a `.env` file, or command-line arguments (`--help` for more information)
- To see an example configuration, see `.env.example`
- This can be copied to `.env` and edited to suit your needs
### Poetry
#### Specific Prerequisites
- Python (3.11+)
- [pyenv](https://github.com/pyenv/pyenv) assists with installing and managing multiple versions of Python and may be helpful if you have an incompatible version of Python installed
- If on Windows, [pyenv-win](https://github.com/pyenv-win/pyenv-win) is recommended
- Poetry
- [Poetry](https://python-poetry.org/docs/#installation) is a package manager for Python that manages dependencies and virtual environments
#### Installation
1. Clone the repository
- `git clone https://github.com/slashtechno/pystodon`
2. Change directory into the repository
- `cd pystodon`
3. Install dependencies
- `poetry install`
#### Running
1. Confirm the bot has been configured correctly
2. `poetry run python -m pystodon`
### Docker
Recommended, especially if you want to use commands that depend on a database (e.g. `#remindme`)
#### Specific Prerequisites
- Docker
- [Docker](https://docs.docker.com/get-docker/) is a platform for developing, shipping, and running applications in containers
- Docker Compose
- [Docker Compose](https://docs.docker.com/compose/install/) is a tool for defining and running multi-container Docker applications
#### Running
1. Clone the repository
- `git clone https://github.com/slashtechno/pystodon`
2. Change directory into the repository
- `cd pystodon`
3. Confirm the bot has been configured correctly
4. `docker-compose up -d`
- The `-d` flag runs the containers in the background
#### Specific Prerequisites
- Python (3.11+)
- See the Poetry section for more information
### PyPi
Not recommended as you can't modify the commands
#### Requirements
- Python (3.11+)
- Read the Poetry section for more information
#### Installation
1. `pip install pystodon`
- You may need to use `pip3` instead of `pip` depending on your system
- In addition, you may want to try `python -m pip install pystodon` or `python3 -m pip install pystodon` if the above commands do not work
#### Running
- Assuming programs installed by `pip` are in your PATH, you can run the bot with `pystodon`
### Usage
- By default, the bot will use the commands configured in `pystodon/commands.py`
- Commands include `#remindme`, `#timezone`, `#weather`, and `/test`
- The command `help` (note the lack of a prefix) will list all available commands and can be used to get more information on a specific command
- These commands can be modified, removed, or added to suit your needs
- Look in `pystodon/__main__.py` to see how commands are added
- When running with Docker, run `docker compose --build` to rebuild the image with the new commands
- The syntax for commands is `@bot_username@example.com command [arguments]`
- For example, `@rathercurious #remindme in 1h30m`
- The bot will match the visibility of the command to the visibility of the message it is replying to
- If the message is public, the bot will reply with a public message
- If the message is unlisted, the bot will reply with an unlisted message
- If the message is direct, the bot will reply with a direct message
- It's recommended to set `RC_ALWAYS_MENTION` to `True` in the `.env` (or use `--always-mention`) to ensure the user is mentioned in the reply
Raw data
{
"_id": null,
"home_page": null,
"name": "pystodon",
"maintainer": null,
"docs_url": null,
"requires_python": "<4.0,>=3.11",
"maintainer_email": null,
"keywords": null,
"author": "slashtechno",
"author_email": "77907286+slashtechno@users.noreply.github.com",
"download_url": "https://files.pythonhosted.org/packages/0b/f9/cbce7438ad55f4635e369818f0e6e77a18cd9ba535541053592c2ac449e4/pystodon-0.1.0.tar.gz",
"platform": null,
"description": "# Pystodon \n<!-- Someone on the Python Discord (with the username briskettaco at the time) pitched the name since I was looking to move away from the name \"rathercurious-mastodon\" for this project. -->\nA hybrid between a framework for building Mastodon bots and a standalone bot. You can see this bot in action on [Mastodon](https://botsin.space/@rathercurious) (not always running).\n\n## Usage \n### Prerequisites \n- A Mastodon account \n - Preferably a bot account, but a normal account will work as well \n- A Mastodon application \n 1. Log into your Mastodon account on the respective instance's web interface \n 2. Navigate to Preferences > Development > Your applications \n 3. Click \"New application\" \n 4. Set an application name (e.g. \"Rather Curious Bot\") \n 5. For basic usage, allow the application to read and write to your account \n - You can also try specifying more granular permissions but this is not tested (yet) \n 6. Click \"Submit\" \n 7. Make sure you are in the respective application's details page \n 8. Copy \"Your access token\" \n - This is your bot's access token \n - You will need this later \n - Do not share this token as it allows access to your account \n\n### Basic Configuration \n- Configuration is handled through environment variables, a `.env` file, or command-line arguments (`--help` for more information) \n- To see an example configuration, see `.env.example` \n- This can be copied to `.env` and edited to suit your needs \n\n\n### Poetry \n#### Specific Prerequisites \n- Python (3.11+)\n - [pyenv](https://github.com/pyenv/pyenv) assists with installing and managing multiple versions of Python and may be helpful if you have an incompatible version of Python installed \n - If on Windows, [pyenv-win](https://github.com/pyenv-win/pyenv-win) is recommended\n- Poetry \n - [Poetry](https://python-poetry.org/docs/#installation) is a package manager for Python that manages dependencies and virtual environments \n#### Installation\n1. Clone the repository \n - `git clone https://github.com/slashtechno/pystodon` \n2. Change directory into the repository \n - `cd pystodon` \n3. Install dependencies \n - `poetry install` \n#### Running \n1. Confirm the bot has been configured correctly \n2. `poetry run python -m pystodon` \n\n### Docker \nRecommended, especially if you want to use commands that depend on a database (e.g. `#remindme`) \n#### Specific Prerequisites\n- Docker \n - [Docker](https://docs.docker.com/get-docker/) is a platform for developing, shipping, and running applications in containers \n- Docker Compose \n - [Docker Compose](https://docs.docker.com/compose/install/) is a tool for defining and running multi-container Docker applications \n#### Running \n1. Clone the repository \n - `git clone https://github.com/slashtechno/pystodon`\n2. Change directory into the repository\n - `cd pystodon`\n3. Confirm the bot has been configured correctly \n4. `docker-compose up -d` \n - The `-d` flag runs the containers in the background \n#### Specific Prerequisites\n- Python (3.11+)\n - See the Poetry section for more information \n\n### PyPi\nNot recommended as you can't modify the commands \n#### Requirements\n- Python (3.11+)\n - Read the Poetry section for more information\n#### Installation\n1. `pip install pystodon`\n - You may need to use `pip3` instead of `pip` depending on your system\n - In addition, you may want to try `python -m pip install pystodon` or `python3 -m pip install pystodon` if the above commands do not work \n#### Running \n- Assuming programs installed by `pip` are in your PATH, you can run the bot with `pystodon` \n\n\n### Usage \n- By default, the bot will use the commands configured in `pystodon/commands.py`\n - Commands include `#remindme`, `#timezone`, `#weather`, and `/test`\n - The command `help` (note the lack of a prefix) will list all available commands and can be used to get more information on a specific command \n - These commands can be modified, removed, or added to suit your needs\n - Look in `pystodon/__main__.py` to see how commands are added \n - When running with Docker, run `docker compose --build` to rebuild the image with the new commands\n- The syntax for commands is `@bot_username@example.com command [arguments]`\n - For example, `@rathercurious #remindme in 1h30m` \n - The bot will match the visibility of the command to the visibility of the message it is replying to\n - If the message is public, the bot will reply with a public message \n - If the message is unlisted, the bot will reply with an unlisted message \n - If the message is direct, the bot will reply with a direct message \n - It's recommended to set `RC_ALWAYS_MENTION` to `True` in the `.env` (or use `--always-mention`) to ensure the user is mentioned in the reply \n",
"bugtrack_url": null,
"license": null,
"summary": null,
"version": "0.1.0",
"project_urls": null,
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "f7f5a5fd1843e5cd4c98b3308d3374b700752ae883fac5a9e9e3b9be83ac974f",
"md5": "07e0284a7fc6bd318e44372b4ea5e55f",
"sha256": "3b14527274023bbf26fd161a285a32586eb7aa6ad1dd1bd7fd57941f2f473018"
},
"downloads": -1,
"filename": "pystodon-0.1.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "07e0284a7fc6bd318e44372b4ea5e55f",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4.0,>=3.11",
"size": 14808,
"upload_time": "2024-06-06T00:34:21",
"upload_time_iso_8601": "2024-06-06T00:34:21.086819Z",
"url": "https://files.pythonhosted.org/packages/f7/f5/a5fd1843e5cd4c98b3308d3374b700752ae883fac5a9e9e3b9be83ac974f/pystodon-0.1.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "0bf9cbce7438ad55f4635e369818f0e6e77a18cd9ba535541053592c2ac449e4",
"md5": "d14badafa76120bf2ff2422e38dfc03f",
"sha256": "977272bec6aa610b808285faf40652eb837bb92ed674fce30c37fdfa273f12bc"
},
"downloads": -1,
"filename": "pystodon-0.1.0.tar.gz",
"has_sig": false,
"md5_digest": "d14badafa76120bf2ff2422e38dfc03f",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<4.0,>=3.11",
"size": 12390,
"upload_time": "2024-06-06T00:34:22",
"upload_time_iso_8601": "2024-06-06T00:34:22.446720Z",
"url": "https://files.pythonhosted.org/packages/0b/f9/cbce7438ad55f4635e369818f0e6e77a18cd9ba535541053592c2ac449e4/pystodon-0.1.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-06-06 00:34:22",
"github": false,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"lcname": "pystodon"
}