Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/EnokiUN/voltage
A simple asynchronous pythonic wrapper for the revolt api
https://github.com/EnokiUN/voltage
Last synced: 3 months ago
JSON representation
A simple asynchronous pythonic wrapper for the revolt api
- Host: GitHub
- URL: https://github.com/EnokiUN/voltage
- Owner: EnokiUN
- License: mit
- Created: 2022-03-12T10:58:05.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-03-02T20:08:27.000Z (8 months ago)
- Last Synced: 2024-07-09T09:21:22.309Z (4 months ago)
- Language: Python
- Size: 1.86 MB
- Stars: 44
- Watchers: 3
- Forks: 14
- Open Issues: 5
-
Metadata Files:
- Readme: README.rst
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-revolt - Voltage - A simple asynchronous pythonic wrapper for the revolt api. (💻 API Libraries / Python)
README
-------
Voltage
-------|Support Server| |PyPi| |Docs| |Checks|
A simple pythonic asynchronous API wrapper for `Revolt. `_
|Screenshot|
=====
Usage
=====.. code-block:: python3
import voltage # Import voltage.
client = voltage.Client() # Initialize the client.
@client.listen("ready") # Listen to an event.
async def on_ready():
print(f"Logged in as {client.user}")@client.listen("message")
async def on_message(message): # Doesn't matter what you call the function.
if message.content == "-ping":
await message.channel.send("pong!") # Send a message.
elif message.content == "-embed":
embed = voltage.SendableEmbed(title="Hello World", description="This is an embed") # Create an embed.
# Reply to a message.
await message.reply(embed=embed)# Run the client which is an abstraction of calling the start coroutine.
client.run("TOKEN") # Replace with your token.Commands framework example:
.. code-block:: python3
import voltage
from voltage.ext import commands # Import the commands module from ``voltage.ext``client = commands.CommandsClient("-") # Create a CommandsClient (client that has commands (original ik)) with the prefix set to "-".
@client.listen("ready") # You can still listen to events.
async def ready():
print("Gaaah, It's rewind time.")@client.command() # Register a command using the ``command`` decorator.
async def ping(ctx):
"""Sends Pong!""" # Name and description can be passed in the decorator or automatically inferred.
await ctx.reply("Pong") # Reply to the context's message.client.run("TOKEN") # Again, replace with your bot token.
For more examples check the `examples `_ folder which has a lot of useful, ready to go, and explained examples.
============
Installation
============Voltage is available on `PyPI `_!
To install voltage just run:
.. code-block:: sh
pip install voltage
If you want to install the main branch which may have more features but will be more unstable you run:
.. code-block:: sh
pip install git+https://github.com/EnokiUN/voltage
.. note::
Python 3.8 or higher is required to install voltage.Installing from GitHub requires the Git CLI to be available on your machine.
=======
Credits
=======- **Contributors**, thank you :)
- `Revolt.py `_, when shit broke, that's where I went.
- `Revolt.js `_, when the docs fail you.
- `Discord.py `_, also a really great help while making this.
- **Revolt development team**, absolute chads.
- **FatalErrorCoded**, Vortex guys, carrying with voice implementation, eats chadness.
- **RGBCube**, Came up with the amazing name "Voltage".
.. |Support Server| image:: https://img.shields.io/badge/dynamic/json?color=ff4655&labelColor=111823&label=Support%20Server&query=member_count&suffix=%20Members&url=https%3A%2F%2Fapi.revolt.chat%2Finvites%2Fbwtscg1F&style=for-the-badge&logo=
:target: https://rvlt.gg/bwtscg1F
:alt: Revolt Support Server
.. |PyPi| image:: https://img.shields.io/pypi/v/voltage.svg?labelColor=111823&logo=pypi&logoColor=white&style=for-the-badge
:target: https://pypi.org/project/voltage
:alt: PyPi Page.
.. |Docs| image:: https://img.shields.io/readthedocs/revolt-voltage/latest?labelColor=111823&style=for-the-badge&logo=readthedocs&logoColor=white
:alt: Docs Status
:target: https://revolt-voltage.readthedocs.io/
.. |Checks| image:: https://img.shields.io/github/actions/workflow/status/enokiun/voltage/pyright.yml?label=checks&labelColor=111823&logo=github&style=for-the-badge
:alt: GitHub Workflow Status
.. |Logo| image:: https://github.com/EnokiUN/voltage/blob/main/assets/voltage.png
:alt: Voltage Logo
:width: 80
.. |Screenshot| image:: https://github.com/EnokiUN/voltage/blob/main/assets/ss.png
:alt: Screenshot Of Starting A Bot.