Skip to content

push to swarm

push to swarm #298

Workflow file for this run

name: push to swarm
### run this action when something is pushed to master branch
on:
push:
branches: [ master ]
schedule:
- cron: '9 9 1,15 * *'
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
with:
submodules: true # Fetch Hugo themes (true OR recursive)
fetch-depth: 0 # Fetch all history for .GitInfo and .Lastmod
- name: Setup Ruby
uses: ruby/setup-ruby@v1
with:
ruby-version: '3.0' # Not needed with a .ruby-version file
bundler-cache: true # runs 'bundle install' and caches installed gems automatically
cache-version: 1 # Increment this number if you need to re-download cached gems
- run: bundle exec jekyll build --baseurl "" --destination ./dist # defaults output to '/_site'
### upload the content of public folder to swarm
- name: Upload
id: swarm-upload
uses: ethersphere/swarm-actions/upload-dir@latest
with:
# Fairdatasociety provides a free endpoint for uploading content to swarm
# use .dev. for testnet uploads
# or remove .dev. for mainnet uploads
# or use your own private endpoint
bee-url: https://gateway.fairdatasociety.org/proxy/
dir: ./dist
index-document: index.html
timeout: 120000
pin: true
- name: update feed
id: swarm-feed
uses: ethersphere/swarm-actions/write-feed@latest
with:
# Same as above regarding bee-url
bee-url: https://gateway.fairdatasociety.org/proxy/
# takes the reference from the uploaded dir
reference: ${{ steps.swarm-upload.outputs.reference }}
# make up some topic name
# for example: # openssl rand -hex 16
topic: a022076ed9689fb041476a4f60ab7153
# signer you will want to put into your projects secrets
# again use some random hex 32 length generation
# for example: openssl rand -hex 32 and put the output into gihub secrets named "SIGNER"
# https://docs.github.com/en/actions/security-guides/encrypted-secrets#creating-encrypted-secrets-for-a-repository
signer: ${{ secrets.SIGNER }}
# print some references of what we just uploaded to swarm
- name: print references
run: |
echo "upload ref: " ${{ steps.swarm-upload.outputs.reference }} # you can use this to access the content directly https://gateway.dev.fairdatasociety.org/bzz/<refrence>
echo "CID: " ${{ steps.swarm-cid.outputs.cid }} # same but in cid format
echo "Feed Manifest: " ${{ steps.swarm-feed.outputs.manifest }} # note this reference, you will need this in next step to create a persistant reference to it using ENS
- name: purge cache
env:
TOKEN: '${{ secrets.purge_token }}'
DEPLOYMENT: .
PURGE_URL: 'https://fairdrive.fairdatasociety.org'
run: |
curl -s ${{ env.PURGE_URL }}/deploy/purge?token=${{ secrets.purge_token }} -H "site: fairdataprotocol.link.fairdatasociety.org" -H "uri: /"