Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/stopspazzing/Sanic-MDL-Blog

An async Python server running Material Design Lite Blog template
https://github.com/stopspazzing/Sanic-MDL-Blog

async async-python asynchronous blog material-design-lite mdl python sanic server

Last synced: 2 months ago
JSON representation

An async Python server running Material Design Lite Blog template

Awesome Lists containing this project

README

        

[![Codacy Badge](https://api.codacy.com/project/badge/Grade/a6bd96eca22d4711a708db80a9b42e63) ](https://www.codacy.com/app/stopspazzing/Sanic-Server-with-MDL-Blog-Template?utm_source=github.com&utm_medium=referral&utm_content=stopspazzing/Sanic-Server-with-MDL-Blog-Template&utm_campaign=Badge_Grade)
# Material Design Lite Blog Using Sanic
A [Sanic](https://github.com/channelcat/sanic) ([asynchronous](http://stackoverflow.com/questions/748175/asynchronous-vs-synchronous-execution-what-does-it-really-mean)) server running with the [blog template](https://getmdl.io/templates/blog/) from [Material Design Lite](https://getmdl.io/) . Eventually will become a 'live' blog template with an [admin dashboard](https://getmdl.io/templates/dashboard/index.html).

## Prerequisites
You need several packages first for all pip packages to completely install.

NOTICE:

Working on Windows with Visual C++ v14 installed. Please use instructions here: https://www.scivision.dev/python-windows-visual-c-14-required/

So here is a list of packages required:
```
python & python-dev >=3.6
```

## Installation

`pip install -r requirements.txt`

## Configuration

100% following Sanic's import from config:
http://sanic.readthedocs.io/en/latest/sanic/config.html#from-a-file
For Database connection urls, use https://docs.sqlalchemy.org/en/13/core/engines.html#database-urls

Database type names:
```
sqlite
mysql
postgresql
```

Example config:
```
DB_URI = 'sqlite:///app.db'
DB_TYPE = 'sqlite'
DEMO_CONTENT = False
```

Either you can create a config file `config.py` file in same directory as `main.py` or you may load the program with the location of the file to variable config_file like so:
```
MY_SETTINGS=/path/to/config_file python3 main.py
```

## Starting Server

To start the server: `python3 run.py`

To access server: http://127.0.0.1:8000

## TODO

1. Finish Database support
2. Admin Page completion
3. Possibly most common plugins for Wordpress sites (Contact Forms, Yoast) as built in features you could enable.