Skip to content

This repository holds the code for creating a organisation specific open catalogi instance

License

Notifications You must be signed in to change notification settings

OpenCatalogi/opencatalogi-action

Use this GitHub action with your project
Add this Action to an existing workflow or create a new one
View on Marketplace

Repository files navigation

Open Catalogi action

This action builds on the organization-specific Open Catalogi page as a static GitHub page.

Usage

To use this action, simply include it as a step in your workflow file. No inputs are required.

name: My Open Catalogi Workflow

on:
  schedule:
    - cron: '0 0 * * *'

jobs:
  build:
    runs-on: ubuntu-latest
    steps:
      - name: Deploy Open Catalogi Github Page
        uses: OpenCatalogi/opencatalogi-action@latest

In the above example a page is created or updated every night at 0:00, we advise this route because you will automatically be supplied with fixes and new features. You can however also choose other options to trigger a page build

To trigger a page build whenever you commit something to the main branch

on:
  push:
    branches:
      - main

Warning It is possible that this workflow fails, a simple 'rerun job' in your GitHub actions might be enough to fix this.

To gain a bit more control and only trigger a page build manually use

on:
  workflow_dispatch:

Warning If you do not supply the action with an access token or an SSH key, you must access your repositories settings and provide Read and Write Permissions to the provided GITHUB_TOKEN, otherwise you'll potentially run into permission issues. Alternatively, you can set the following in your workflow file to grant the action the permissions it needs.

permissions:
  contents: write

Note When you first run the workflow you need to manually activate GitHub pages on your repository! Head over to settings -> pages. Select deploy form a branch as a source and gh-pages as your branche (unless you configured the page to be built in a different branch) Page Settings After pressing save head over to the actions and take a look at the pages build and deployment action Page Action When it is done it will also tell you under which link you can find your page Page Action done

Inputs

Input Name
Description
Required Type Default Value
env_vars_set Whether to use the env variables set in this file, set to false to use env variables of the OpenCatalogi config files Yes boolean true
github_pages_branch The branch on which the GitHub page will be built (Optional) No string gh-pages
github_repository_name_as_prefix Whether to use the GitHub repository name as a prefix (Optional) No boolean true
repository The GitHub repository to use (could be an external repository) (Optional) No string ${{ github.event.repository.name }}
pull_from_branche The branch on which to base the build (Optional) No string main
me_url The profile URL used (Optional) No string https://api.opencatalogi.nl/api/users/me
api_url The location of the Open Catalogi API (change if you are running your own API) (Optional) No string https://api.opencatalogi.nl/api
nextcloud_api_url The location of the Nextcloud Open Catalogi API (change if you are running your own API) (Optional) No string https://directory.opencatalogi.nl/index.php/apps/opencatalogi/api
admin_url The admin (dashboard) URL used (Optional) No string https://api.opencatalogi.nl/admin
base_url The BASE location of the Open Catalogi API (change if you are running your own API) (Optional) No string https://api.opencatalogi.nl
frontend_url The location (URL) of this Open Catalogi installation (Optional) No string https://api.opencatalogi.nl
login_redirect The path for login redirection (Optional) No string vault
admin_dashboard_url The location of the Open Catalogi dashboard (Optional) No string https://admin.opencatalogi.nl
nl_design_theme_classname The class name of the desired NL design theme (Optional) No string open-webconcept-theme
arrow_breadcrumbs Whether to use arrow breadcrumbs instead of the normal breadcrumbs (Optional) No boolean false
start_page When given, shows a readme file instead of the normal start page (Optional) No string false
filter_forks Remove forked repositories from search, set it to false to not show this filter, set to true to show this filter and have it active as default, leave it empty to show the filter but not have it active(Optional) No string
filter_rating The rating version that will be used, OpenCatalogi or Commonground set to false to not show this filter (Optional) No string OpenCatalogi
filter_rating_default The default value of the shown rating. OpenCatalogi: (0-24), Commonground: (0-4). If filter_rating is set to false the default value won't do anything.(Optional) No string 0
filter_layer If you want to have the filter layer displayed, set it to false to not show this filter, to set a default value set to '["{value1}", "{value2}"]' values: (interface, process, integration, service, data), leave it empty to show the filter but not have it active (Optional) No string
filter_upl If you want to have the filter upl displayed, set it to false to not show this filter, to set a default value set to '["{value1}", "{value2}"]' values can be found here, leave it empty to show the filter but not have it active (Optional) No string
filter_organisation If you want to have the filter organisation displayed, set to false to not show the filter (Optional) No string
filter_category If you want to have the filter category displayed, set it to false to not show this filter, to set a default value set the value to one of the categories found here, leave it empty to show the filter but not have it active (Optional) No string
filter_platforms If you want to have the filter platforms displayed, set it to false to not show this filter, to set a default value set to '["{value1}", "{value2}"]' values: (web, windows, mac, linux, ios, android), leave it empty to show the filter but not have it active (Optional) No string
filter_status If you want to have the filter status displayed, set it to false to not show this filter, to set a default value set the value to one of the status (concept, development, beta, stable, obsolete, hideObsolete), leave it empty to show the filter but not have it active (Optional) No string
filter_maintenance_types If you want to have the filter status maintenance types, set it to false to not show this filter, to set a default value set the value to one of the maintenancy types (internal, contract, community), leave it empty to show the filter but not have it active (Optional) No string
filter_license If you want to have the filter license displayed, set it to false to not show this filter, to set a default value set the value to one of the licenses found here, leave it empty to show the filter but not have it active (Optional) No string
filter_business_functions If you want to have the filter business functions displayed, set it to false to not show this filter, to set a default value set to '["{value1}", "{value2}"]' values can be found here, leave it empty to show the filter but not have it active (Optional) No string
filter_software_type If you want to have the filter software type displayed, set it to false to not show this filter, to set a default value set the value to one of the software type found here, leave it empty to show the filter but not have it active (Optional) No string
filter_business_services If you want to have the filter business services displayed, set it to false to not show this filter, to set a default value set to '["{value1}", "{value2}"]' values can be found here, leave it empty to show the filter but not have it active (Optional) No string
filter_reference_components If you want to have the filter reference components displayed, set it to false to not show this filter, to set a default value set to '["{value1}", "{value2}"]' values can be found here, leave it empty to show the filter but not have it active (Optional) No string
favicon_logo A base64 encoded SVG file or URL to the logo used as a favicon (Optional) No string https://openwebconcept.nl/wp-content/themes/openwebconcept/assets/src/images/[email protected]
page_title The title for the website / gitpage (Optional) No string ${{ github.event.repository.name }}
navbar_logo An base64 encoded SVG file or URL to the logo used in the main menu (Optional) No string https://openwebconcept.nl/wp-content/themes/openwebconcept/assets/src/images/[email protected]
navbar_show_login Shows the inloggen option (Optional) No boolean false
navbar_content A link to the JSON file that manages the footer content (Optional) No string https://raw.githubusercontent.com/OpenCatalogi/web-app/348679b7537b20e51767dfdc6086349602afe219/pwa/src/templates/templateParts/header/HeaderContent.json
jumbotron_title The title of the jumbotron (Optional) No string ${{ github.event.repository.name }}
jumbotron_subtitle The (short) subtitle used in the jumbotron (Optional) No string Product page
jumbotron_description The (long) description included in the jumbotron (Optional) No string ${{ github.event.repository.description }}
footer_logo An base64 encoded SVG file or URL to the logo used in the footer (Optional) No string https://openwebconcept.nl/wp-content/themes/openwebconcept/assets/src/images/[email protected]
footer_content A link to the JSON file that manages the footer content (Optional) No string https://raw.githubusercontent.com/OpenCatalogi/web-app/25995205e1dbb043822d1c58c5c23f8e6f77ff7e/pwa/src/templates/templateParts/footer/FooterContent.json
footer_show_creator Shows the "With love from conduction" link in the footer (Optional) No boolean true
git_name Git name configuration for the commit (Optional) No string Open Catalogi bot
git_mail Git mail configuration for the commit (Optional) No string [email protected]
git_commit_message The description for the commit (Optional) No string ${{ github.event.repository.html_url }}
github_organization_url The repository to which the results are limited (used to only look in your own organization) (Optional) No string https://github.com/${{ github.repository_owner }}

Output

Output Name Description
page A zip of the build page

Tips

Besides creating a front end for your catalogue it's also a good idea to define how your organization uses open source. Luckily this is very easily done by adding the publiccode action to your workflow

name: My PublicCode Workflow

on:
  push:
    branches:
      - main

jobs:
  build:
    runs-on: ubuntu-latest
    steps:
      - name: Deploy Product Github Page
        uses: OpenCatalogi/productpage-action@latest
      - name: Update opencatalogi.yaml
        uses: OpenCatalogi/publiccode-action@latest

Read more about the publiccode action that also creates the opencatalogi.yaml

Working with branch protection

Keep in mind that this action creates/updates a file and force pushes into the branch it was run on. It is therefore incompatible with GitHub branch protection ON THE SAME branch. You can however the workflow to start higher up in the branche tree to circumvent this. e.g. if you normally work with a branch setup like:

  • Master (protected)
    • Development (protected)
      • Feature-1
      • Feature-1

You can configure the workflow to trigger on

on:
  push:
    branches:
      - 'feature-*'

The adjusted publiccode or opencatalogi files will then come along in your normal pull requests from feature-x to development, etc.

Special thanks

As is the case with most software this action is based on the work of others and uses their code. We would like to give a special shout-out to the following parties and their code

Maintainers

This software is maintained by Conduction b.v.

License

© 2023 Conduction B.V.

Licensed under the EUPL. The version control system provides attribution for specific lines of code.

Remarks

This GitHub Action is published in the GitHub Marketplace. As such, you can find the Terms of Service here. Also, here you can find the GitHub Marketplace Developer Agreement.

About

This repository holds the code for creating a organisation specific open catalogi instance

Resources

License

Security policy

Stars

Watchers

Forks

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •