Skip to main content

Async library for creating Bots for amino

Project description

This project is in no way associated with Amino or MediaLabs, this is completely reverse engineered

AminoAcid

Why AminoAcid?

Because other projects like BotAmino fail to allow a nicely done, pythonic, completely async hinted experience.
This project aims to open up the possibilities that other libraries don't fulfill by being completely async using aiohttp, allowing OOP, allowing events with a discord.py-esque experience.
While BotAmino tries to be easy to use it fails to provide an easy high-level API by forcing to use Amino.fix instead of allowing access via their own methods and objects.

How do you use it?

AminoAcid's documentation is available through GitHub pages and auto generated using pdoc, for examples take a look into the examples dir

from aminoacid import Bot
from aminoacid.abc import Message, Context

client = Bot(
    prefix="b!",
    key=bytes.fromhex("B0000000B50000000000000000000B000000000B"),
    device = "42..."
)

@client.command(name="say")
async def hi(ctx: Context, *nya: str):
    message = await ctx.send(" ".join(nya))
    print(message)

@client.event("on_message")
async def on_message(message: Message):
    if message.author.id == client.profile.id: return
    print(message, "nya!")

client.run(
    session="AnsiMSI6..."
)
# OR
#client.run(
#    email="mail@gmail.com",
#    password=   r"Rc2Z=I5S0bN;ewjn2jasdn43",
#)

As you might see, you need to supply your own key to sign the requests with. You can find this in other libraries tho.
Please note, that this library is NOT finished and a lot of features I want to implement are still missing.

How to subscribe to topics to get notifications?

AminoAcid supports receiving notification events via the socket like the normal app would.
The notification future still needs a lot of work, because so far it's not receiving events like follow, comment, etc.

To receive notifications with a certain topic you can it's suggested to send a subscribe object in your on_ready callback

...

@client.event()
async def on_ready():
    client.logger.info(client._http.session)
    await client.socket.subscribe(ndcId, topic=topic)

...

so far known topics are documented in the Topics enum

Why no key?

The aim of this library is NOT to make malicious bots, which is why you need to put the key in yourself.
This library should only be used for making fun chat bots.

How to do X?

Check the docs, if it's in there then look at how to use it. If it's not there you probably can't.
If you want to request a feature, you can open a new Issue.

AminoAcid or AminoAcids?

This was originally called AminoAcids but then i noticed that the pypi project "aminoacids" was already taken, so i removed the s

To-Do

  • Finish Object attributes
  • Type checking and converting
  • Add Embed features
  • Improve existing features
  • Better quality in code
  • Complete Exceptions
  • Complete SocketCode Enum
  • Make the SocketClient subscribe to other events to allow on_follow and on_notification events
  • Finish started but unfinished methods
  • Cog-like Command categories
  • on_typing_start, etc. events (socket code 400)
  • Command error handlers

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

aminoacid-0.1.4.tar.gz (20.0 kB view details)

Uploaded Source

Built Distribution

aminoacid-0.1.4-py3-none-any.whl (21.4 kB view details)

Uploaded Python 3

File details

Details for the file aminoacid-0.1.4.tar.gz.

File metadata

  • Download URL: aminoacid-0.1.4.tar.gz
  • Upload date:
  • Size: 20.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.6

File hashes

Hashes for aminoacid-0.1.4.tar.gz
Algorithm Hash digest
SHA256 859c93354abf9997ab86b88a8a5879ad73bfa2f8b52ff7e9f6d97957df39a93b
MD5 885221d5e6068dd349b624141fb776de
BLAKE2b-256 117ad7becc3abfd06b6f2b2c1065772644ce860e2956acf9f650c6541540e560

See more details on using hashes here.

File details

Details for the file aminoacid-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: aminoacid-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 21.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.6

File hashes

Hashes for aminoacid-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 d8ad8c2d823c99a8ac909f1c3274098f2a58771d11d0874c62e03e21cb25e314
MD5 65788350eb4fa08cede9d08d56c54667
BLAKE2b-256 5e1d1909a15fd69e9dfa5411f6de57ed5215a98af2854c2cca30d2db5473181b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page