Skip to main content

A simple abstraction for publishing files as blog posts.

Project description

Easy Publish

Easy publish is a Python library that provides a simple abstraction for publishing text files as blog posts.

Installation

Requires: Python >= 3.6

python3 -m pip install easy-publish

Usage

To use easy publish import and call the generate_posts function pointing it to the directory your files are located in. The generate_posts function returns an object that has two useful data structures: metadata and posts. metadata is a list of metadata about each of your posts(the "Including Markdown" section explains how to include metadata). posts is a list of post objects that include the metadata as well as post content.

Below is an example flask app with jinja templating that utilizes easy publish and the metadata/post objects. While this example uses flask/jinja, any web framework/templating engine should work with easy publish.

app.py

from flask import Flask, render_template
from easy_publish import generate_posts

app = Flask(__name__)
posts = generate_posts("~/my/blogposts")

@app.route("/blog")
def blog():
  return render_template("blog.html", metadata=posts.metadata)

@app.route("/blog/<p>")
def blogpost(p):
  return render_template("post.html", post=posts.posts[p])

blog.html

{{% for post in metadata %}}
  <li>{{ post.title }}</li>
  <li>{{ post.date }}</li>
  <li>{{ post.tags }}</li>
  <li>{{ post.author }}</li>
{{% endfor %}}

post.html

<h1>{{ post.title }}</h1>
<h4>{{ post.date }}</h1>
<h4>{{ post.author }}</h1>
<p>{{ post.content }}</p>

Including Metadata

Easy publish currently expects text files to have a field at the top denoting the metadata. The field must be in the following format:

~
title: title would go here
date: date would go here
tags: tags, would, go, here (comma separated)
author: author would go here
~

The parser looks for information in between the ~'s and strips it out into the metadata. It's on the list of TODO's to add different ways to include metadata.

Contributing

Currently in heavy development and not a stable interface. Feel free to contribute ideas as issues or as a pull request.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

easy-publish-0.0.5.tar.gz (5.1 kB view hashes)

Uploaded Source

Built Distributions

easy_publish-0.0.5-py3-none-any.whl (5.4 kB view hashes)

Uploaded Python 3

easy_publish-0.0.5-py2.py3-none-any.whl (5.4 kB view hashes)

Uploaded Python 2 Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page