# TypeFit
[](http://typefit.rtfd.io/)
[](https://github.com/Xowap/typefit/actions/workflows/run-tests.yaml)
Typing annotations make Python awesome, however it's complicated to keep your
data annotated when it comes from external sources like APIs. The goal of
Typefit is to help you map that external data into type-annotated native Python
objects.
```python
from typefit import api
from typing import NamedTuple, Text
class Item(NamedTuple):
    id: int
    title: Text
class HackerNews(api.SyncClient):
    BASE_URL = "https://hacker-news.firebaseio.com/v0/"
    @api.get("item/{item_id}.json")
    def get_item(self, item_id: int) -> Item:
        pass
story = HackerNews().get_item(42)
print(story.title)
# An alternative to VC: "Selling In"
```
This is the full example of a Hacker News API client. Its functionality is
limited but in 14 lines counting white space you can build a type-safe client
for Hacker News. You'll find a [full example](example/typefit_hn) attached if
you're interested.
## Documentation
[✨ **Documentation is there** ✨](http://typefit.rtfd.io/)
## Licence
This library is provided under the terms of the [WTFPL](./LICENSE).
If you find it useful, you can have a look at the
[contributors](https://github.com/Xowap/typefit/graphs/contributors) page to
know who helped.
            
         
        Raw data
        
            {
    "_id": null,
    "home_page": "https://github.com/Xowap/typefit/",
    "name": "typefit",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<4.0,>=3.10",
    "maintainer_email": null,
    "keywords": "typing, json, api",
    "author": "R\u00e9my Sanchez",
    "author_email": "remy.sanchez@hyperthese.net",
    "download_url": "https://files.pythonhosted.org/packages/b3/21/ed76c10dc694b9e34ca44a24ba9012a59a652a1bccea8644f157c623ad3a/typefit-1.0.0.tar.gz",
    "platform": null,
    "description": "# TypeFit\n\n[](http://typefit.rtfd.io/)\n[](https://github.com/Xowap/typefit/actions/workflows/run-tests.yaml)\n\nTyping annotations make Python awesome, however it's complicated to keep your\ndata annotated when it comes from external sources like APIs. The goal of\nTypefit is to help you map that external data into type-annotated native Python\nobjects.\n\n```python\nfrom typefit import api\nfrom typing import NamedTuple, Text\n\n\nclass Item(NamedTuple):\n    id: int\n    title: Text\n\n\nclass HackerNews(api.SyncClient):\n    BASE_URL = \"https://hacker-news.firebaseio.com/v0/\"\n\n    @api.get(\"item/{item_id}.json\")\n    def get_item(self, item_id: int) -> Item:\n        pass\n\nstory = HackerNews().get_item(42)\nprint(story.title)\n# An alternative to VC: "Selling In"\n```\n\nThis is the full example of a Hacker News API client. Its functionality is\nlimited but in 14 lines counting white space you can build a type-safe client\nfor Hacker News. You'll find a [full example](example/typefit_hn) attached if\nyou're interested.\n\n## Documentation\n\n[\u2728 **Documentation is there** \u2728](http://typefit.rtfd.io/)\n\n## Licence\n\nThis library is provided under the terms of the [WTFPL](./LICENSE).\n\nIf you find it useful, you can have a look at the\n[contributors](https://github.com/Xowap/typefit/graphs/contributors) page to\nknow who helped.\n",
    "bugtrack_url": null,
    "license": "WTFPL",
    "summary": "Fits JSON values into Python type-anotated objects",
    "version": "1.0.0",
    "project_urls": {
        "Homepage": "https://github.com/Xowap/typefit/",
        "Repository": "https://github.com/Xowap/typefit/"
    },
    "split_keywords": [
        "typing",
        " json",
        " api"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "b3b356f9de7577e29ce044ed936ec9fcd43829f98d5435298eba2dd15ec19f3b",
                "md5": "b1280c987b4bf92edbd89bc2225a3855",
                "sha256": "c21d92b83e18418ce1b786c4c88bd02b00ae890adc4e671cf6a7e524058b3df4"
            },
            "downloads": -1,
            "filename": "typefit-1.0.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "b1280c987b4bf92edbd89bc2225a3855",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<4.0,>=3.10",
            "size": 26392,
            "upload_time": "2024-09-13T12:21:23",
            "upload_time_iso_8601": "2024-09-13T12:21:23.370433Z",
            "url": "https://files.pythonhosted.org/packages/b3/b3/56f9de7577e29ce044ed936ec9fcd43829f98d5435298eba2dd15ec19f3b/typefit-1.0.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "b321ed76c10dc694b9e34ca44a24ba9012a59a652a1bccea8644f157c623ad3a",
                "md5": "ad19ea6a94bd048be0fc35265304306e",
                "sha256": "4300f773a83c48e8bf3911773555d50e5678d11ab7f2234e96f12263237a5a56"
            },
            "downloads": -1,
            "filename": "typefit-1.0.0.tar.gz",
            "has_sig": false,
            "md5_digest": "ad19ea6a94bd048be0fc35265304306e",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<4.0,>=3.10",
            "size": 23116,
            "upload_time": "2024-09-13T12:21:25",
            "upload_time_iso_8601": "2024-09-13T12:21:25.044248Z",
            "url": "https://files.pythonhosted.org/packages/b3/21/ed76c10dc694b9e34ca44a24ba9012a59a652a1bccea8644f157c623ad3a/typefit-1.0.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-09-13 12:21:25",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "Xowap",
    "github_project": "typefit",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "typefit"
}