- π Overview
- πΎ Features
- π Getting Started
- ποΈ Building the Project
- π€ Contributing
- π₯ Contributor Graph
- π License
- π References
The Publish Blog Post action is a GitHub Action that automates the process of publishing blog posts to various platforms, such as Dev.to and Medium. The action reads the markdown content from a specified file and based on its front matter data publishes or updates the post to the selected platform using the respective API.
The action get the list of files to process (new or updated) by comparing the current commit with the previous commit. It then reads the front matter of the markdown file to extract metadata such as title, description, tags, etc. The action then publishes or updates the post to the selected platform using the respective API.
The action provides the following features:
- Publish new posts: Publishes blog posts to supported/configured hosting (currently only Dev.to).
- Update Existing Posts: Updates existing posts on supported/configured hosting (currently only Dev.to).
- TypeScript: The action is developed using TypeScript, ensuring type safety and code consistency.
- ESLint and Prettier: The codebase adheres to best practices using ESLint and Prettier for consistent code formatting.
- Unit Tests: The action includes unit tests to validate the correctness of individual functions and modules.
- Vitest: The action utilizes Vitest for testing, ensuring the reliability and accuracy of the codebase.
- Code Coverage: The action maintains a high code coverage percentage, guaranteeing comprehensive testing.
KY: Tiny & elegant JavaScript HTTP client based on the Fetch API ussed to make HTTP requests to the Dev.to API. gray-matter: Used to parse the front matter of the markdown file to extract metadata such as title, description, tags, etc.
To use the Publish Blog Post action, it is necessary to configure the required permissions and API keys. Later you need to create a workflow file in your repository to trigger the action.
It is necessary to enable Read and write permissions
for the GitHub Token in the repository settings. This permission is required to access and modify markdown files within the repository.
- Navigate to the repository
Settings
. - Expand the
Actions
section and click onGeneral
- Scroll down to the
Permissions
section and ensure that theRead and write permissions
are enabled for the GitHub Token.
To use the action, you need to obtain an API key for the choosen Blog Post Hosting. Follow these steps to create an API key:
To use the Dev.to API, you need to create an API key. Follow these steps to create an API key:
- Go to Dev.to and sign in to your account.
- Navigate to the Settings -> Exetensions page.
- Scroll down and click on the
Generate API Key
button after defining the description. - Copy the generated API key.
Once you have obtained the API key, add it to the repository secrets as DEV_TO_API_KEY
.
- Navigate to the repository
Settings
. - Expand the
Secrets and variables
section and click onActions
. - Click on
New repository secret
. - Add the
Name
:DEV_TO_API_KEY
Value
:<Your Dev.to API Key>
Create a new workflow file in your repository to trigger the Publish Blog Post action. The workflow file should be placed in the .github/workflows
directory.
The action requires the following inputs:
Name | Required | Default Value | Description |
---|---|---|---|
token | true | ${{ github.token }} |
The GitHub token to access the repository. |
publishTo | true | devTo |
The hostings to publish/update the post. Comma separated values. Supported values: 'devTo' |
devToApiKey | true (if publishTo contains 'devTo') | The API key for the devTo Blog Post Hosting. | |
includeFolders | false | Folders to look for post files to publish/update. Multiple folders can be specified, one per line. If not defined, all folders will be checked | |
commitMessage | false | publish/update %file with updated data |
The commit message template for review suggestions. %file is replaced by file path |
Example of a workflow file:
name: Test Publish Blog Post Action
on:
push:
branches:
- main
jobs:
publish-blog-post::
runs-on: ubuntu-latest
name: A test job to run the Publish Blog Post action
steps:
# To use this repository's private action,
# you must check out the repository
- name: Checkout
uses: actions/checkout@v4
# IMPORTANT: Fetch all history for all tags and branches so it can compare commits and get files changed
with:
fetch-depth: 0
- name: Test the publish-blog-post action
uses: trystan2k/publish-blog-post@v1
id: publish-blog-post
with:
devToApiKey: ${{ secrets.DEV_TO_API_KEY }}
includeFolders: |-
post-samples
Ensure you have Node.js and PNPM installed on your machine before proceeding with the installation.
β― node -v
>= 20.0.0
β― pnpm -v
>= 9.9.0
Build the project from source:
- Clone the repository:
β― git clone [email protected]:trystan2k/publish-blog-post.git
- Navigate to the project directory:
β― cd publish-blog-post
- Install the required dependencies:
β― pnpm install
To build the project for distribution, run the following command:
β― pnpm build
Execute the test suite using the following command:
β― pnpm test
Contributions are welcome! Here are several ways you can contribute:
- Report Issues: Submit bugs found or log feature requests for the
app
project. - Submit Pull Requests: Review open PRs, and submit your own PRs.
This project is protected under the MIT License. For more details, refer to the LICENSE file.