GitHub Action
blogpub
Github action to publish your blog articles to Medium or Dev.to.
It gets the files from a push
event and process the first md
file that find.
The file is ignored if it already existed before the push event.
This avoid publishing again when making fixes on an existing article.
In order to interact with both platforms API's you will need:
- Medium integration token
- Dev.to API Key
- Github access token with
reading
permissions
The action will grab an markdown
file from a push event to a branch.
The following workflow configuration will publish articles that are committed to
the main
branch:
on:
push:
branches:
- 'main'
paths:
- 'articles/*'
Note: we only want to trigger this action when files are added to the folder
blogs
.
You can define your job as follows:
jobs:
publish:
name: publish new article
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v2
- name: blogpub
uses: protiumx/blogpub@v0.6.0
with:
devto_api_key: ${{ secrets.DEVTO_API_KEY }}
gh_token: ${{ secrets.GH_TOKEN }}
medium_token: ${{ secrets.MEDIUM_TOKEN }}
medium_user_id: 1f3b633f149233c057af77f0016a9421fa520b9a59f97f5bd07201c2ca2a4a6bc
Check blogpub-test for more examples or my personal blog source
gh_token
: Github token. Requiredarticles_folder
: Folder to look for new articles. Default:blogs
medium_token
: Your Medium integration token. Requiredmedium_base_url
: Medium base URL to post articles. Default:https://api.medium.com/v1
medium_user_id
: Your Medium user ID. Required. See medium api docsdevto_api_key
: Your Dev.to API Key. Required
Example:
---
title: New Article
description: Some description
tags: test, ci
license: public-domain
---
# This is my new Article
In this article we will learn how to setup with `blogpub`
## Relative paths from the repository
![ci-meme.jpg](./assets/meme.jpg)
## Requirements
...
medium_url
: URL of the published article to Mediumdevto_url
: URL of the published article to Dev.to
blogpub
will search for metadata surrounded by section markers ---
. The metadata
should be a yml
section.
The following arguments can be set:
title
:[string]
The title of the article. If not specified, the first H1 heading will be used.description
:[string]
Description fordev.to
API.tags
:[string | string[]]
Comma separated tags or yaml list. Note: Medium allows up to 5 tags whereas Dev.to only 4.license
:[string]
Medium license type. Refer to Medium API Docs. Default:public-domain
published
:[boolean]
. Default:true
cover_image
:[string]
Dev.to cover image
blogpub
supports handlebars templates.
It provides the following context
{
medium: boolean;
devto: boolean;
}
Usage:
{{#if medium}}
This is only for Medium
{{/if}}
To use any media contained in your repository you can use relative paths. All relative paths will be resolved using the raw url of the markdown down file that is being processed.
Example:
![image](./img1.png)
<img src="../assets/img2.jpg" />
Will be parsed as
![image](https://raw.githubusercontent.com/<owner>/<repo>/<articles_folder>/img1.png)
<img src="https://raw.githubusercontent.com/<owner>/<repo>/assets/img2.jpg" />
Run tests
yarn test
Run build
yarn build
If you want to test the action locally you could clone blogpub-test
and use
act to run the action.
Please submit a PR with any contribution. Refer to the list of TODO's
or open issues.
- Relative paths to github raw server
- Support
cover_image
for dev.to API with relative path - Test action with custom
medium
base url. - Remove
axios
in favor of node'shttps
- Sanitize inputs
- Support publishing to only 1 platform
- Support edition and auto update of articles
- Support multiple articles per job run