ShatterCMS submodule for rebuilding Dokku apps using dokku-rebuild.
This repository has been archived on 2026-06-11. You can view files and clone it, but you cannot make any changes to its state, such as pushing and creating new issues, pull requests or comments.
  • TypeScript 100%
Find a file
2021-06-02 17:23:10 +02:00
src chore: initial commit 2021-02-22 17:52:56 +01:00
.editorconfig chore: initial commit 2021-02-22 17:52:56 +01:00
.gitignore chore: initial commit 2021-02-22 17:52:56 +01:00
.prettierrc chore: initial commit 2021-02-22 17:52:56 +01:00
CHANGELOG.md chore(release): 0.1.1 2021-06-02 17:23:10 +02:00
LICENSE chore: initial commit 2021-02-22 17:52:56 +01:00
package.json chore(release): 0.1.1 2021-06-02 17:23:10 +02:00
README.md chore: initial commit 2021-02-22 17:52:56 +01:00
tsconfig.json chore: initial commit 2021-02-22 17:52:56 +01:00
yarn.lock chore(deps): upgrade dependencies 2021-06-02 17:22:52 +02:00

ShatterCMS Rebuild

ShatterCMS submodule for rebuilding Dokku apps using dokku-rebuild.

Requirements

This module is meant for use with Dokku. If you don't manage your apps through Dokku this module is not for you.

  • A Dokku app you want to trigger a rebuild on
  • The dokku-rebuild service set up and running

Setup

  1. Add @shattercms/rebuild as dependency to your project
# install with npm
npm install @shattercms/rebuild

# or use yarn instead
yarn add @shattercms/rebuild
  1. Add the module to the shatter.js config file
module.exports = {
  modules: ['@shattercms/rebuild'],

  // (defaults)
  rebuild {
    socketPath: '/var/run/dokku-rebuild/dokku-rebuild.sock',
    saveLimit: 10,
  },
}

Options

socketPath

If you configured dokku-rebuild to use a different socket path, you can tell the rebuild module to use that same path by using the socketPath option.

saveLimit

If you want to store more than 10 builds you can do so by changing the saveLimit option.

Usage

This module does not interface with the database. Current and past builds are only saved in memory. If you restart the API, this data will be lost!

GraphQL

type Rebuild {
  # 'pending' | 'complete' | 'failed'
  status: String!

  # Current stage from dokku-rebuild
  stage?: String

  # ISO time strings
  startedAt: String!
  completedAt?: String
}

query {
  # Get all builds
  # () => [Rebuild]
  rebuild_getAll {
    ...Rebuild
  }

  # Get current build
  # () => Rebuild | null
  rebuild_get {
    ...Rebuild
  }
}

mutation {
  # Trigger a new rebuild
  # () => Rebuild
  rebuild_create {
    ...Rebuild
  }
}

Troubleshooting

  • Make sure the socketPath is mounted to your app.
  • Check if the dokku-rebuild service is indeed running (systemctl status dokku-rebuild), or check the logs for more info (journalctl -u dokku-rebuild)
  • Try reinstalling the dokku-rebuild service to correct folder and file permissions