- π Table of Contents
- π Overview
- π« Features
- π Project Structure
- 𧩠Modules
- π Getting Started
- πΊ Roadmap
- π€ Contributing
- π License
- π Acknowledgments
The tech-sheet-app is a Flask-based web application with a PostgreSQL database that allows users to create, read, and update app details. The app details include ID, URL, name, description, front-end and back-end technology, database technology, author, and GitHub URL. The project provides a reliable and scalable solution for managing app details and offers value by allowing users to quickly access and update details for their apps in a central location. Additionally, the project includes robust security measures, such as Go-Auth server verification, to ensure app details are only accessible by authorized users.
Feature | Description |
---|---|
π Structure and Organization | The codebase follows a standard directory structure with scripts for deployment and setups, a Dockerfile for the Flask app, and a separate directory for the PostgreSQL setup. The Flask app directory follows a modular design pattern with separate files for database helper functions, console logging, and the main Flask API code. |
π Code Documentation | The code is generally well-documented, with comments explaining the purpose and functionality of most functions and scripts in the codebase. Docstrings are also present in some modules, though not consistently throughout. |
𧩠Dependency Management | Dependencies are handled using a requirements.txt file for the Flask app and a Dockerfile for the PostgreSQL setup, with both listing the necessary packages and versions. |
β»οΈ Modularity and Reusability | The Flask app is designed with modularity in mind, with separate files for database helper functions, logging, and the main Flask API code. The PostgreSQL setup is similarly separated into its own directory. Helper functions and SQL queries are designed for reusability across the Flask app endpoints. |
βοΈ Testing and Quality Assurance | No testing or quality assurance code is present in the repository for the moment. |
π Security Measures | The Flask app includes integration with an authentication server to verify permissions before allowing updates. The database setup includes granting necessary privileges to a user for the app details table. |
π Version Control and Collaboration | The codebase uses Git for version control, with frequent commits and descriptive commit messages. Collaboration is not apparent as there is only one contributor in the repository. |
π External Integrations | The Flask app includes integration with a Go-Auth server for authentication. The Docker containers for the Flask app and the PostgreSQL database may also be integrated with external tools and services. |
π Scalability and Extensibility | The modular design of the Flask app and PostgreSQL setup allows for easy extension and modification of app details functionality. |
repo
βββ LICENSE
βββ README.md
βββ flask-app
βΒ Β βββ Dockerfile
βΒ Β βββ app
βΒ Β βΒ Β βββ api
βΒ Β βΒ Β βΒ Β βββ api.json
βΒ Β βΒ Β βΒ Β βββ api.yaml
βΒ Β βΒ Β βββ app.py
βΒ Β βΒ Β βββ console_logger.py
βΒ Β βΒ Β βββ psql_helper.py
βΒ Β βββ requirements.txt
βββ postgresql-db
βΒ Β βββ Dockerfile
βΒ Β βββ setup.sql
βΒ Β βββ setup_template.sql
βββ scripts
βββ deploy_api.sh
βββ deploy_db.sh
βββ prepare_db_setup.sh
βββ prepare_env.sh
5 directories, 16 files
App
File | Summary | Module |
---|---|---|
psql_helper.py | The code snippet provides functions to establish a connection to a PostgreSQL database, set up keys to be used in CRUD operations, and generate SQL queries for create, read (by ID and count), and update operations on app entries in the database. The app details include ID, URL, name, description, front-end and back-end technology, database technology, author, and GitHub URL. The queries use environment variables to retrieve database connection details and table name. | flask-app/app/psql_helper.py |
app.py | The code is a Flask API for creating, reading, and updating app details stored in a PostgreSQL database. The API endpoints allow GET and POST requests, with GET returning the details of a specified app and POST allowing the creation or updating of the app details. The code also includes connection to a Go-Auth server to verify permissions before allowing updates. | flask-app/app/app.py |
console_logger.py | The code initializes a logger named "APP_DETAILS_API" with a debug level. Then, it creates a console handler with an info level and a formatter for log messages. Finally, the console handler is added to the logger to output log messages to the console. | flask-app/app/console_logger.py |
Flask-app
File | Summary | Module |
---|---|---|
Dockerfile | The code snippet sets up a Docker container running Python 3.10 with Flask. It installs the necessary requirements, sets environment variables for a PostgreSQL database connection, and exposes port 3500 for the Flask server to run on. Finally, it runs the Flask app with the command "flask run". | flask-app/Dockerfile |
Postgresql-db
File | Summary | Module |
---|---|---|
setup.sql | The provided code snippet performs the following tasks in a PostgreSQL database: creates a database if it does not exist, lists all databases, connects to a specific database, creates a user if not already exists, grants necessary privileges to the user, creates a table if it does not exist, and grants necessary privileges to the user for the table. It also provides the command to list all tables and show details of a specific table. | postgresql-db/setup.sql |
Dockerfile | The provided code snippet sets up a Postgres container with environment variables for database initialization and usage. It copies a setup.sql file to the container's entrypoint init directory for database setup. Finally, it exposes the Postgres port 5432. | postgresql-db/Dockerfile |
setup_template.sql | The code snippet creates a PostgreSQL database, a table, and a user with the necessary privileges. It also checks if the database, the table, and user exist, and grants necessary privileges to the user. Finally, it lists all databases and tables in the database. | postgresql-db/setup_template.sql |
Scripts
File | Summary | Module |
---|---|---|
prepare_db_setup.sh | This code snippet is a bash script that sources another script called "prepare_env.sh" and reads data from a setup_with_vars.sql file. It then replaces environment variable placeholders with their corresponding values and writes the output to a setup.sql file. The purpose appears to be to prepare a PostgreSQL database environment with the necessary configurations. | scripts/prepare_db_setup.sh |
deploy_api.sh | The code snippet prepares the environment using a shell script, builds and pushes a Docker image, and deploys it as a Docker container on port 3500 with environment variables set for PostgreSQL database and authentication. The container is named "APPDETAILS-API-LOCAL". | scripts/deploy_api.sh |
prepare_env.sh | The code snippet sets environment variables for a PostgreSQL admin database, app details information, and an auth server. The variables include database credentials, table name, server host and port, and authentication server URL. The purpose is to provide necessary information and credentials for executing queries and accessing resources within a PostgreSQL database and an authentication server. | scripts/prepare_env.sh |
deploy_db.sh | This code snippet is a Bash script that builds and runs a Docker container named "APPDETAILS-PSQL-LOCAL" which hosts a PostgreSQL database locally. The script also sets environment variables required for the database setup. The Docker container is built from a Dockerfile located in the "../postgresql-db" directory. | scripts/deploy_db.sh |
- Clone the tech-sheet-app repository:
git clone ../tech-sheet-app
- Change to the project directory:
cd tech-sheet-app
- Install the dependencies:
chmod +x main.sh
./main.sh
bats *.bats
Contributions are always welcome! Please follow these steps:
- Fork the project repository. This creates a copy of the project on your account that you can modify without affecting the original project.
- Clone the forked repository to your local machine using a Git client like Git or GitHub Desktop.
- Create a new branch with a descriptive name (e.g.,
new-feature-branch
orbugfix-issue-123
).
git checkout -b new-feature-branch
- Make changes to the project's codebase.
- Commit your changes to your local branch with a clear commit message that explains the changes you've made.
git commit -m 'Implemented new feature.'
- Push your changes to your forked repository on GitHub using the following command
git push origin new-feature-branch
- Create a pull request to the original repository. Open a new pull request to the original project repository. In the pull request, describe the changes you've made and why they're necessary. The project maintainers will review your changes and provide feedback or merge them into the main branch.
This project is licensed under the Apache-2.0
License. See the LICENSE file for additional info.
- Personal Project
This awesome documentation was automatically generated using the README-AI Project