Skip to content

Latest commit

 

History

History
175 lines (107 loc) · 7.09 KB

readme.md

File metadata and controls

175 lines (107 loc) · 7.09 KB

Tutorial Setup

OK, your project is created and open. You must first Establish Your Python Environment to run the Tutorial.

  1. Execute the Setup and Run procedure below, then
  2. Open the Tutorial

The standard API Logic Project Readme is included, below.

 


 

 

Readme - API Logic Project

This API Logic Project was created by the API Logic Server with the ApiLogicServer create command.

Edit / extend this readme as desired.

  

Setup and Run

To run your project, the system requires various runtime systems for data access, api, and logic. These are included with API Logic Server. So, to run your project:

  1. Establish your Python Environment to activate these runtime systems
    • Choose the either the Local Install or the Docker approach below, then
  2. Run

 

Establish Your Python Environment - Local Install

You requirements.txt has already been created, so...

python -m venv venv                        # may require python3 -m venv venv
venv\Scripts\activate                      # mac/linux: source venv/bin/activate
python -m pip install -r requirements.txt  # accept "new Virtual environment"

Notes:

  • See also the venv_setup directory in this API Logic Project.

  • If using SqlServer, install pyodbc. Not required for docker-based projects. For local installs, see the Quick Start.

 

Establish Your Python Environment - Docker

Your runtime systems are part of Dev Container, which you probably activated when you opened the project. If you did not accept the "Open in Container" option when you started VSCode, use View > Command Palette > Remote-Containers: Reopen in Container.

 

Run

To run your project:

  • Start the API, either by IDE launch configurations (see below), or by command line: python api_logic_server_run.py.

  • Open the Admin App - either

    • Open your Browser at http://localhost:5656, or

    • Open in VSCode's Simple Browser (as shown below):

      1. Click View > Command to open the Command Palette
        • Enter command: Simple Browser: Show
        • Specify the URL: http://localhost:5656
      2. Explore the swagger - open another simple Browser with URL http://localhost:5656/api
        • Note: you can drag windows to arrange your viewing area

  

Project Information

About Info
Created August 01, 2022 21:44:08
API Logic Server Version 5.03.27
Created in directory /localhost/ApiLogicProject-GitHub
API Name api

  

Key Technologies

API Logic Server is based on the projects shown below. Consult their documentation for important information.

SARFS JSON:API Server

SAFRS: Python OpenAPI & JSON:API Framework

SAFRS is an acronym for SqlAlchemy Flask-Restful Swagger. The purpose of this framework is to help python developers create a self-documenting JSON API for sqlalchemy database objects and relationships.

These objects are serialized to JSON and created, retrieved, updated and deleted through the JSON API. Optionally, custom resource object methods can be exposed and invoked using JSON.

Class and method descriptions and examples can be provided in yaml syntax in the code comments.

The description is parsed and shown in the swagger web interface. The result is an easy-to-use swagger/OpenAPI and JSON:API compliant API implementation.

LogicBank

Transaction Logic for SQLAlchemy Object Models

Use Logic Bank to govern SQLAlchemy update transaction logic - multi-table derivations, constraints, and actions such as sending mail or messages. Logic consists of both:

  • Rules - 40X more concise using a spreadsheet-like paradigm, and

  • Python - control and extensibility, using standard tools and techniques

Logic Bank is based on SQLAlchemy - it handles before_flush events to enforce your logic. Your logic therefore applies to any SQLAlchemy-based access - JSON:Api, Admin App, etc.

SQLAlchemy

Object Relational Mapping for Python.

SQLAlchemy provides Python-friendly database access for Python.

It is used by JSON:Api, Logic Bank, and the Admin App.

SQLAlchemy processing is based on Python model classes, created automatically by API Logic Server from your database, and saved in the database directory.

Admin App

This generated project also contains a React Admin app:

  • Multi-page - including page transitions to "drill down"
  • Multi-table - master / details (with tab sheets)
  • Intelligent layout - favorite fields first, predictive joins, etc
  • Logic Aware - updates are monitored by business logic

  

Project Structure

This project was created with the following directory structure:

Directory Usage Key Customization File Typical Customization
api JSON:API api/customize_api.py Add new end points / services
database SQLAlchemy Data Model Classes database/customize_models.py Add derived attributes, and relationships missing in the schema
logic Transactional Logic logic/declare_logic.py Declare multi-table derivations, constraints, and events such as send mail / messages
ui Admin App ui/admin/admin.yaml Control field display - order, captions etc.
tests Behave Test Suite tests/api_logic_server_behave/features Declare and implement Behave Tests
 

Key Customization File - Typical Customization

In the table above, the Key Customization Files are created as stubs, intended for you to add customizations that extend the created API, Logic and Web App. Since they are separate files, the project can be rebuilt (e.g., synchronized with a revised schema), preserving your customizations.

Please see the nw sample for examples of typical customizations.