<div align="center">
<img src="https://raw.githubusercontent.com/OpShin/hebi/master/hebi.png" width="240" />
<h1 style="text-align: center;">hebi</h1></br>
<a href="https://app.travis-ci.com/OpShin/hebi"><img alt="Build Status" src="https://app.travis-ci.com/OpShin/hebi.svg?branch=main"/></a>
<a href="https://pypi.org/project/hebi/"><img alt="PyPI version" src="https://badge.fury.io/py/hebi.svg"/></a>
<img alt="PyPI - Python Version" src="https://img.shields.io/pypi/pyversions/hebi.svg" />
<a href="https://pypi.org/project/hebi/"><img alt="PyPI - Status" src="https://img.shields.io/pypi/status/hebi.svg" /></a>
<a href="https://coveralls.io/github/OpShin/hebi?branch=main"><img alt="Coverage Status" src="https://coveralls.io/repos/github/OpShin/hebi/badge.svg?branch=main" /></a>
</div>
> You are building what you want. Why not also build **how** you want?
This is an implementation of smart contracts for Cardano which are written in a very strict subset of valid Python.
The general philosophy of this project is to write a compiler that
ensure the following:
If the program compiles then:
1. it is a valid Python program
2. the output running it with python is the same as running it on-chain.
> Note this is the sister project of [eopsin](https://github.com/ImperatorLang/eopsin).
It uses an even more restricted subset of python (for example no while loops).
The benefit is that the resulting code is greatly reduced in size and cpu/memory consumption.
### Why hebi?
- 100% valid Python. Leverage the existing tool stack for Python, syntax highlighting, linting, debugging, unit-testing, [property-based testing](https://hypothesis.readthedocs.io/), [verification](https://github.com/marcoeilers/nagini)
- Intuitive. Just like Python.
- Functional. Forces you to write elegant, functional code in Python.
- Efficient & Secure. Static type inference ensures strict typing and optimized code
Eopsin is more comfortable to use than hebi.
If you want to start building, write your contract in eopsin first.
Then, after everything works to your pleasing, try to port to hebi and enjoy the performance gains.
### Getting Started
#### OpShin Pioneer Program
Check out the [opshin-pioneer-program](
https://github.com/OpShin/opshin-pioneer-program) for a host of educational example contracts, test cases and off-chain code.
#### Example repository
Check out the [opshin-starter-kit](
https://github.com/OpShin/opshin-starter-kit) repository for a quick start in setting up a development environment
and compiling some sample contracts yourself.
You can replace the contracts in your local copy of the repository with code from the
`examples` section here to start exploring different contracts.
#### Developer Community and Questions
The eopsin repository contains a discussions page.
Feel free to open up a new discussion with questions regarding development using hebi and using certain features.
Others may be able to help you and will also benefit from the previously shared questions.
Check out the community [here](https://github.com/OpShin/opshin/discussions)
You can also chat with other developers [in the welcoming discord
community](https://discord.gg/umR3A2g4uw) of OpShin
#### Installation
Install Python 3.8, 3.9 or 3.10. Then run
```bash
python3 -m pip install hebi
```
#### Writing a Smart Contract
A short non-complete introduction in starting to write smart contracts follows.
1. Make sure you understand EUTxOs, Addresses, Validators etc on Cardano. [There is a wonderful crashcourse by @KtorZ](https://aiken-lang.org/fundamentals/eutxo). The contract will work on these concepts
2. Make sure you understand python. hebi works like python and uses python. There are tons of tutorials for python, choose what suits you best.
3. Make sure your contract is valid python and the types check out. Write simple contracts first and run them using `hebi eval` to get a feeling for how they work.
4. Make sure your contract is valid hebi code. Run `hebi compile` and look at the compiler erros for guidance along what works and doesn't work and why.
5. Dig into the [`examples`](https://github.com/OpShin/hebi/tree/main/examples) to understand common patterns. Check out the [`prelude`](https://hebi.opshin.dev/hebi/prelude.html) for understanding how the Script Context is structured and how complex datums are defined.
6. Check out the [sample repository](https://github.com/OpShin/opshin-starter-kit) to find a sample setup for developing your own contract.
In summary, a smart contract in hebi is defined by the function `validator` in your contract file.
The function validates that a specific value can be spent, minted, burned, withdrawn etc, depending
on where it is invoked/used as a credential.
If the function fails (i.e. raises an error of any kind such as a `KeyError` or `AssertionError`)
the validation is denied, and the funds can not be spent, minted, burned etc.
> There is a subtle difference here in comparison to most other Smart Contract languages.
> In hebi a validator may return anything (in particular also `False`) - as long as it does not fail, the execution is considered valid.
> This is more similar to how contracts in Solidity always pass, unless they run out of gas or hit an error.
> So make sure to `assert` what you want to ensure to hold for validation!
A simple contract called the "Gift Contract" verifies that only specific wallets can withdraw money.
They are authenticated by a signature.
If you don't understand what a pubkeyhash is and how this validates anything, check out [this gentle introduction into Cardanos EUTxO](https://aiken-lang.org/fundamentals/eutxo).
Also see the [tutorial by `pycardano`](https://pycardano.readthedocs.io/en/latest/guides/plutus.html) for explanations on what each of the parameters to the validator means
and how to build transactions with the contract.
```python3
from hebi.prelude import *
@dataclass
class WithdrawDatum(PlutusData):
pubkeyhash: bytes
def validator(datum: WithdrawDatum, redeemer: None, context: ScriptContext) -> None:
assert datum.pubkeyhash in context.tx_info.signatories, "Required signature missing"
```
All contracts written in hebi are 100% valid python.
Minting policies expect only a redeemer and script context as argument.
Check out the [Architecture guide](https://github.com/OpShin/hebi/blob/main/ARCHITECTURE.md#minting-policy---spending-validator-double-function)
for details on how to write double functioning contracts.
The [`examples`](https://github.com/OpShin/hebi/blob/main/examples) folder contains more examples.
Also check out the [opshin-pioneer-program](
https://github.com/OpShin/opshin-pioneer-program)
and [opshin-starter-kit](
https://github.com/OpShin/opshin-starter-kit) repo.
### Compiling
Write your program in python. You may start with the content of `examples`.
Arguments to scripts are passed in as Plutus Data objects in JSON notation.
You can run any of the following commands
```bash
# Evaluate script in Python - this can be used to make sure there are no obvious errors
hebi eval examples/smart_contracts/assert_sum.py "{\"int\": 4}" "{\"int\": 38}" "{\"constructor\": 0, \"fields\": []}"
# Compile script to 'uplc', the Cardano Smart Contract assembly
hebi compile examples/smart_contracts/assert_sum.py
```
### Deploying
The deploy process generates all artifacts required for usage with common libraries like [pycardano](https://github.com/Python-Cardano/pycardano), [lucid](https://github.com/spacebudz/lucid) and the [cardano-cli](https://github.com/input-output-hk/cardano-node).
```bash
# Automatically generate all artifacts needed for using this contract
hebi build examples/smart_contracts/assert_sum.py
```
See the [tutorial by `pycardano`](https://pycardano.readthedocs.io/en/latest/guides/plutus.html) for explanations how to build transactions with `opshin` contracts.
### The small print
_Not every valid python program is a valid smart contract_.
Not all language features of python will or can be supported.
The reasons are mainly of practical nature (i.e. we can't infer types when functions like `eval` are allowed).
Specifically, only a pure subset of python is allowed.
Further, only immutable objects may be generated.
For your program to be accepted, make sure to only make use of language constructs supported by the compiler.
You will be notified of which constructs are not supported when trying to compile.
### Name
Hebi is japanese for "snake", which is a play on words on `python`, the underlying language.
### Versioning scheme
Since this project builds on top of eopsin, it has a particular versioning scheme.
The first three numbers indicate the version of `hebi` (starting at `0.1.0`).
Then follows the latest version number of `eopsin` which was merged into the project (starting at `0.9.3`).
This is intended to help navigating releases among both packages, where it might be important
that a recent eopsin release is integrated that contains a security patch.
## Contributing
### Architecture
This program consists of a few independent components:
1. An aggressive static type inferencer
2. Rewriting tools to simplify complex python expressions
3. A compiler from a subset of python into UPLC
### Debugging artefacts
For debugging purposes, you can also run
```bash
# Compile script to 'uplc', and evaluate the script in UPLC (for debugging purposes)
python3 -m hebi eval_uplc examples/smart_contracts/assert_sum.py "{\"int\": 4}" "{\"int\": 38}" "{\"constructor\": 0, \"fields\": []}"
# Compile script to 'pluto', an intermediate language (for debugging purposes)
python3 -m hebi compile_pluto examples/smart_contracts/assert_sum.py
```
### Sponsoring
You can sponsor the development of hebi through GitHub or [Teiki](https://alpha.teiki.network/projects/opshin) or just by sending ADA. Drop me a message on social media and let me know what it is for.
- **[Kreate](https://beta.kreate.community/projects/opshin)** Stake your ada to support OpShin at [Kreate](https://beta.kreate.community/projects/opshin)
- **GitHub** Sponsor the developers of this project through the button "Sponsor" next to them
- **ADA** Donation in ADA can be submitted to `$opshin` or `addr1qyz3vgd5xxevjy2rvqevz9n7n7dney8n6hqggp23479fm6vwpj9clsvsf85cd4xc59zjztr5zwpummwckmzr2myjwjns74lhmr`.
### Supporters
<a href="https://github.com/inversion-dev"><img src="https://avatars.githubusercontent.com/u/127298233?s=200&v=4" width="50"></a>
<a href="https://github.com/MuesliSwapTeam/"><img src="https://avatars.githubusercontent.com/u/91151317?v=4" width="50" /></a>
<a href="https://github.com/AadaFinance/"><img src="https://avatars.githubusercontent.com/u/89693711?v=4" width="50" /></a>
The main sponsor of this project is [Inversion](https://inversion.dev/cardano/). Here is a word from them!
> At Inversion, we pride ourselves on our passion for life and our ability to create exceptional software solutions for our clients. Our team of experts, with over a century of cumulative experience, is dedicated to harnessing the power of the Cardano blockchain to bring innovative and scalable decentralized applications to life. We've successfully built applications for NFT management, staking and delegation, chain data monitoring, analytics, and web3 integrations, as well as countless non-blockchain systems. With a focus on security, transparency, and sustainability, our team is excited to contribute to the Cardano ecosystem, pushing the boundaries of decentralized technologies to improve lives worldwide. Trust Inversion to be your go-to partner for robust, effective, and forward-thinking solutions, whether blockchain based, traditional systems, or a mix of the two.
They have recently started a podcast, called "Africa On Chain", which you can check out here:
https://www.youtube.com/@africaonchain
Raw data
{
"_id": null,
"home_page": "https://github.com/opshin/hebi",
"name": "hebi",
"maintainer": "",
"docs_url": null,
"requires_python": ">=3.8,<3.12",
"maintainer_email": "",
"keywords": "python,language,programming-language,compiler,validator,smart-contracts,cardano",
"author": "nielstron",
"author_email": "n.muendler@web.de",
"download_url": "https://files.pythonhosted.org/packages/96/d6/69f39dd9a19548786a9d043c09e9d5a7d30c1f3a399227bf740b2ff12fc9/hebi-0.2.0.0.12.5.tar.gz",
"platform": null,
"description": "\n<div align=\"center\">\n\n<img src=\"https://raw.githubusercontent.com/OpShin/hebi/master/hebi.png\" width=\"240\" />\n<h1 style=\"text-align: center;\">hebi</h1></br>\n\n\n<a href=\"https://app.travis-ci.com/OpShin/hebi\"><img alt=\"Build Status\" src=\"https://app.travis-ci.com/OpShin/hebi.svg?branch=main\"/></a>\n<a href=\"https://pypi.org/project/hebi/\"><img alt=\"PyPI version\" src=\"https://badge.fury.io/py/hebi.svg\"/></a>\n<img alt=\"PyPI - Python Version\" src=\"https://img.shields.io/pypi/pyversions/hebi.svg\" />\n<a href=\"https://pypi.org/project/hebi/\"><img alt=\"PyPI - Status\" src=\"https://img.shields.io/pypi/status/hebi.svg\" /></a>\n<a href=\"https://coveralls.io/github/OpShin/hebi?branch=main\"><img alt=\"Coverage Status\" src=\"https://coveralls.io/repos/github/OpShin/hebi/badge.svg?branch=main\" /></a>\n\n</div>\n\n> You are building what you want. Why not also build **how** you want?\n\n\nThis is an implementation of smart contracts for Cardano which are written in a very strict subset of valid Python.\nThe general philosophy of this project is to write a compiler that \nensure the following:\n\nIf the program compiles then:\n\n1. it is a valid Python program\n2. the output running it with python is the same as running it on-chain.\n\n\n> Note this is the sister project of [eopsin](https://github.com/ImperatorLang/eopsin).\nIt uses an even more restricted subset of python (for example no while loops).\nThe benefit is that the resulting code is greatly reduced in size and cpu/memory consumption.\n\n\n### Why hebi?\n- 100% valid Python. Leverage the existing tool stack for Python, syntax highlighting, linting, debugging, unit-testing, [property-based testing](https://hypothesis.readthedocs.io/), [verification](https://github.com/marcoeilers/nagini)\n- Intuitive. Just like Python.\n- Functional. Forces you to write elegant, functional code in Python.\n- Efficient & Secure. Static type inference ensures strict typing and optimized code\n\nEopsin is more comfortable to use than hebi.\nIf you want to start building, write your contract in eopsin first.\nThen, after everything works to your pleasing, try to port to hebi and enjoy the performance gains.\n\n### Getting Started\n\n#### OpShin Pioneer Program\n\nCheck out the [opshin-pioneer-program](\nhttps://github.com/OpShin/opshin-pioneer-program) for a host of educational example contracts, test cases and off-chain code.\n\n#### Example repository\n\nCheck out the [opshin-starter-kit](\nhttps://github.com/OpShin/opshin-starter-kit) repository for a quick start in setting up a development environment\nand compiling some sample contracts yourself.\n\n\nYou can replace the contracts in your local copy of the repository with code from the\n`examples` section here to start exploring different contracts.\n\n#### Developer Community and Questions\n\nThe eopsin repository contains a discussions page.\nFeel free to open up a new discussion with questions regarding development using hebi and using certain features.\nOthers may be able to help you and will also benefit from the previously shared questions.\n\nCheck out the community [here](https://github.com/OpShin/opshin/discussions)\n\nYou can also chat with other developers [in the welcoming discord\ncommunity](https://discord.gg/umR3A2g4uw) of OpShin\n\n#### Installation\n\nInstall Python 3.8, 3.9 or 3.10. Then run\n\n```bash\npython3 -m pip install hebi\n```\n\n#### Writing a Smart Contract\n\nA short non-complete introduction in starting to write smart contracts follows.\n\n1. Make sure you understand EUTxOs, Addresses, Validators etc on Cardano. [There is a wonderful crashcourse by @KtorZ](https://aiken-lang.org/fundamentals/eutxo). The contract will work on these concepts\n2. Make sure you understand python. hebi works like python and uses python. There are tons of tutorials for python, choose what suits you best.\n3. Make sure your contract is valid python and the types check out. Write simple contracts first and run them using `hebi eval` to get a feeling for how they work.\n4. Make sure your contract is valid hebi code. Run `hebi compile` and look at the compiler erros for guidance along what works and doesn't work and why.\n5. Dig into the [`examples`](https://github.com/OpShin/hebi/tree/main/examples) to understand common patterns. Check out the [`prelude`](https://hebi.opshin.dev/hebi/prelude.html) for understanding how the Script Context is structured and how complex datums are defined.\n6. Check out the [sample repository](https://github.com/OpShin/opshin-starter-kit) to find a sample setup for developing your own contract.\n\n\nIn summary, a smart contract in hebi is defined by the function `validator` in your contract file.\nThe function validates that a specific value can be spent, minted, burned, withdrawn etc, depending\non where it is invoked/used as a credential.\nIf the function fails (i.e. raises an error of any kind such as a `KeyError` or `AssertionError`)\nthe validation is denied, and the funds can not be spent, minted, burned etc.\n\n> There is a subtle difference here in comparison to most other Smart Contract languages.\n> In hebi a validator may return anything (in particular also `False`) - as long as it does not fail, the execution is considered valid.\n> This is more similar to how contracts in Solidity always pass, unless they run out of gas or hit an error.\n> So make sure to `assert` what you want to ensure to hold for validation!\n\nA simple contract called the \"Gift Contract\" verifies that only specific wallets can withdraw money.\nThey are authenticated by a signature.\nIf you don't understand what a pubkeyhash is and how this validates anything, check out [this gentle introduction into Cardanos EUTxO](https://aiken-lang.org/fundamentals/eutxo).\nAlso see the [tutorial by `pycardano`](https://pycardano.readthedocs.io/en/latest/guides/plutus.html) for explanations on what each of the parameters to the validator means\nand how to build transactions with the contract.\n\n```python3\nfrom hebi.prelude import *\n\n@dataclass\nclass WithdrawDatum(PlutusData):\n pubkeyhash: bytes\n\n\ndef validator(datum: WithdrawDatum, redeemer: None, context: ScriptContext) -> None:\n assert datum.pubkeyhash in context.tx_info.signatories, \"Required signature missing\"\n```\n\nAll contracts written in hebi are 100% valid python.\nMinting policies expect only a redeemer and script context as argument.\nCheck out the [Architecture guide](https://github.com/OpShin/hebi/blob/main/ARCHITECTURE.md#minting-policy---spending-validator-double-function)\nfor details on how to write double functioning contracts.\nThe [`examples`](https://github.com/OpShin/hebi/blob/main/examples) folder contains more examples.\nAlso check out the [opshin-pioneer-program](\nhttps://github.com/OpShin/opshin-pioneer-program)\nand [opshin-starter-kit](\nhttps://github.com/OpShin/opshin-starter-kit) repo.\n\n### Compiling\n\nWrite your program in python. You may start with the content of `examples`.\nArguments to scripts are passed in as Plutus Data objects in JSON notation.\n\nYou can run any of the following commands\n```bash\n# Evaluate script in Python - this can be used to make sure there are no obvious errors\nhebi eval examples/smart_contracts/assert_sum.py \"{\\\"int\\\": 4}\" \"{\\\"int\\\": 38}\" \"{\\\"constructor\\\": 0, \\\"fields\\\": []}\"\n\n# Compile script to 'uplc', the Cardano Smart Contract assembly\nhebi compile examples/smart_contracts/assert_sum.py\n```\n\n### Deploying\n\nThe deploy process generates all artifacts required for usage with common libraries like [pycardano](https://github.com/Python-Cardano/pycardano), [lucid](https://github.com/spacebudz/lucid) and the [cardano-cli](https://github.com/input-output-hk/cardano-node).\n\n```bash\n# Automatically generate all artifacts needed for using this contract\nhebi build examples/smart_contracts/assert_sum.py\n```\n\nSee the [tutorial by `pycardano`](https://pycardano.readthedocs.io/en/latest/guides/plutus.html) for explanations how to build transactions with `opshin` contracts.\n\n### The small print\n\n_Not every valid python program is a valid smart contract_.\nNot all language features of python will or can be supported.\nThe reasons are mainly of practical nature (i.e. we can't infer types when functions like `eval` are allowed).\nSpecifically, only a pure subset of python is allowed.\nFurther, only immutable objects may be generated.\n\nFor your program to be accepted, make sure to only make use of language constructs supported by the compiler.\nYou will be notified of which constructs are not supported when trying to compile.\n\n### Name\n\nHebi is japanese for \"snake\", which is a play on words on `python`, the underlying language.\n\n### Versioning scheme\n\nSince this project builds on top of eopsin, it has a particular versioning scheme.\nThe first three numbers indicate the version of `hebi` (starting at `0.1.0`).\nThen follows the latest version number of `eopsin` which was merged into the project (starting at `0.9.3`).\nThis is intended to help navigating releases among both packages, where it might be important\nthat a recent eopsin release is integrated that contains a security patch.\n\n## Contributing\n\n### Architecture\n\nThis program consists of a few independent components:\n\n1. An aggressive static type inferencer\n2. Rewriting tools to simplify complex python expressions\n3. A compiler from a subset of python into UPLC\n\n### Debugging artefacts\n\nFor debugging purposes, you can also run\n\n```bash\n# Compile script to 'uplc', and evaluate the script in UPLC (for debugging purposes)\npython3 -m hebi eval_uplc examples/smart_contracts/assert_sum.py \"{\\\"int\\\": 4}\" \"{\\\"int\\\": 38}\" \"{\\\"constructor\\\": 0, \\\"fields\\\": []}\"\n\n# Compile script to 'pluto', an intermediate language (for debugging purposes)\npython3 -m hebi compile_pluto examples/smart_contracts/assert_sum.py\n```\n\n### Sponsoring\n\nYou can sponsor the development of hebi through GitHub or [Teiki](https://alpha.teiki.network/projects/opshin) or just by sending ADA. Drop me a message on social media and let me know what it is for.\n\n- **[Kreate](https://beta.kreate.community/projects/opshin)** Stake your ada to support OpShin at [Kreate](https://beta.kreate.community/projects/opshin)\n- **GitHub** Sponsor the developers of this project through the button \"Sponsor\" next to them\n- **ADA** Donation in ADA can be submitted to `$opshin` or `addr1qyz3vgd5xxevjy2rvqevz9n7n7dney8n6hqggp23479fm6vwpj9clsvsf85cd4xc59zjztr5zwpummwckmzr2myjwjns74lhmr`.\n\n### Supporters\n\n<a href=\"https://github.com/inversion-dev\"><img src=\"https://avatars.githubusercontent.com/u/127298233?s=200&v=4\" width=\"50\"></a>\n<a href=\"https://github.com/MuesliSwapTeam/\"><img src=\"https://avatars.githubusercontent.com/u/91151317?v=4\" width=\"50\" /></a>\n<a href=\"https://github.com/AadaFinance/\"><img src=\"https://avatars.githubusercontent.com/u/89693711?v=4\" width=\"50\" /></a>\n\nThe main sponsor of this project is [Inversion](https://inversion.dev/cardano/). Here is a word from them!\n\n> At Inversion, we pride ourselves on our passion for life and our ability to create exceptional software solutions for our clients. Our team of experts, with over a century of cumulative experience, is dedicated to harnessing the power of the Cardano blockchain to bring innovative and scalable decentralized applications to life. We've successfully built applications for NFT management, staking and delegation, chain data monitoring, analytics, and web3 integrations, as well as countless non-blockchain systems. With a focus on security, transparency, and sustainability, our team is excited to contribute to the Cardano ecosystem, pushing the boundaries of decentralized technologies to improve lives worldwide. Trust Inversion to be your go-to partner for robust, effective, and forward-thinking solutions, whether blockchain based, traditional systems, or a mix of the two.\n\nThey have recently started a podcast, called \"Africa On Chain\", which you can check out here:\nhttps://www.youtube.com/@africaonchain\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "A simple and fast pythonic programming language for Smart Contracts on Cardano",
"version": "0.2.0.0.12.5",
"split_keywords": [
"python",
"language",
"programming-language",
"compiler",
"validator",
"smart-contracts",
"cardano"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "11663f03b6337cec6438c5a9579c0b166411d150a75c6fc03f2cab9afde48477",
"md5": "807ce3211015fb4c0bbda7dff5bdd0ff",
"sha256": "25e8a22f3c857fbec2aea74e9a8e3c13343156654ef624a869c4f66ad8411999"
},
"downloads": -1,
"filename": "hebi-0.2.0.0.12.5-py3-none-any.whl",
"has_sig": false,
"md5_digest": "807ce3211015fb4c0bbda7dff5bdd0ff",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.8,<3.12",
"size": 67759,
"upload_time": "2023-04-15T22:35:17",
"upload_time_iso_8601": "2023-04-15T22:35:17.956668Z",
"url": "https://files.pythonhosted.org/packages/11/66/3f03b6337cec6438c5a9579c0b166411d150a75c6fc03f2cab9afde48477/hebi-0.2.0.0.12.5-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "96d669f39dd9a19548786a9d043c09e9d5a7d30c1f3a399227bf740b2ff12fc9",
"md5": "af9a52a1749229705a3c312aa8e5f7df",
"sha256": "eece5dd0192aac262ac7f938ba792f67208f8c2318545707c48deca865bf8f53"
},
"downloads": -1,
"filename": "hebi-0.2.0.0.12.5.tar.gz",
"has_sig": false,
"md5_digest": "af9a52a1749229705a3c312aa8e5f7df",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.8,<3.12",
"size": 56205,
"upload_time": "2023-04-15T22:35:19",
"upload_time_iso_8601": "2023-04-15T22:35:19.991400Z",
"url": "https://files.pythonhosted.org/packages/96/d6/69f39dd9a19548786a9d043c09e9d5a7d30c1f3a399227bf740b2ff12fc9/hebi-0.2.0.0.12.5.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-04-15 22:35:19",
"github": true,
"gitlab": false,
"bitbucket": false,
"github_user": "opshin",
"github_project": "hebi",
"travis_ci": true,
"coveralls": false,
"github_actions": true,
"lcname": "hebi"
}