Helper module for Frozen-Flask based websites
Project description
Elsa will help you build your Frozen-Flask based website and deploy it to GitHub pages. It’s based on scripts from PyLadies.cz repo and is distributed under the terms of the MIT license, see LICENSE (does not apply for the image below). It requires Python 3.
Basic usage
Create you Flask app and give it to elsa.cli():
from flask import Flask
app = Flask(...)
# do stuff with app
if __name__ == '__main__':
from elsa import cli
cli(app, base_url='https://example.com')
This will add command line interface to the script, enabling you to use it like this:
python foo.py serve # serves the site, no freezing, so you can check it quickly
python foo.py freeze # freezes the site, i.e. makes a HTML snapshot
python foo.py deploy # deploys the frozen site to GitHub pages
See more options with --help.
Travis CI based deployment
Travis CI is (in this context) a tool, that allows you to deploy the site automatically to GitHub pages after every push. All you have to do is tell Travis to run Elsa and provide a GitHub token. Elsa on Travis will freeze the site and deploy it frozen to GitHub pages. Elsa knows it’s being run on Travis and will use the provided GitHub token to gain push permissions. Elsa will push force to gh-pages branch in a single commit rewriting the history and all manual changes of that branch.
Here is an example .travis.yml file for automatic deployment. It assumes elsa and other requirements are in requirements.txt and that you are familiar with Travis CI (so it’s not very verbose):
language: python
python:
- '3.5'
script:
- "echo 'No linters, no tests...'"
env:
global:
- secure: "blahblah" # gem install travis; travis encrypt GITHUB_TOKEN=xyz --add
deploy:
provider: script
script: 'python foo.py deploy'
on:
branch: master
repo: only/yours
Further notes
URLs
When you use URLs without trailing slash (e.g. https://example.com/foobar), GitHub pages will serve the pages with bad Content-Type header (application/octet-stream instead of text/html) and the browser will attempt to download it. Make sure to use URLs with trailing slash (e.g. https://example.com/foobar/) instead, so Frozen-Flask will create index.html in a folder and GitHub pages will use proper content type.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file elsa-0.1.dev3.tar.gz
.
File metadata
- Download URL: elsa-0.1.dev3.tar.gz
- Upload date:
- Size: 5.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4eb47c7ffe1515ed63bc1a73552706acf4acd31adecc3325aebec5e21cf4c90d |
|
MD5 | 700ce29a6d37821ea61430d6679beb7d |
|
BLAKE2b-256 | f6b36f8f32cf364d93d2b3f9dd8f330f6d6146c171294e6336881866e15f9b39 |
Provenance
File details
Details for the file elsa-0.1.dev3-py3-none-any.whl
.
File metadata
- Download URL: elsa-0.1.dev3-py3-none-any.whl
- Upload date:
- Size: 7.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4fe4d2898f9462a1949ca635bc6b3ce6a18fe6b881ec68c01b5fefa41f493928 |
|
MD5 | 90b006a9557bdf3306277b4537014115 |
|
BLAKE2b-256 | 45cef35e31fcf1b9ed0fa23933522cb11bb120ee80b05ad3a3a55805a154c7aa |