## apicrud
[![](https://img.shields.io/pypi/v/apicrud.svg)](https://pypi.org/project/apicrud/) [![](https://images.microbadger.com/badges/image/instantlinux/example-api.svg)](https://microbadger.com/images/instantlinux/example-api "Image badge") [![](https://gitlab.com/instantlinux/apicrud/badges/main/pipeline.svg)](https://gitlab.com/instantlinux/apicrud/pipelines "pipelines") [![](https://gitlab.com/instantlinux/apicrud/badges/main/coverage.svg)](https://gitlab.com/instantlinux/apicrud/-/jobs/artifacts/main/file/apicrud/htmlcov/index.html?job=analysis "coverage") ![](https://img.shields.io/badge/platform-amd64%20arm64%20arm%2Fv6%20arm%2Fv7-blue "Platform badge") [![](https://img.shields.io/badge/dockerfile-latest-blue)](https://gitlab.com/instantlinux/apicrud/-/blob/main/example/Dockerfile.api "dockerfile")
### What is this
Skip the kubernetes / python / React.js learning curve and put your ideas in production!
The _APIcrud_ framework makes it easier to get started on full-stack development of REST-based services, ranging from a simple CLI wrapper for queries of local APIs to full web-scale consumer-facing applications running on kubernetes.
The essential components of a modern full-stack application include a back-end API server, a front-end UI server, a database, a memory-cache and a background worker for performing actions such as emailing, photo uploading or report generation. The challenge of setting up CI testing and microservice deployment is usually daunting; this repo addresses all of those issues by providing a fully-working example you can set up and start modifying in minutes. No prior experience is required.
This is the API back-end and worker, with an _example_ application.
### Usage
See the [getting started](docs/content/gettingstarted.md) page, or navigate to [Read the Docs](https://apicrud.readthedocs.io/).
### Background
The rise of Docker and Kubernetes starting around 2017 made it possible to set up these production-grade services directly on the laptop of any developer. Only recently have the tools been easier to configure and set up. This framework provides working example code you can use to get started creating your own secure, web-scale services.
Implementation/design includes these technologies: [babel](http://babel.pocoo.org/en/latest/), [celery](http://www.celeryproject.org/), [CloudFront and S3](https://aws.amazon.com/cloudfront/), [docker](https://www.docker.com/), [flask](http://flask.pocoo.org/), [kubernetes](https://kubernetes.io/), [MapQuest geocoding](https://developer.mapquest.com/documentation/open/geocoding-api/), [mapbox](https://www.mapbox.com/), [MariaDB](https://mariadb.org/), [OAuth 2.0](https://oauth.net/2/), [python 3](https://docs.python.org/3/), [OpenAPI](https://www.openapis.org/), [PyOTP](https://pyauth.github.io/pyotp/), [RabbitMQ](https://www.rabbitmq.com/), [react.js](https://reactjs.org/), [react-admin](https://marmelab.com/react-admin), [redis](https://redis.io/), [sqlalchemy](https://www.sqlalchemy.org/), [uWSGI](https://uwsgi-docs.readthedocs.io/en/latest/).
### Contributions
Your pull-requests and bug-reports are welcome here. See [CONTRIBUTING.md](CONTRIBUTING.md).
### License
Software copyright © 2021 by Richard Braun • <a href="https://www.apache.org/licenses/LICENSE-2.0">Apache 2.0</a> license <p />
Raw data
{
"_id": null,
"home_page": "https://github.com/instantlinux/apicrud",
"name": "apicrud",
"maintainer": "",
"docs_url": null,
"requires_python": ">=3.6",
"maintainer_email": "",
"keywords": "api flask rbac rest",
"author": "Rich Braun",
"author_email": "docker@instantlinux.net",
"download_url": "https://files.pythonhosted.org/packages/97/bc/da1dbc37391f2cfb64b4a7609a56e61d2a94bb0edde814f869ec321b676c/apicrud-0.3.1.tar.gz",
"platform": null,
"description": "## apicrud\n[![](https://img.shields.io/pypi/v/apicrud.svg)](https://pypi.org/project/apicrud/) [![](https://images.microbadger.com/badges/image/instantlinux/example-api.svg)](https://microbadger.com/images/instantlinux/example-api \"Image badge\") [![](https://gitlab.com/instantlinux/apicrud/badges/main/pipeline.svg)](https://gitlab.com/instantlinux/apicrud/pipelines \"pipelines\") [![](https://gitlab.com/instantlinux/apicrud/badges/main/coverage.svg)](https://gitlab.com/instantlinux/apicrud/-/jobs/artifacts/main/file/apicrud/htmlcov/index.html?job=analysis \"coverage\") ![](https://img.shields.io/badge/platform-amd64%20arm64%20arm%2Fv6%20arm%2Fv7-blue \"Platform badge\") [![](https://img.shields.io/badge/dockerfile-latest-blue)](https://gitlab.com/instantlinux/apicrud/-/blob/main/example/Dockerfile.api \"dockerfile\")\n\n### What is this\n\nSkip the kubernetes / python / React.js learning curve and put your ideas in production!\n\nThe _APIcrud_ framework makes it easier to get started on full-stack development of REST-based services, ranging from a simple CLI wrapper for queries of local APIs to full web-scale consumer-facing applications running on kubernetes.\n\nThe essential components of a modern full-stack application include a back-end API server, a front-end UI server, a database, a memory-cache and a background worker for performing actions such as emailing, photo uploading or report generation. The challenge of setting up CI testing and microservice deployment is usually daunting; this repo addresses all of those issues by providing a fully-working example you can set up and start modifying in minutes. No prior experience is required.\n\nThis is the API back-end and worker, with an _example_ application.\n\n### Usage\n\nSee the [getting started](docs/content/gettingstarted.md) page, or navigate to [Read the Docs](https://apicrud.readthedocs.io/).\n\n### Background\n\nThe rise of Docker and Kubernetes starting around 2017 made it possible to set up these production-grade services directly on the laptop of any developer. Only recently have the tools been easier to configure and set up. This framework provides working example code you can use to get started creating your own secure, web-scale services.\n\nImplementation/design includes these technologies: [babel](http://babel.pocoo.org/en/latest/), [celery](http://www.celeryproject.org/), [CloudFront and S3](https://aws.amazon.com/cloudfront/), [docker](https://www.docker.com/), [flask](http://flask.pocoo.org/), [kubernetes](https://kubernetes.io/), [MapQuest geocoding](https://developer.mapquest.com/documentation/open/geocoding-api/), [mapbox](https://www.mapbox.com/), [MariaDB](https://mariadb.org/), [OAuth 2.0](https://oauth.net/2/), [python 3](https://docs.python.org/3/), [OpenAPI](https://www.openapis.org/), [PyOTP](https://pyauth.github.io/pyotp/), [RabbitMQ](https://www.rabbitmq.com/), [react.js](https://reactjs.org/), [react-admin](https://marmelab.com/react-admin), [redis](https://redis.io/), [sqlalchemy](https://www.sqlalchemy.org/), [uWSGI](https://uwsgi-docs.readthedocs.io/en/latest/).\n\n### Contributions\n\nYour pull-requests and bug-reports are welcome here. See [CONTRIBUTING.md](CONTRIBUTING.md).\n\n### License\n\nSoftware copyright © 2021 by Richard Braun • <a href=\"https://www.apache.org/licenses/LICENSE-2.0\">Apache 2.0</a> license <p />\n",
"bugtrack_url": null,
"license": "Apache License Version 2.0",
"summary": "Flask REST framework for role-based access",
"version": "0.3.1",
"project_urls": {
"Homepage": "https://github.com/instantlinux/apicrud"
},
"split_keywords": [
"api",
"flask",
"rbac",
"rest"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "e4c9c91fb5a01173e7eeba9c08e097196943eeb59ba81b15c8e8634237b7cf31",
"md5": "aee81ec87e5a1655603cb00b6cc227c1",
"sha256": "5a56fd279adb4a0cdd711c3e33e95a8051df0723e68313789e5111283d7d7c3a"
},
"downloads": -1,
"filename": "apicrud-0.3.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "aee81ec87e5a1655603cb00b6cc227c1",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.6",
"size": 151997,
"upload_time": "2023-08-13T19:44:39",
"upload_time_iso_8601": "2023-08-13T19:44:39.833843Z",
"url": "https://files.pythonhosted.org/packages/e4/c9/c91fb5a01173e7eeba9c08e097196943eeb59ba81b15c8e8634237b7cf31/apicrud-0.3.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "97bcda1dbc37391f2cfb64b4a7609a56e61d2a94bb0edde814f869ec321b676c",
"md5": "b553d258491300c4b806e583a7fc85c7",
"sha256": "bbde01a0872bf0596e4fdce8c049232df340b3540b75f42f6f8769854b5abd46"
},
"downloads": -1,
"filename": "apicrud-0.3.1.tar.gz",
"has_sig": false,
"md5_digest": "b553d258491300c4b806e583a7fc85c7",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.6",
"size": 135275,
"upload_time": "2023-08-13T19:44:41",
"upload_time_iso_8601": "2023-08-13T19:44:41.538187Z",
"url": "https://files.pythonhosted.org/packages/97/bc/da1dbc37391f2cfb64b4a7609a56e61d2a94bb0edde814f869ec321b676c/apicrud-0.3.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-08-13 19:44:41",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "instantlinux",
"github_project": "apicrud",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "apicrud"
}