Skip to main content

CD-like tool for publishing your static website from Git to IPFS

Project description

IPFS Publish

Git+IPFS=Love

PyPI version PyPI - Python Version PyPI - Downloads Docker Hub - Pulls codecov Codacy Badge Updates

Continuous Delivery of static websites from Git to IPFS

About

This is a tool that aims to enable automatic publishing of static webpages from Git repositories into IPFS. It consists of two parts: small web server and management CLI.

Web server exposes an endpoint which you use as your Git's webhook. When the hook is invoked, it clones your repo, build it (if needed), add it to the IPFS node (pin it if configured) and publish the new IPFS address under configured IPNS name.

CLI is in place to manage the repos.

Features

  • Ignore files - .ipfs_publish_ignore file specify entries that should be removed before adding the repo to IPFS
  • Publish directory - you can publish only specific sub-directory inside the repo
  • Publish specific branch - you can specify which branch should be published from the repo
  • Build script - before adding to IPFS you can run script/binary inside the cloned repo
  • After publish script - after the publishing to IPFS, this script is run with argument of the created IPFS address
  • Direct DNSLink update for CloudFlare DNS provider

Git providers

Currently the webhook supports generic mode, where the repo's secret is passed through as URL's parameter.

There is also special mode for GitHub, where the secret should be configured as part of the Webhook's configuration.

Warning

This tool is not meant as public service and only trusted Git repos should be used with it. It can introduce serious security risk into your system as the runtime environment for the scripts is not isolated from rest of your machine!

Install

Requirements

  • Python 3.7 and higher
  • Git
  • go-ipfs daemon (tested with version 4.23)
  • UNIX-Like machine with public IP

pip

You can install ipfs-publish directly on your machine using pip:

$ pip install ipfs-publish

Then you can use the command ipfs-publish to manage your repos and/or start the webhook's server.

Docker

There is official Docker image build with name: auhau/ipfs-publish

Easiest way to run ipfs-publish is with docker-compose. Here is example for its configuration:

version: '3'

services:
  ipfs:
    image: ipfs/go-ipfs:v0.4.23
    volumes:
      - /data/ipfs # or you can mount it directly to some directory on your system
  ipfs-publish:
    image: auhau/ipfs-publish
    environment:
      IPFS_PUBLISH_CONFIG: /data/ipfs_publish/config.toml
      IPFS_PUBLISH_VERBOSITY: 3
      IPFS_PUBLISH_IPFS_HOST: ipfs
      IPFS_PUBLISH_IPFS_PORT: 5001
    volumes:
      - /data/ipfs_publish
    depends_on:
      - ipfs
    ports:
      - 8080:8000

For more information see documentation.

Usage

# Add new repo
$ ipfs-publish add
[?] Git URL of the repo: https://github.com/auhau/auhau.github.io
[?] Name of the new repo: github_com_auhau_auhau_github_io
[?] Do you want to publish to IPNS? (Y/n):
[?] Path to build binary, if you want to do some pre-processing before publishing:
[?] Path to after-publish binary, if you want to do some actions after publishing:
[?] Directory to be published inside the repo. Path related to the root of the repo: /

Successfully added new repo!
Use this URL for you webhook: http://localhost:8080/publish/github_com_auhau_auhau_github_io
Also set this string as your hook's Secret: NIHT4785CVFT358GFE08RDAZG
Your IPNS address: /ipns/QmRTqaW3AJJXmKyiNT7MqqZ4VjGtNNxPyTkgo3Q7pmoCeX/

# List current enabled repos
$ ipfs-publish list
github_com_auhau_auhau_github_io

# Show details of repo
$ ipfs-publish show github_com_auhau_auhau_github_io
github_com_auhau_auhau_github_io
Git URL: https://github.com/auhau/auhau.github.io
Secret: EAHJ43UYT7LUEM4QFRZ4IFAXL
IPNS key: ipfs_publishg_github_com_auhau_auhau_github_io
IPNS lifetime: 24h
IPNS ttl: 15m
IPNS address: /ipns/QmRTqaW3AJJXmKyiNT7MqqZ4VjGtNNxPyTkgo3Q7pmoCeX/
Last IPFS address: None
Webhook address: http://localhost:8080/publish/github_com_auhau_auhau_github_io

# You can manually publish repo
$ ipfs-publish publish github_com_auhau_auhau_github_io

# Starts HTTP server & IPNS republishing service
$ ipfs-publish server &
Running on http://localhost:8080 (CTRL + C to quit)

Contributing

Feel free to dive in, contributions are welcomed! Open an issue or submit PRs.

For PRs and tips about development please see contribution guideline.

License

MIT © Adam Uhlir

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ipfs-publish-0.2.1.tar.gz (55.9 kB view details)

Uploaded Source

Built Distribution

ipfs_publish-0.2.1-py2.py3-none-any.whl (21.8 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file ipfs-publish-0.2.1.tar.gz.

File metadata

  • Download URL: ipfs-publish-0.2.1.tar.gz
  • Upload date:
  • Size: 55.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.0

File hashes

Hashes for ipfs-publish-0.2.1.tar.gz
Algorithm Hash digest
SHA256 3f53345c21b80639a829aab6ac8095d82cfe9be30eaf8d54a25b67a99ad3f6bc
MD5 91bbf185dc5d01f4e7e29facc32b6397
BLAKE2b-256 2f8b41def579dd60c5b526013ef81c6c6d95da8913860f9dfe69e7f015d98eef

See more details on using hashes here.

File details

Details for the file ipfs_publish-0.2.1-py2.py3-none-any.whl.

File metadata

  • Download URL: ipfs_publish-0.2.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 21.8 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.0

File hashes

Hashes for ipfs_publish-0.2.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 45d55e83a6f90a36b0ade0780e7cc8098bcb6ae7eb9427c4ef26395069c5df4a
MD5 644c92ea1cc03c7ea25f35e2f2421ddc
BLAKE2b-256 ae7d4d31b7d44922488ae731898cb38b8eaae6ea530342ce12b62f3eb96c8f55

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page