Sylvan is a flexible and scalable Flask template designed for seamless growth and easy maintenance. Built with a modular architecture using Blueprints, SQLAlchemy ORM, encryption, and hashing, Sylvan provides a strong foundation for web applications that require high performance and security. This template includes essential features like a real-time chat system and dynamic flashcards, which display various status messages, such as success, info, message, error, and danger, to enhance user experience and feedback.
To ensure high performance and low latency, Sylvan optimizes server interactions by reducing the number of HTTP requests. Static assets like HTML, CSS, and JavaScript are bundled into a single file, streamlining page loads and reducing network overhead.
Whether you're building a small-scale app or a large enterprise solution, Sylvan’s architecture is designed to scale with your needs. The integrated features can easily be extended to accommodate new functionality as your project evolves.
- Flask Blueprints: Modular structure for scaling the application by separating concerns.
- Encryption & Hashing: Secure user authentication and sensitive data handling using industry-standard techniques.
- SQLAlchemy ORM: Simplifies interaction with the database and provides a convenient, Pythonic interface.
- Flash Cards with Status: Display messages to users with various status indicators, including success, warning, error, info, and danger.
- Optimized Static Files: Minimizes HTTP requests by combining HTML, CSS, and JavaScript into a single file.
- Integrated Chat System: Real-time chat feature integrated within the app.
- Minimal Server Requests: Optimized architecture for reduced load on the server.
To get started with Sylvan, follow the steps below to set up the environment and install dependencies.
- Python: 3.12.8 recomended
-
Clone the repository:
git clone https://github.com/Gabbar-v7/Sylvan.git cd Sylvan
-
Create a virtual environment:
python -m venv env
-
Activate the virtual environment:
- Windows:
env\Scripts\activate
- Mac/Linux:
source env/bin/activate
- Windows:
-
Install dependencies:
pip install -r requirements.txt
-
Set up configuration files:
This file should only contain sensitive information such as API keys, database credentials, and encryption keys.
SQLALCHEMY_DATABASE_URI="postgresql://{dbUserName}:{dbPassword}@localhost:5432/{dbDataSet}" FLASK_SESSION_KEY="your_secure_session_key" HASH_KEY="your_secret_hash_key" FERNET_KEY=b"J3GEWEglCFMAAP5c8eWX6DrXmqJgtQsykJyHYzZSib4=" # Fernet key must be 32 URL-safe base64-encoded bytes. # Visit: https://console.cloud.google.com/ GOOGLE_CLIENT_ID = "" GOOGLE_CLIENT_SECRET = "" # Visit: https://developers.facebook.com/ FACEBOOK_CLIENT_ID="" FACEBOOK_CLIENT_SECRET=""
This file contains references to other configuration files or general settings.
[application] env_file=env.development [database] echo=true
-
Run Postgres via Docker: (Optionally use any other SQL Database)
docker run -d \ --name homeogenie \ -e POSTGRES_USER={dbUserName} \ -e POSTGRES_PASSWORD={dbPassword} \ -e POSTGRES_DB={dbDataSet} \ -v {absolute_path}:/var/lib/postgresql/data \ -p 5432:5432 \ postgres
-
Start the application:
python main.py
-
Open your browser and navigate to:
http://127.0.0.1:5000
- Login with your credentials or register as a new user (if registration is implemented).
- Interact with the app features, such as managing resources and viewing content.
Root/
├── src/
│ ├── dbModels/ # SQLAlchemy database models
│ ├── flasky/ # Flask setup, including CORS, LoginManager, etc.
│ └── security/ # Security utilities such as hashing and encryption
│
├── scripts/ # Linux build scripts
├── settings/ # Optional: Configuration files (.env, config.ini)
├── templates/ # HTML templates for the website
├── static/ # Static files (CSS, JS, images)
├── temp/ # Temporary workspace (ignored by git)
├── .gitignore # Git ignore file
├── README.md # Project documentation
├── LICENSE # License information
├── main.py # Main entry point for the application
└── requirements.txt # Dependency list
- Fork the repository.
- Create a feature branch:
git checkout -b label/update-name
. - Commit your changes:
git commit -m "your commit message"
. - Push to the branch:
git push origin label/update-name
. - Create a Pull Request on GitHub.
Note: For rough work use temp/ folder in Root directory. It is ignored by git.
This project is licensed under the MIT License.
For any issues, create a new issue in the repository.