forked from lthn/blockchain
This pull request introduces a comprehensive new API interface for the blockchain, leveraging OpenAPI v3 to facilitate direct consumption of chain data by GUI and web applications. This change significantly refines the project's build infrastructure, incorporating Conan for dependency management and CMake for configuration, alongside the integration of an OpenAPI Generator to produce SDKs for multiple languages. ### Highlights * **New API Interface**: Introduced a new API interface using OpenAPI v3 to enable GUI/WEB development to consume chain data without needing custom server applications. * **Build System Enhancements**: Significant updates to the build system, including Makefile, CMake, and Conan configurations, to streamline the build process and support new functionalities. * **Multi-language SDK Generation**: Integrated OpenAPI Generator to automatically create SDKs for various programming languages, including Go, Angular, and PHP, simplifying client-side integration.
95 lines
2.4 KiB
TOML
Generated
95 lines
2.4 KiB
TOML
Generated
[project]
|
|
name = "lthn"
|
|
version = "1.0.0"
|
|
description = "Lethean Blockchain API"
|
|
authors = [
|
|
{name = "Lethean",email = "team@openapitools.org"},
|
|
]
|
|
license = { text = "EUPL-1.2" }
|
|
readme = "README.md"
|
|
keywords = ["OpenAPI", "OpenAPI-Generator", "Lethean Blockchain API"]
|
|
requires-python = ">=3.9"
|
|
|
|
dependencies = [
|
|
"urllib3 (>=2.1.0,<3.0.0)",
|
|
"python-dateutil (>=2.8.2)",
|
|
"pydantic (>=2)",
|
|
"typing-extensions (>=4.7.1)",
|
|
]
|
|
|
|
[project.urls]
|
|
Repository = "https://github.com/letheanVPN/blockchain"
|
|
|
|
[tool.poetry]
|
|
requires-poetry = ">=2.0"
|
|
|
|
[tool.poetry.group.dev.dependencies]
|
|
pytest = ">= 7.2.1"
|
|
pytest-cov = ">= 2.8.1"
|
|
tox = ">= 3.9.0"
|
|
flake8 = ">= 4.0.0"
|
|
types-python-dateutil = ">= 2.8.19.14"
|
|
mypy = ">= 1.5"
|
|
|
|
|
|
[build-system]
|
|
requires = ["setuptools"]
|
|
build-backend = "setuptools.build_meta"
|
|
|
|
[tool.pylint.'MESSAGES CONTROL']
|
|
extension-pkg-whitelist = "pydantic"
|
|
|
|
[tool.mypy]
|
|
files = [
|
|
"lthn",
|
|
#"test", # auto-generated tests
|
|
"tests", # hand-written tests
|
|
]
|
|
# TODO: enable "strict" once all these individual checks are passing
|
|
# strict = true
|
|
|
|
# List from: https://mypy.readthedocs.io/en/stable/existing_code.html#introduce-stricter-options
|
|
warn_unused_configs = true
|
|
warn_redundant_casts = true
|
|
warn_unused_ignores = true
|
|
|
|
## Getting these passing should be easy
|
|
strict_equality = true
|
|
extra_checks = true
|
|
|
|
## Strongly recommend enabling this one as soon as you can
|
|
check_untyped_defs = true
|
|
|
|
## These shouldn't be too much additional work, but may be tricky to
|
|
## get passing if you use a lot of untyped libraries
|
|
disallow_subclassing_any = true
|
|
disallow_untyped_decorators = true
|
|
disallow_any_generics = true
|
|
|
|
### These next few are various gradations of forcing use of type annotations
|
|
#disallow_untyped_calls = true
|
|
#disallow_incomplete_defs = true
|
|
#disallow_untyped_defs = true
|
|
#
|
|
### This one isn't too hard to get passing, but return on investment is lower
|
|
#no_implicit_reexport = true
|
|
#
|
|
### This one can be tricky to get passing if you use a lot of untyped libraries
|
|
#warn_return_any = true
|
|
|
|
[[tool.mypy.overrides]]
|
|
module = [
|
|
"lthn.configuration",
|
|
]
|
|
warn_unused_ignores = true
|
|
strict_equality = true
|
|
extra_checks = true
|
|
check_untyped_defs = true
|
|
disallow_subclassing_any = true
|
|
disallow_untyped_decorators = true
|
|
disallow_any_generics = true
|
|
disallow_untyped_calls = true
|
|
disallow_incomplete_defs = true
|
|
disallow_untyped_defs = true
|
|
no_implicit_reexport = true
|
|
warn_return_any = true
|