2023-11-21 18:27:29 -06:00
|
|
|
|
|
|
|
Quick Start
|
|
|
|
===========
|
|
|
|
|
2024-11-24 10:13:56 -06:00
|
|
|
We have two varieties of "quick start" instructions:
|
|
|
|
|
|
|
|
* :ref:`quick-start-generated`
|
|
|
|
* :ref:`quick-start-manual`
|
|
|
|
|
|
|
|
|
|
|
|
.. _quick-start-generated:
|
|
|
|
|
|
|
|
From Generated Code
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
Note that this section describes an app based on WuttaWeb (i.e. not
|
2024-11-26 11:46:17 -06:00
|
|
|
just WuttJamaican). We'll name it "Poser" for sake of example.
|
2024-11-24 10:13:56 -06:00
|
|
|
|
2024-11-26 11:46:17 -06:00
|
|
|
Make a parent folder for all source code:
|
2024-11-24 10:13:56 -06:00
|
|
|
|
2024-11-26 11:46:17 -06:00
|
|
|
.. code-block:: sh
|
|
|
|
|
|
|
|
mkdir -p ~/src
|
|
|
|
|
|
|
|
Make a :term:`virtual environment` for your project:
|
|
|
|
|
|
|
|
.. code-block:: sh
|
2024-11-24 10:13:56 -06:00
|
|
|
|
2024-11-26 11:46:17 -06:00
|
|
|
cd /path/to/envs
|
|
|
|
python3 -m venv poser
|
2024-11-24 10:13:56 -06:00
|
|
|
|
2024-11-26 11:46:17 -06:00
|
|
|
Make a new e.g. ``poser`` database in PostgreSQL (or MySQL).
|
2024-11-24 10:13:56 -06:00
|
|
|
|
2024-11-26 11:46:17 -06:00
|
|
|
Install and run cookiecutter with wuttaweb template:
|
2024-11-24 10:13:56 -06:00
|
|
|
|
|
|
|
.. code-block:: sh
|
|
|
|
|
2024-11-26 11:46:17 -06:00
|
|
|
cd /path/to/envs/poser
|
|
|
|
bin/pip install cookiecutter
|
|
|
|
bin/cookiecutter -o ~/src git+https://forgejo.wuttaproject.org/wutta/cookiecutter-wuttaweb
|
|
|
|
|
|
|
|
Assuming you now have project code at ``~/src/poser`` then install
|
|
|
|
that and run the app installer:
|
|
|
|
|
|
|
|
.. code-block:: sh
|
2024-11-24 10:13:56 -06:00
|
|
|
|
|
|
|
bin/pip install -e ~/src/poser
|
|
|
|
bin/poser install
|
|
|
|
|
2024-11-26 11:46:17 -06:00
|
|
|
If all goes well, you can run the web app with:
|
2024-11-24 10:13:56 -06:00
|
|
|
|
|
|
|
.. code-block:: sh
|
|
|
|
|
|
|
|
bin/pserve --reload file+ini:app/web.conf
|
|
|
|
|
|
|
|
And browse it at http://localhost:9080
|
|
|
|
|
|
|
|
|
|
|
|
.. _quick-start-manual:
|
|
|
|
|
|
|
|
From Scratch
|
|
|
|
------------
|
|
|
|
|
2024-08-23 15:20:38 -05:00
|
|
|
This shows the *minimum* use case, basically how to make/use the
|
|
|
|
:term:`config object` and :term:`app handler`.
|
|
|
|
|
|
|
|
(See next section for :ref:`db-setup`.)
|
|
|
|
|
|
|
|
You should have already made a :term:`virtual environment`. Install
|
|
|
|
the package with:
|
2023-11-21 18:27:29 -06:00
|
|
|
|
|
|
|
.. code-block:: sh
|
|
|
|
|
|
|
|
pip install wuttjamaican
|
|
|
|
|
2024-08-23 15:20:38 -05:00
|
|
|
Create a :term:`config file`, e.g. ``my.conf``:
|
2023-11-21 18:27:29 -06:00
|
|
|
|
|
|
|
.. code-block:: ini
|
|
|
|
|
|
|
|
[foo]
|
|
|
|
bar = A
|
|
|
|
baz = 2
|
|
|
|
feature = true
|
|
|
|
words = the quick brown fox
|
|
|
|
|
2024-08-23 15:20:38 -05:00
|
|
|
In code, load the config and reference its values as needed, and/or
|
|
|
|
invoke other app/handler logic::
|
2023-11-21 18:27:29 -06:00
|
|
|
|
|
|
|
from wuttjamaican.conf import make_config
|
|
|
|
|
|
|
|
config = make_config('/path/to/my.conf')
|
|
|
|
|
|
|
|
# this call.. ..returns this value
|
|
|
|
|
|
|
|
config.get('foo.bar') # 'A'
|
|
|
|
|
|
|
|
config.get('foo.baz') # '2'
|
|
|
|
config.get_int('foo.baz') # 2
|
|
|
|
|
|
|
|
config.get('foo.feature') # 'true'
|
|
|
|
config.get_bool('foo.feature') # True
|
|
|
|
|
|
|
|
config.get('foo.words') # 'the quick brown fox'
|
|
|
|
config.get_list('foo.words') # ['the', 'quick', 'brown', 'fox']
|
|
|
|
|
2024-08-23 15:20:38 -05:00
|
|
|
# now for the app handler..and interacting with DB
|
|
|
|
app = config.get_app()
|
|
|
|
model = app.model
|
|
|
|
session = app.make_session()
|
|
|
|
|
|
|
|
# invoke secondary handler to make new user account
|
|
|
|
auth = app.get_auth_handler()
|
|
|
|
user = auth.make_user(session=session, username='barney')
|
|
|
|
|
|
|
|
# commit changes to DB
|
|
|
|
session.add(user)
|
|
|
|
session.commit()
|
|
|
|
|
2023-11-21 18:27:29 -06:00
|
|
|
For more info see:
|
|
|
|
|
|
|
|
* :func:`~wuttjamaican.conf.make_config()`
|
|
|
|
* :class:`~wuttjamaican.conf.WuttaConfig` and especially
|
|
|
|
:meth:`~wuttjamaican.conf.WuttaConfig.get()`
|
|
|
|
|
2024-08-23 15:20:38 -05:00
|
|
|
|
|
|
|
.. _db-setup:
|
|
|
|
|
|
|
|
Database Setup
|
2024-11-24 10:13:56 -06:00
|
|
|
~~~~~~~~~~~~~~
|
2024-08-23 15:20:38 -05:00
|
|
|
|
|
|
|
You should already have the package installed (see previous section).
|
|
|
|
|
|
|
|
You also must install some package(s) for the particular database
|
|
|
|
backend you wish to use. PostgreSQL is recommended although MySQL
|
|
|
|
etc. should also work. For instance:
|
|
|
|
|
|
|
|
.. code-block:: sh
|
|
|
|
|
|
|
|
# postgres
|
|
|
|
pip install psycopg2
|
|
|
|
|
|
|
|
# mysql
|
|
|
|
pip install mysql-connector-python
|
|
|
|
|
|
|
|
Next you must create the database, as well as any user account needed,
|
|
|
|
within the DB backend.
|
|
|
|
|
|
|
|
Now add the DB info to your :term:`config file` (e.g. ``my.conf`` as
|
|
|
|
shown above). Contents for this will look something like (using
|
|
|
|
``poserdb`` as the DB name):
|
|
|
|
|
|
|
|
.. code-block:: ini
|
|
|
|
|
|
|
|
[wutta.db]
|
|
|
|
|
|
|
|
# postgres
|
|
|
|
default.url = postgresql://USERNAME:PASSWORD@localhost/poserdb
|
|
|
|
|
|
|
|
# mysql
|
|
|
|
default.url = mysql+mysqlconnector://USERNAME:PASSWORD@localhost/poserdb
|
|
|
|
|
|
|
|
See :doc:`/narr/db/app` for more about that.
|
|
|
|
|
|
|
|
You also must add some Alembic config, needed for DB schema
|
|
|
|
migrations:
|
|
|
|
|
|
|
|
.. code-block:: ini
|
|
|
|
|
|
|
|
[alembic]
|
|
|
|
script_location = wuttjamaican.db:alembic
|
|
|
|
version_locations = wuttjamaican.db:alembic/versions
|
|
|
|
|
|
|
|
With config file updated you can run the Alembic command to migrate schema:
|
|
|
|
|
|
|
|
.. code-block:: sh
|
|
|
|
|
|
|
|
cd /path/to/env
|
|
|
|
bin/alembic -c /path/to/my.conf upgrade heads
|
|
|
|
|
|
|
|
Now you should have all the tables required for a WuttJamaican
|
|
|
|
:term:`app database`.
|