Scripts for the actions are under ./actions
folder.
Records of requested and performed actions are under ./records
.
- .github/workflows # Contains workflows
- process.yml # Process merged requests
- validate.yml # Validate JSON requests added in PRs to catch early errors
- actions/ # scripts for the actions
- lib/
- test/
- integration.js # This can be run locally to test process.js on a test account
- process.js # a script that takes a path/to/new/name.json to perform actions
- login-and-validate.js # part of process.js, can be run alone to validate a JSON
- records/
- new/ # Where requests can be added in the form of JSON via pull requests.
# It contains some existing examples with the name xxx.json.example
- processed/ # Requests in the new folder will be moved here with information
# about the performed actions added. The file will be renamed
# to YYYY-MM-DD-ID.json, where ID is incremental index for files
# processed on that date.
Content automation is done in the form of adding new JSON files to records/new
. To submit the request:
- Open a pull request targeting the
main
branch to add a JSON file or multiple JSON files torecords/new/
.- Currently, the PR branch should be opened from the nodejs repository if you have write access to it, so that the PR gets full validation using the secrets in the repository. PRs from forks cannot get a full validation due to GitHub workflow restrictions.
- The file name can be anything, as long as it ends with
.json
, though its better to give it a descriptive name likerepost.json
. The file will be renamed and moved torecords/processed
later so it doesn't matter how it is named during the draft phase. - For example, see #8
- The JSON files must contain at least the two required fields:
"account"
: a pre-configured account name, see repository setup on account name configuration. currently the following accounts are supported:NODEJS_ORG
: for nodejs.org on Bluesky
"action"
: Currently, the following actions are supported:"post"
: post new content specified by"richText"
(or"richTextFile"
if it's more convenient to edit the content from a separate text file)."repost"
: repost an existing post specified by"repostURL"
"reply"
: reply to an existing post specified by"replyURL"
, with content specified by"richText"
(or"richTextFile"
if it's more convenient to edit the content from a separate text file)."quote-post"
: quote an existing post specified by"repostURL"
, with new content specified by"richText"
(or"richTextFile"
if it's more convenient to edit the content from a separate text file).
- For other fields see the examples under
records/new
.
- When the PR is opened, the validate-json workflow will run to make sure the JSON files are correctly filled. It will verify the URLs filled in the JSON files are valid.
- When the PR is merged (either with Squash and merge or with a merge commit, Rebase and merge is not supported), the process-json workflow will run to perform the requested actions, and when it's done, it will move the processed JSON files to
./records/processed
and renamed the file toYYYY-MM-DD-ID.json
where ID is an incremental ID based on the number of files already processed on that date. It will also add in additional details of the performed actions (e.g. CID and URI of the posted post). - When the process workflow is complete (likely within a minute), you should see a commit from the GitHub bot in the main branch moving the JSON file.
To send several messages replying to one another, you can separate each tweet
using a Markdown thematic break inside the richText
or richTextFile
:
Here is the first tweet.
---
Here is the second tweet.
---
Here is the third tweet.
-
Set up repository secrets for accounts.
- For each account that the automation controls, give it a name (this will be used as part of the environment variables, so ideally it should just be a capitalized word), for example
NODEJS_ORG
. - Go to https://bsky.app/settings/app-passwords and create an app password for that account
- Set up a repository secret
BLUESKY_APP_PASSWORD_$ACCOUNT
(e.g.BLUESKY_APP_PASSWORD_NODEJS_ORG
) to be that app password.
- For each account that the automation controls, give it a name (this will be used as part of the environment variables, so ideally it should just be a capitalized word), for example
-
Make sure that in the GitHub workflows where
BLUESKY_APP_PASSWORD_
andBLUESKY_APP_PASSWORD_
environment variables are used to run scripts under theactions/
folder, the account handle and the account app password are added in there. For example:env: BLUESKY_IDENTIFIER_NODEJS_ORG: nodejs.org BLUESKY_APP_PASSWORD_NODEJS_ORG: ${{ secrets.BLUESKY_APP_PASSWORD_NODEJS_ORG }}
There can be multiple accounts configured in the environment variables. The GitHub actions will process JSON files with an "account" field specifying which account they want to use to perform the action.
$ nvs add 22 # Or use nvm if you prefer
$ nvs use 22
$ corepack enable
$ cd actions
$ yarn install
There aren't a lot of tests right now. Though to run the test locally to perform a series actions on a live test account, you could do:
cd ./actions
node --env-file=./.env.bluesky test/integration.js
All files starting with .env are ignored in this repository, you could save the credentials there, like in the .env.bluesky
used above, if the account is named PRIMARY
, it should have:
BLUESKY_IDENTIFIER_PRIMARY=... # The Bluesky handle
BLUESKY_APP_PASSWORD_PRIMARY=... # The app password