A simple blog platform built with Flask, SQLAlchemy, and SQLite. The platform supports user authentication and allows users to create, read, update, and delete blog posts.
- User authentication (sign up, sign in)
- Create, read, update, and delete blog posts
- Basic HTTP authentication for protected routes
- SQLite database for data persistence
- Clone the repository:
git clone https://github.com/EvianTan/blog-platform.git cd blog-platform
- Set up a virtual environment (Optional but recommended):
python -m venv venv source venv/bin/activate # On Windows use `venv\Scripts\activate`
- Install dependencies:
Note: Ensure Python and
pip
are installed on your system. If not, download and install Python from python.org.pip install -r requirements.txt
- Configure the application:
Create a
config.py
file in the root directorywith the following content:Or you can useimport os class Config: SECRET_KEY = os.environ.get('SECRET_KEY') or 'a_secret_key' SQLALCHEMY_DATABASE_URI = os.environ.get('DATABASE_URL') or 'sqlite:///instance/blogging_platform.db' SQLALCHEMY_TRACK_MODIFICATIONS = False
config-example.py
as an example - Set up the database:
flask db init flask db migrate -m "Initial migration" flask db upgrade
- Seed the database with initial testing data (optional):
Note: Populating the database with initial users and posts data
python seed.py
- Run the application:
flask run
- Access the application:
Open your browser and go to
http://127.0.0.1:5000
. - Test API Endpoints with Postman:
- Import the Postman collection
(Python Flask Blog Platform.postman_collection.json
) into your Postman application. - Modify the requests as needed to suit your testing or integration requirements.
- Import the Postman collection
- Sign up a new user:
POST /auth/signup
{ "username": "yourusername", "password": "yourpassword" }
- Sign in an existing user:
POST /auth/signin
- Use Basic Auth with your username and password.
- Create a new post:
POST /posts
{ "title": "Post Title", "body": "Post Body" }
- Protected route, requires authentication.
- Retrieve All Posts:
GET /posts
- Retrieve a specific post by ID:
GET /posts/<id>
- Protected route, requires authentication.
- Update an existing post by ID:
PUT /posts/<id>
{ "title": "Updated Title", "body": "Updated Body" }
- Protected route, requires authentication.
- Delete a post by ID:
DELETE /posts/<id>
- Protected route, requires authentication.
- Set up the test environment:
- Ensure your virtual environment is activated.
- Install the required dependencies if you haven't already:
pip install -r requirements.txt
- Run tests:
python -m unittest discover tests
- Database Errors:
- Ensure SQLALCHEMY_DATABASE_URI points to the correct database file.
- Run
flask db migrate
to test schema changes - If you encounter missing tables, run
flask db upgrade
to apply migrations.
- Authentication Issues:
- Use Basic Auth for protected routes.
- Clear browser cache to test authentication changes.
- Environment Setup:
- Ensure your virtual environment is activated before running commands.
- Install all dependencies listed in requirements.txt.
- Flask Documentation
- Flask-SQLAlchemy Documentation
- Flask-Migrate Documentation
- Flask-HTTPAuth Documentation
- Virtual Environments
- pip Documentation
- SQLite Documentation
- Postman Documentation
This project is licensed under the MIT License.
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
- The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
- The software is provided "as is", without warranty of any kind, express or implied, including but not limited to the warranties of merchantability, fitness for a particular purpose and noninfringement. In no event shall the authors or copyright holders be liable for any claim, damages or other liability, whether in an action of contract, tort or otherwise, arising from, out of or in connection with the software or the use or other dealings in the software.
For more details, see the LICENSE file.