/tootbot-template

cheap mastodon bots done quick (in php)!

Primary LanguagePHPMIT LicenseMIT

tootbot-template

getting started

first things first

  • clone this repository
  • create a mastodon account for your bot, e.g. on https://botsin.space/
  • when your account is approved, go to the development settings and create a new application
  • copy /config/.env_example to /config/.env (for local test, do not upload the .env to GitHub!)
    • copy the access token from the mastodon application and save it in the .env as MASTODON_TOKEN, go to the repository settings on GitHub under {repo_url}/settings/secrets/actions and save it there too (not necessary if you plan to run the bot on your own webserver)
    • save the mastodon instance URL in the .env as MASTODON_INSTANCE, save it as GitHub repository secret as well
    • if you plan to use remote authentication with the mastodon app, you will need to do the same for the client key, secret and callback-URL
  • fetch a fresh cacert.pem from https://curl.se/ca/cacert.pem and save it under /config

next up: code

  • update the LICENSE
  • change the example namespaces in composer.json, add any libraries you need, add yourself as author
    • commit the composer.lock after updating
  • change/replace the MyTootBot and MyTootBotTest examples
    • MyTootBot needs to extend the abstract TootBot class
  • update the CLI runner run.php as necessary

finally: run

  • test locally: php ./cli/run.php
  • create a run.yml in /.github/workflows which enables a scheduled GitHub action (see below)
  • profit!
# https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions

on:
  schedule:
    # POSIX cron syntax (every 12th hour), https://crontab.guru/#0_12_*_*_*
    - cron: "0 12 * * *"

name: "Run"

jobs:

  run-bot:
    name: "Run the bot and post to Mastodon"

    runs-on: ubuntu-latest

    # requiired for stefanzweifel/git-auto-commit-action
    permissions:
      contents: write

    env:
      MASTODON_TOKEN: ${{ secrets.MASTODON_TOKEN }}
      MASTODON_INSTANCE: ${{ secrets.MASTODON_INSTANCE }}

    steps:
      - name: "Checkout sources"
        uses: actions/checkout@v4

      - name: "Install PHP"
        uses: shivammathur/setup-php@v2
        with:
          php-version: "8.2"
          coverage: none
          extensions: curl, json, mbstring, openssl, sodium

      - name: "Install dependencies with composer"
        uses: ramsey/composer-install@v3

      - name: "Fetch cacert.pem from curl.haxx.se"
        run: wget -O config/cacert.pem https://curl.se/ca/cacert.pem

      - name: "Run bot"
        run: php ./cli/run.php

      # please note that this requires read/write permissions for the actions runner!
      - name: "Commit log"
        uses: stefanzweifel/git-auto-commit-action@v5
        with:
          commit_message: ":octocat: posted toot"
          file_pattern: "data/posted.json"
          commit_user_name: "github-actions[bot]"
          commit_user_email: "41898282+github-actions[bot]@users.noreply.github.com"
          commit_author: "github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>"

related projects

disclaimer

WE'RE TOTALLY NOT RUNNING A PRODUCTION-LIKE ENVIRONMENT ON GITHUB.
WE'RE RUNNING A TEST AND POST THE RESULT TO AN EXTERNAL WEBSITE.
WE'RE JUST LOOKING IF THE SCRIPT STILL WORKS ON A SCHEDULE N TIMES A DAY.