Skip to main content

A sane Discord API for Python 3 built on asyncio and good intentions

Project description

hikari

An opinionated Discord API for Python 3 and asyncio.

THIS API IS CURRENTLY IN A PRE-ALPHA STAGE, SO NEW VERSIONS WILL CONTAIN BREAKING CHANGES WITHOUT A MINOR VERSION INCREMENTATION. ALL FEATURES ARE PROVISIONAL AND CAN CHANGE AT ANY TIME UNTIL THIS API IS IN A USABLE STATE FOR A FULL FIRST RELEASE.

Please VISIT MY DISCORD if you wish to receive progress updates or help out, any help and contribution is more than welcome :-)

If you wish to explore the code in an online interactive viewer, you can use Sourcegraph on master and staging too!

What is this API?

A base Python Discord API framework for CPython 3.8 Designed for ease of use, customization, and sane defaults.

This API is designed to provide the pure-python interface to the RESTful Discord API and the Gateway. This will provide a set of basic models and abstractions that can be used to build a basic Discord bot in Python with asyncio in a logical, idiomatic, Pythonic, concise way.

Other APIs may exist that are faster, use less memory, or are smaller. I wont dispute that. The aim of this library is to provide a solid and consistent interface that can be relied upon by the end user, and to provide regular updates that are able to be opted into.

I also aim to provide as much automated test coverage as possible. I want to be able to immediately prove that a function does what is expected of it to provide hard evidence that a build is not fundamentally broken before deploying it.

The final aim is for maintainability. This API attempts to be as documented and expandable as possible internally. If something isn't right and you have some understanding of Python, hopefully you should be able to pick it up and tweak it to solve your use case, rather than fighting inflexible internal abstractions that hide the information you need.

What is this API not?

This API is not for people using anything older than CPython 3.8.

It currently is not able to provide voice functionality. Again, this may be added in the future.

FAQ

Contributing to Hikari

View the contributing guide!

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

hikari-1.0.1.dev6.tar.gz (124.1 kB view details)

Uploaded Source

Built Distribution

hikari-1.0.1.dev6-py3-none-any.whl (161.5 kB view details)

Uploaded Python 3

File details

Details for the file hikari-1.0.1.dev6.tar.gz.

File metadata

  • Download URL: hikari-1.0.1.dev6.tar.gz
  • Upload date:
  • Size: 124.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/45.1.0 requests-toolbelt/0.9.1 tqdm/4.44.0 CPython/3.8.1

File hashes

Hashes for hikari-1.0.1.dev6.tar.gz
Algorithm Hash digest
SHA256 85cda9c6b2c722b002db8c9ab32d21a1a5dab8faa61d05d745de34bb6856244f
MD5 e0aa6be3db1e64b01a650bd0738ee2a8
BLAKE2b-256 9febd3bb91424eddd3ab013a5f94a972bf57d47095a8c4bfea60aea5168b81d9

See more details on using hashes here.

File details

Details for the file hikari-1.0.1.dev6-py3-none-any.whl.

File metadata

  • Download URL: hikari-1.0.1.dev6-py3-none-any.whl
  • Upload date:
  • Size: 161.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/45.1.0 requests-toolbelt/0.9.1 tqdm/4.44.0 CPython/3.8.1

File hashes

Hashes for hikari-1.0.1.dev6-py3-none-any.whl
Algorithm Hash digest
SHA256 d4ee5f62ba4a624da61ed7a385255b34b747877047599199c35fe486bff97139
MD5 a7aefc1a855af296f8f5439087e8c200
BLAKE2b-256 13f37fdacbe061718309858c4eccaf0dadaa1d0eb2023b730d7ddd19f7a6019b

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