diff --git a/docs/project-generation.md b/docs/project-generation.md new file mode 100644 index 000000000..707963102 --- /dev/null +++ b/docs/project-generation.md @@ -0,0 +1,42 @@ +There is a project generator that you can use to get started, with a lot of the initial set up, security, database and first API endpoints already done for you. + +## Full-Stack-FastAPI-Couchbase + +GitHub: https://github.com/tiangolo/full-stack-fastapi-couchbase + +### Features + +* Full **Docker** integration (Docker based). +* Docker Swarm Mode deployment. +* **Docker Compose** integration and optimization for local development. +* **Production ready** Python web server using Uvicorn and Gunicorn. +* Python **FastAPI** backend with all its features. +* **Celery** worker that can import and use code from the rest of the backend selectively (you don't have to install the complete app in each worker). +* **NoSQL Couchbase** database that supports direct synchronization via Couchbase Sync Gateway for offline-first applications. +* **Full Text Search** integrated, using Couchbase. +* REST backend tests based on Pytest, integrated with Docker, so you can test the full API interaction, independent on the database. As it runs in Docker, it can build a new data store from scratch each time (so you can use ElasticSearch, MongoDB, or whatever you want, and just test that the API works). +* Easy Python integration with **Jupyter** Kernels for remote or in-Docker development with extensions like Atom Hydrogen or Visual Studio Code Jupyter. +* **Email notifications** for account creation and password recovery, compatible with: + * Mailgun + * SparkPost + * SendGrid + * ...any other provider that can generate standard SMTP credentials. +* **Vue** frontend: + * Generated with Vue CLI. + * **JWT Authentication** handling. + * Login view. + * After login, main dashboard view. + * Main dashboard with user creation and edition. + * Self user edition. + * **Vuex**. + * **Vue-router**. + * **Vuetify** for beautiful material design components. + * **TypeScript**. + * Docker server based on **Nginx** (configured to play nicely with Vue-router). + * Docker multi-stage building, so you don't need to save or commit compiled code. + * Frontend tests ran at build time (can be disabled too). + * Made as modular as possible, so it works out of the box, but you can re-generate with Vue CLI or create it as you need, and re-use what you want. +* Flower for Celery jobs monitoring. +* Load balancing between frontend and backend with **Traefik**, so you can have both under the same domain, separated by path, but served by different containers. +* Traefik integration, including Let's Encrypt **HTTPS** certificates automatic generation. +* GitLab **CI** (continuous integration), including frontend and backend testing. diff --git a/docs/tutorial/dependencies/second-steps.md b/docs/tutorial/dependencies/second-steps.md index 1acefca8f..aa7197265 100644 --- a/docs/tutorial/dependencies/second-steps.md +++ b/docs/tutorial/dependencies/second-steps.md @@ -28,7 +28,7 @@ Create a model for the common parameters (and don't pay attention to the rest, f Now we can return a Pydantic model from the dependency ("dependable") with the same data as the dict before: -```Python hl_lines="18" +```Python hl_lines="17" {!./src/dependencies/tutorial002.py!} ``` @@ -42,7 +42,7 @@ commons: CommonQueryParams = Depends(common_parameters) It won't be interpreted as a JSON request `Body` because we are using `Depends`: -```Python hl_lines="22" +```Python hl_lines="21" {!./src/dependencies/tutorial002.py!} ``` @@ -55,7 +55,7 @@ It won't be interpreted as a JSON request `Body` because we are using `Depends`: And now we can use that model in our code, with all the lovable editor support: -```Python hl_lines="24 25 26" +```Python hl_lines="23 24 25" {!./src/dependencies/tutorial002.py!} ``` diff --git a/docs/tutorial/nosql-databases.md b/docs/tutorial/nosql-databases.md index 09ee64dc6..29387f8c1 100644 --- a/docs/tutorial/nosql-databases.md +++ b/docs/tutorial/nosql-databases.md @@ -10,6 +10,9 @@ You can adapt it to any other NoSQL database like: * **ArangoDB** * **ElasticSearch**, etc. +!!! tip + There is an official project generator with **FastAPI** and **Couchbase**, all based on **Docker**, including a frontend and more tools: https://github.com/tiangolo/full-stack-fastapi-couchbase + ## Import Couchbase components For now, don't pay attention to the rest, only the imports: @@ -49,7 +52,7 @@ This utility function will: * Set defaults for timeouts. * Return it. -```Python hl_lines="13 14 15 16 17 18 19 20" +```Python hl_lines="13 14 15 16 17 18 19 20 21 22" {!./src/nosql_databases/tutorial001.py!} ``` @@ -61,7 +64,7 @@ As **Couchbase** "documents" are actually just "JSON objects", we can model them First, let's create a `User` model: -```Python hl_lines="23 24 25 26 27" +```Python hl_lines="25 26 27 28 29" {!./src/nosql_databases/tutorial001.py!} ``` @@ -75,7 +78,7 @@ This will have the data that is actually stored in the database. We don't create it as a subclass of Pydantic's `BaseModel` but as a subclass of our own `User`, because it will have all the attributes in `User` plus a couple more: -```Python hl_lines="30 31 32" +```Python hl_lines="32 33 34" {!./src/nosql_databases/tutorial001.py!} ``` @@ -96,7 +99,7 @@ Now create a function that will: By creating a function that is only dedicated to getting your user from a `username` (or any other parameter) independent of your path operation function, you can more easily re-use it in multiple parts and also add unit tests for it: -```Python hl_lines="35 36 37 38 39 40 41" +```Python hl_lines="37 38 39 40 41 42 43" {!./src/nosql_databases/tutorial001.py!} ``` @@ -131,7 +134,7 @@ UserInDB(username="johndoe", hashed_password="some_hash") ### Create the `FastAPI` app -```Python hl_lines="45" +```Python hl_lines="47" {!./src/nosql_databases/tutorial001.py!} ``` @@ -141,7 +144,7 @@ As our code is calling Couchbase and we are not using the threads", so, we can get just get the bucket directly and pass it to our utility functions: -```Python hl_lines="48 49 50 51 52" +```Python hl_lines="50 51 52 53 54" {!./src/nosql_databases/tutorial001.py!} ``` diff --git a/docs/tutorial/sql-databases.md b/docs/tutorial/sql-databases.md index 7b83a1565..ef5a2b6c6 100644 --- a/docs/tutorial/sql-databases.md +++ b/docs/tutorial/sql-databases.md @@ -1,6 +1,6 @@ **FastAPI** doesn't require you to use a SQL (relational) database. -But you can use relational database that you want. +But you can use any relational database that you want. Here we'll see an example using SQLAlchemy. @@ -69,13 +69,13 @@ That way you don't have to declare them explicitly. So, your models will behave very similarly to, for example, Flask-SQLAlchemy. -```Python hl_lines="15 16 17 18 19" +```Python hl_lines="16 17 18 19 20" {!./src/sql_databases/tutorial001.py!} ``` ## Create the SQLAlchemy `Base` model -```Python hl_lines="22" +```Python hl_lines="23" {!./src/sql_databases/tutorial001.py!} ``` @@ -85,7 +85,7 @@ Now this is finally code specific to your app. Here's a user model that will be a table in the database: -```Python hl_lines="25 26 27 28 29" +```Python hl_lines="26 27 28 29 30" {!./src/sql_databases/tutorial001.py!} ``` @@ -93,7 +93,7 @@ Here's a user model that will be a table in the database: By creating a function that is only dedicated to getting your user from a `username` (or any other parameter) independent of your path operation function, you can more easily re-use it in multiple parts and also add unit tests for it: -```Python hl_lines="32 33" +```Python hl_lines="33 34" {!./src/sql_databases/tutorial001.py!} ``` @@ -103,7 +103,7 @@ Now, finally, here's the standard **FastAPI** code. Create your app and path operation function: -```Python hl_lines="37 40 41 42 43" +```Python hl_lines="38 41 42 43 44" {!./src/sql_databases/tutorial001.py!} ``` @@ -131,7 +131,7 @@ user = get_user(username, db_session) Then we should declare the path operation without `async def`, just with a normal `def`: -```Python hl_lines="41" +```Python hl_lines="42" {!./src/sql_databases/tutorial001.py!} ``` diff --git a/mkdocs.yml b/mkdocs.yml index 26cd6f9bc..d96403016 100644 --- a/mkdocs.yml +++ b/mkdocs.yml @@ -54,6 +54,7 @@ nav: - Extra Starlette options: 'tutorial/extra-starlette.md' - Concurrency and async / await: 'async.md' - Deployment: 'deployment.md' + - Project Generation - Template: 'project-generation.md' markdown_extensions: - markdown.extensions.codehilite: