Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

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

Awesome Lists containing this project

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.