PostManager«
Content manager for all types of content, blog posts, galleries, personal records, etc.
Features - Requirements - Installation - Quick usage - Examples
Features«
-
AWS S3 storage: This means you can store your content directly to the cloud with very little configuration out of the box.
-
Local storage: Store all your content on your local system, skip cloud vulnerabilities or use for quick development purposes.
-
Easy media management: Add, Delete or Update any media associated with your content. Receive media data in a browser friendly format for easy image source display.
-
Control your meta data: Meta data each data point has meta data associated which can be in any shape. The user has complete control.
Requirements«
Operating system«
- Linux
- MacOS
- Windows
Python Version«
Python 3.9 or greater
Local Storage«
There is very little requirements for local storage
- User Read / Write privilege to home directory (true by default)
Cloud Storage«
It is necessary to have the following configured to use PostManager with AWS S3.
- AWS Account
- S3 Bucket with Read/Write access (not necessarily public)
- AWS CLI installed and configured
Installation«
With pip
:
pip install postmanager
Quick usage«
Setup«
from postmanager.manager import PostManager
blog_manager = PostManager.setup_local()
Create«
meta_data = {
"title": "Cool Blog",
"author": "Jeff"
}
content = {
"blocks":[
{"Header"}:"Cool Blog"
],
...
...
}
new_blog = blog_manager.new_post(meta_data,content)
post_manager.save_post(new_blog)
Get«
blog_id = 42
bog = blog_manager.get_by_id(blog_id)
return blog.to_json()
Delete«
blog_id = 42
blog_manager.delete_post(blog_id)
Add Media«
Note: Media format
The add_media
takes the media bytes in DataUrl format. This is the same as the value returned from JavaScript FileReader.readAsDataURL().
media = {
"name":"cover_photo",
"bytes": "...."
}
blog_id = 42
blog = blog_manager.get_by_id(blog_id)
blog.add_media(media["name"],media["bytes"])
blog_manager.save_post(blog)
Examples«
Build docs«
- Install deps
pip3 install -r requirements_docs.txt
- Run Build
mkdocs build
- Serve site directory
serve site