zix - Create your SaaS app quickly by adding plugins!
Project description
zix
FastAPI based web app framework.
Introduction
I wanted to build a web app with frontend, backend, database, login, email services, and paywall very quickly.
Since those are common skeleton for most SaazS apps, I built a plugin framework to build apps quickly.
Prereqs
- Python 3.8 or later is installed
Install
Make and activate a Python environment:
python -m venv venv
source ./venv/bin/activate
pip install -U pip
pip install zixweb
Create an app
zix init -w myapp
cd myapp
pip install -r requirement.txt
pip install -r requirement_dev.txt
requirement.txt contains the modules required for running the app. requirement_dev.txt contains the modules required for developing the app.
The rest of the document assumes your project is in myapp
directory.
Create tables
By default, it will run Sqlite and creates zix.db file in the project root directory.
alembic revision --autogenerate -m "initial models"
alembic upgrade head
Set up env.yml file
From the project root, do:
mkdir .env
cp env.yml .env
Open .env/env.yml at the root project directory.
To use Auth0 login, sign up (should be free) at https://auth0.com
To try the test app,
- Go to Applications from the left menu and select Default App.
- Copy and Domain, Client ID and Client Secret and paste them into env.yml file into the corresponding fields.
- Set Application Type to "Regular Web Application."
- Enter "http://localhost:4000" to Allowed Callback URLs, Allowed Logout URLs, and Allowed Web Origins
- Click Save
Run app
Go to the project root directory and run:
zix -w . -p 4000 -e .env/env.yml serve
Point browser to http://localhost:4000
Frontend and static files
Try modifying myapp/static/compiled/index.html
and run the server again.
Place frontend and static files under myapp/static/compiled
Anything under compiled folder is served under /
as long as the path is not taken by the API endpoints you define.
Vanilla Bootstrap Studio project
Under the myapp directory, you'll find bstudio directory. If you have an active license of Bootstrap Studio, you can open this project.
Go to Export Settings on Bootstrap Studio and set the export path
to myapp/static/compiled
. Then export.
Run the server again. Now you have an (empty) webapp UI.
Add endpoints
Take a look at myapp/plugins/core/routers.py
and myapp/plugins/web/routers.py
.
You can add your service under plugins directory.
Third-party services
In coming release of zix, I'm going to add the complete code to leverage these third-party services:
Auth0 (login)
To be written
Stripe (payment)
To be written
SendGrid (email)
To be written
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file zixweb-0.1.4.tar.gz
.
File metadata
- Download URL: zixweb-0.1.4.tar.gz
- Upload date:
- Size: 1.8 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 348c51894e09fb34a4317d7b0e36288213e0aee52218da7560287d27b4680f05 |
|
MD5 | efee3e7e137b7f720e5474de1e1a2cfe |
|
BLAKE2b-256 | 997120637d62372e2e7df25a979e4e03cd472a10e2f7c4babe2a71be9ce039c7 |
File details
Details for the file zixweb-0.1.4-py3-none-any.whl
.
File metadata
- Download URL: zixweb-0.1.4-py3-none-any.whl
- Upload date:
- Size: 1.8 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3f9717ac2d53c6051fe39bbdd268636c3855d65b039a577efa64b33c774c05db |
|
MD5 | 2992b076a80c4d64c82082dd314d0d2f |
|
BLAKE2b-256 | dff6a2c02d82e6337b9d4aa1b6bd1b67e65a4c2ba21c2a8f1d2eb3bfcf9124dc |