3
3
mirror of https://github.com/octoleo/octosync.git synced 2024-12-22 16:28:53 +00:00
Go to file
2021-07-14 18:00:22 +02:00
.github/workflows Set main workflows into dry run mode, as we add the keys. 2021-07-14 14:01:05 +02:00
conf Fixed moving function. 2021-07-14 13:52:19 +02:00
src Code formated. Added the direct merge option. Added the success message. Fixed a few Bugs. 2021-07-14 18:00:22 +02:00
.gitignore Should the source and target repo be added inside this repo, we ignore those folders. 2021-07-14 07:52:20 +02:00
LICENSE first commit 2021-07-13 10:40:16 +02:00
README.md first commit 2021-07-13 10:40:16 +02:00

Github Sync Bot Setup

  • We use this script to setup a github user on the Ubuntu systems in the Github Actions Workflows. See setup instructions below.
  • Then the sync of each set of repositories are manage with a config file found in the conf folder.
  • So we have to setup multiple workflows for each set repositories (config) you would like to sync.

How To SETUP gitHub User

You will need to setup a list of secrets in your account. You can do this per/repository or per/organization.

The github user email being used to build

  • GIT_EMAIL

The github username being used to build

  • GIT_USER

gpg -a --export-secret-keys >myprivatekeys.asc The whole key file text from the above myprivatekeys.asc This key must be linked to the github user being used

  • GPG_KEY

The name of the myprivatekeys.asc user

  • GPG_USER

A id_ed25519 ssh private key liked to the github user account

  • SSH_KEY

A id_ed25519.pub ssh public key liked to the github user account

  • SSH_PUB

All these secret values are needed to fully automate the setup to easily interact with gitHub.

Workflows

In your workflows action script you will need to add the following as an example:

jobs:
  build:
    runs-on: [ubuntu-20.04]
    steps:
      - name: Setup gitHub User Details
        env:
          GIT_USER: ${{ secrets.GIT_USER }}
          GIT_EMAIL: ${{ secrets.GIT_EMAIL }}
          GPG_USER: ${{ secrets.GPG_USER }}
          GPG_KEY: ${{ secrets.GPG_KEY }}
          SSH_KEY: ${{ secrets.SSH_KEY }}
          SSH_PUB: ${{ secrets.SSH_PUB }}
        run: |
          /bin/bash <(/bin/curl -s https://raw.githubusercontent.com/vdm-io/github-user/master/src/setup.sh) --gpg-key "$GPG_KEY" --gpg-user "$GPG_USER" --ssh-key "$SSH_KEY" --ssh-pub "$SSH_PUB" --git-user "$GIT_USER" --git-email "$GIT_EMAIL"          
      - name: Clone Sync Bot Repo
          # this is the repo that does the work
          run: |
            /bin/git clone -b master --single-branch git@github.com:[org]/github-sync-bot.git bot            
      - name: Sync The Repo Files
        run: |
          cd bot
          /bin/bash ./src/sync.sh --conf=./conf/[config]          

Free Software License

@copyright  Copyright (C) 2021 Llewellyn van der Merwe. All rights reserved.
@license    GNU General Public License version 2 or later; see LICENSE.txt