an OBS plugin to display the status of an ongoing cd recording as a dock

cg2121 f102d11e57 Auto generate plugin name in workflow 2 tahun lalu
.github f102d11e57 Auto generate plugin name in workflow 2 tahun lalu
cmake 0f60ca33f9 Add windows resource 3 tahun lalu
data b75e67843c add data locale template 5 tahun lalu
src 623c7600e8 Apply CMake format to main source file 3 tahun lalu
.clang-format 2764248a5d Reorganize project files 3 tahun lalu
.cmake-format.json 33b4835026 cmake: Update cmake-format to allow files to use up to 100 columns 3 tahun lalu
.gitignore dbde191462 CI: Add automatically generated build directories to gitignore file 3 tahun lalu
CMakeLists.txt 8f1d770e51 cmake: Reformat commented out lines to cmake format check 3 tahun lalu
LICENSE aeb812bc4c Initial commit 7 tahun lalu
README.md 86ae5b4de6 Add documentation for LINUX_PORTABLE variable 2 tahun lalu
buildspec.json 5db14e5850 Add support for linux-aarch64 (Arm) builds 3 tahun lalu

README.md

OBS Plugin Template

Introduction

This plugin is meant to make it easy to quickstart development of new OBS plugins. It includes:

  • The CMake project file
  • Boilerplate plugin source code
  • GitHub Actions workflows and repository actions
  • Build scripts for Windows, macOS, and Linux

Configuring

Open buildspec.json and change the name and version of the plugin accordingly. This is also where the obs-studio version as well as the pre-built dependencies for Windows and macOS are defined. Use a release version (with associated checksums) from a recent obs-deps release.

Next, open CMakeLists.txt and edit the following lines at the beginning:

project(obs-plugintemplate VERSION 1.0.0)

set(PLUGIN_AUTHOR "Your Name Here")

set(LINUX_MAINTAINER_EMAIL "me@contoso.com")

The build scripts (contained in the .github/scripts directory) will update the project line automatically based on values from the buildspec.json file. If the scripts are not used, these changes need to be done manually.

GitHub Actions & CI

The scripts contained in github/scripts can be used to build and package the plugin and take care of setting up obs-studio as well as its own dependencies. A default workflow for GitHub Actions is also provided and will use these scripts.

Retrieving build artifacts

Each build produces installers and packages that you can use for testing and releases. These artifacts can be found on the action result page via the "Actions" tab in your GitHub repository.

Building a Release

Simply create and push a tag and GitHub Actions will run the pipeline in Release Mode. This mode uses the tag as its version number instead of the git ref in normal mode.

Packaging on Linux

The install step results in different directory structures depending on the value of LINUX_PORTABLE - "OFF" will organize outputs to be placed in the system root, such as /usr/, and "ON" will organize outputs for portable installations in the user's home directory. If you are packaging for a Linux distribution, you probably want to set -DLINUX_PORTABLE=OFF.

Signing and Notarizing on macOS

On macOS, Release Mode builds can be signed and sent to Apple for notarization if the necessary codesigning credentials are added as secrets to your repository. You'll need a paid Apple Developer Account for this.

  • On your Apple Developer dashboard, go to "Certificates, IDs & Profiles" and create two signing certificates:
    • One of the "Developer ID Application" type. It will be used to sign the plugin's binaries
    • One of the "Developer ID Installer" type. It will be used to sign the plugin's installer
  • Using the Keychain app on macOS, export these two certificates and keys into a .p12 file protected with a strong password
  • Encode the .p12 file into its base64 representation by running base64 YOUR_P12_FILE
  • Add the following secrets in your Github repository settings:
    • MACOS_SIGNING_APPLICATION_IDENTITY: Name of the "Developer ID Application" signing certificate generated earlier
    • MACOS_SIGNING_INSTALLER_IDENTITY: Name of "Developer ID Installer" signing certificate generated earlier
    • MACOS_SIGNING_CERT: Base64-encoded string generated above
    • MACOS_SIGNING_CERT_PASSWORD: Password used to generate the .p12 certificate
    • MACOS_NOTARIZATION_USERNAME: Your Apple Developer account's username
    • MACOS_NOTARIZATION_PASSWORD: Your Apple Developer account's password (use a generated "app password" for this)