This guide describes about "Memo" and "Post".
- Memo: It is a collection of snippet data
- Post: It is an article for publishing
HubMemo represent a memo as JSON object for machine-readable.
type Memo = {
// unique key
url: string;
private: boolean,
title: string;
content: string;
tags: string[];
date: string;
viaURL?: string;
relatedItems?: { title: string, url: string }[];
media: { url: string }[];
}
Also, HubMemo create a memo as Markdown for human-readable in same directory of JSON.
## [{title}]({url})
{content}
{media}
{relatedItems}
HubMemo use GitHub Actions for updating flow.
dispatch-update-memo.yml Action create/update a memo.
Requirements
You need to get your GitHub Personal Access Token.
- Visit /~https://github.com/settings/tokens/new
- Create a token with
repo
permission - Copy it!
You can call this action via GitHub API.
#!/usr/bin/env bash
# Need to change!
YOUR_REPO="azu/hubmemo"
# Your GitHub Personal Token
GITHUB_TOKEN="xxxxx"
curl -vv \
-H "Authorization: token ${GITHUB_TOKEN}" \
-H "Accept: application/vnd.github.everest-preview+json" \
"https://api.github.com/repos/${YOUR_REPO}/dispatches" \
-d '{"event_type": "update-memo", "client_payload": {"item":{"title":"example","url":"https://example.com","content":"description for example","tags":["example"]}}}'
watch-folder-update-memo.yml Action create a memo from json file if you add the json file to watch_folder/update-memo/
directory.
echo '{"item":{"title":"example","url":"https://example.com","content":"description for example","tags":["example"]}}' > watch_folder/update-memo/example.json
git add watch_folder/update-memo/example.json
git commit -m "new memo"
git push
For more details, see Watch Folder documentation.
manual-update-memo.yml provide simple GUI for creating a memo.
- Visit </~https://github.com///actions?query=workflow%3A%22Manual+Update+Memo%22>
- Click "Run workflow"
- Input and submit
issue-update-memo.yml Action create a memo from GitHub issue.
- New Issue
- Click "New Memo" template
- Create an issue, and then issue-update-memo.yml Action create memo from the issue.
Mapping memo with Issue.
title
: Issue Titleurl
: Firsthttp://
url in Issue body- Issue body should start with
<url>
orurl
link.
- Issue body should start with
content
: Rest content of Issue bodytags
: Issue's label startsTag:???
- If the issue labeled with
Tag:example
, convert it totags: ["example"]
- If the issue labeled with
private
: If the issue labeled withType:Private
, it to betrue
Issue body should be following:
<https://example.com>
Description of example.com
📝 <https://...>
is markdown link syntax.
Tips: title
and body
parameter as placeholder.
/~https://github.com/<username>/<repo>/issues/new?assignees=&labels=Type%3AMemo&template=memo.md&title=%3Ctitle%3E&body=%3Curl%3E%0ddescription
Example: New Example Memo · Issue #4 · azu/hubmemo-sandbox
Postem is GUI client for bookmarking.
Postem support HumMemo format as asocial-bookmark service. (HubMemo structure is based on asocial-bookmark)
You can post a memo from postem.
For more details, please see /~https://github.com/azu/postem/tree/master/src/services/asocial-bookmark.
❤️ If you create new integration to HubMemo, Please add your recipe to here.
dispatch-update-memo.yml create Draft Pull Request automatically when updating memo.
- See your Pull Requests tabs
- Edit the Pull Request
- Merge it!
- Automatically publish this content to your setup provider
HubMemo help you to edit Draft PR via .github/workflows/update-draft-post.yml
.
- if PR title starts
YYYY-MM-DD: ~
, change thedraft.md
toYYYY-MM-DD-<slug>.md
- if the content's
title: ~
starts withYYYY-MM-DD: ~
, change thedraft.md
toYYYY-MM-DD-<slug>.md
- if PR body is changed, add the PR's body as headline into the content