Skip to content

Ashwinning/Gist-Wordpress-Sync

Repository files navigation

Gist-Wordpress-Sync

A Python application to sync Gists with WordPress.

Example : http://hacks.ash.wine

Requirements

Usage

  1. Clone or download this repository.
  2. Rename the .setting.example file to .setting and configure the variables.
    Example:
WORDPRESS_URL=http://my-wordpress-blog.com
WORDPRESS_USERNAME=wordpress_username
WORDPRESS_PASSWORD=wordpress_pasword
GITHUB_USERNAME=github_username
  1. Optionally you can add a GITHUB_ACCESS_TOKEN (for higher rate limits etc.) and a WORDPRESS_CATEGORY if you want to sync content with a particular category in your blog.
  2. In the description of the gists you want to sync, add #gistblog.
  3. You can additionally add other hashtags to your description, those will be parsed over to Wordpress as tags for the post.
  4. In your wordpress header, link the CSS required to correctly highlight/display code snippets and content.
<link crossorigin="anonymous" href="https://assets-cdn.github.com/assets/frameworks-31e369ccd2b23a1eccde83f03ef36eafff1f7b9025f6042ccac33a7915753de2.css" integrity="sha256-MeNpzNKyOh7M3oPwPvNur/8fe5Al9gQsysM6eRV1PeI=" media="all" rel="stylesheet" />
<link crossorigin="anonymous" href="https://assets-cdn.github.com/assets/github-f52c8c687f8b759e77e94e3641edb1c5f49d6e8e0738ef162a66361316566cff.css" integrity="sha256-9SyMaH+LdZ536U42Qe2xxfSdbo4HOO8WKmY2ExZWbP8=" media="all" rel="stylesheet" />
  1. Run python Gist-Wordpress-Sync-2.py

Notes

The biggest downside currently is that the application needs to be manually invoked everytime changes need to be synced. (This is because webhooks/events are not available on gists.)

In the future, this app could potentially be compiled and bundled as a wordpress plugin, which can then be run as cron job to sync posts and gists.

Function Reference

GistPost()

The class that hold data collected from gists, to be put into WordPress post objects to be posted.

  • updated_at is used to check if the latest iteration of the gist has been posted to WordPress.

The value is stored in the `custom_field` in WordPress.
[Custom Fields Documentation](http://python-wordpress-xmlrpc.readthedocs.io/en/latest/examples/posts.html?highlight=custom_fields%20)

GistBlog()

  • item holds the entire gist json payload fetched from api.github.com/gists/

About

Python tool to post gists to wordpress blog.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages