Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/miyako/4d-template-component-cicd
A template repository for 4D component developement
https://github.com/miyako/4d-template-component-cicd
4d-action 4d-component 4d-workflow cicd tool4d
Last synced: 14 days ago
JSON representation
A template repository for 4D component developement
- Host: GitHub
- URL: https://github.com/miyako/4d-template-component-cicd
- Owner: miyako
- License: mit
- Created: 2024-03-04T14:50:47.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-08-21T04:00:17.000Z (5 months ago)
- Last Synced: 2024-11-11T02:19:16.458Z (2 months ago)
- Topics: 4d-action, 4d-component, 4d-workflow, cicd, tool4d
- Language: 4D
- Homepage:
- Size: 187 KB
- Stars: 5
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
A template repository for 4D component developement.
# About
This repository is configured to enable CI/CD of [4D components](https://developer.4d.com/docs/Concepts/components) using a chain of [GitHub Actions](https://docs.github.com/en/actions).
You may clone it to get started with your own 4D component development on GitHub.
**Note**: If you rename the project, you should modify `env.project_path` in your [`publish.yml`](https://github.com/miyako/4d-template-component-cicd/blob/main/.github/workflows/publish.yml).
See also [`test-build-component.yml`](https://github.com/miyako/4d-template-component-cicd/blob/main/.github/workflows/test-build-component.yml#L18), [`run-tests.yml`](https://github.com/miyako/4d-template-component-cicd/blob/main/.github/workflows/run-tests.yml#L15).
The build destination path is `${PWD}`. See [`miyako/4D/.github/actions/build-component`](https://github.com/miyako/4D/blob/v1/.github/actions/build-component/action.yml#L36)
```yml
env:
project_path: example/Project/example.4DProject
```### Development
Whenever you push changes to your `main` branch, the default workflow is automatically triggered in `patch` mode.
```yml
on:
push:
branches:
- main
paths:
- '*/Project/Sources/**/*.4dm'
- '*/Project/Sources/*/*.4DForm'
- '*/Project/Sources/*.4DCatalog'
- '*/Project/Resources/**'
```### Deployment
You can manually dispatch the default workflow for any branch, in either `patch` `minor` `major` mode.
## Workflow
The workflow does the following:
1. The project is compiled on a GitHub hosted runner (`macos-latest`) using `tool4d`.
1. The project is built as a component for ARM/Apple Silicon and AMD/Intel processors.
1. The component is signed with your **Apple Developer ID Application** certificate.
1. The component is submitted to Apple for notarisation.
1. The component is published under Releases (.zip and .dmg format).# Prerequisites
The repository must have [`package.json`](https://github.com/miyako/4d-template-component-cicd/blob/main/package.json) file at the root level.
**Note**: The format is obviously inspired by, but not necessarily relate to, `npm`. In future versions, 4D may roll out its own way of managing dependencies.
In addition to arbitrary meta properties, you should provide the following build parameters:
|Path|Type|Description
|:-|:-:|:-|
|version|Text|[semantic versioning 2.0.0](https://semver.org)|
|tool.platform|Text|always `macos`|
|tool.branch|Text|default=`20.x`|
|tool.version|Text|default=`20.2`|
|tool.build|Text|default=`latest`|
|tool.arch|Text|`x86` or `arm`|**Note**: ~~Free GitHub hosted macOS runners are running on Intel. If you have a subscription, you can select [ARM hosted runners](https://docs.github.com/en/actions/using-github-hosted-runners/about-larger-runners/about-larger-runners)~~. ARM macOS runners are now [available](https://docs.github.com/en/actions/using-github-hosted-runners/using-github-hosted-runners/about-github-hosted-runners).
* For Feature Releases, the space should be URL encoded, e.g. `20%20Rx` `20%20R6`.
* The `latest` keyword can't be used while a Feature Release is in beta.Your Apple Developer credentials should be stored in [GitHub Actions secrets](https://docs.github.com/en/actions/security-guides/using-secrets-in-github-actions).
From Xcode or Keychain, [export signing certificate](https://help.apple.com/xcode/mac/current/#/dev154b28f09). You will be asked to set a password.
|Secret|Description
|:-|:-|
|`APPLE_DEVELOPER_ID_CERTIFICATE`|base64 encoded|
|`APPLE_DEVELOPER_ID_CERTIFICATE_PASSWORD`|password to read the certificate|
|`KEYCHAIN_PASSWORD`|an arbitrary password (used to access temporary keychain)|
|`NOTARYTOOL_APPLE_ID`|`xcrun notarytool submit` parameter|
|`NOTARYTOOL_TEAM_ID`|`xcrun notarytool submit` parameter|
|`NOTARYTOOL_PASSWORD`|`xcrun notarytool submit` parameter|
|`CODESIGN_APPLE_ID`|`codesign`parameter|# Reusable Workflow Actions
The following actions are used by the default workflow. If your repository is not allowed to execute [external workflows](https://docs.github.com/en/enterprise-cloud@latest/actions/using-workflows/reusing-workflows), clone them.
* [`miyako/4D/.github/actions/package-set-version@v1`](https://github.com/miyako/4D/blob/v1/.github/actions/package-set-version/action.yml) - update
`package.json`
* [`miyako/4D/.github/actions/tool4d-get-version@v1`](https://github.com/miyako/4D/blob/v1/.github/actions/tool4d-get-version/action.yml) - parse `package.json`
* [`miyako/4D/.github/actions/tool4d-download@v1`](https://github.com/miyako/4D/blob/v1/.github/actions/tool4d-download/action.yml) - download `tool4d`
* [`miyako/4D/.github/actions/build-component@v1`](https://github.com/miyako/4D/blob/v1/.github/actions/build-component/action.yml) - build component with `tool4d`
* [`miyako/4D/.github/actions/deployment-setup-keychain@v1`](https://github.com/miyako/4D/blob/v1/.github/actions/deployment-setup-keychain/action.yml) -setup keychain with secrets
* [`miyako/4D/.github/actions/deployment-codesign-product@v1`](https://github.com/miyako/4D/blob/v1/.github/actions/deployment-codesign-product/action.yml) - codesign and notarise component
* [`miyako/4D/.github/actions/deployment-create-zip@v1`](https://github.com/miyako/4D/blob/v1/.github/actions/deployment-create-zip/action.yml) - create .zip from .dmg
* [`miyako/4D/.github/actions/deployment-release-assets@v1`](https://github.com/miyako/4D/blob/v1/.github/actions/deployment-release-assets/action.yml) - upload .zip and .dmgIn addition, the following GitHub workflow actions are used internally.
* [`actions/upload-release-asset@v1`](https://github.com/actions/upload-release-asset)
* [`actions/create-release@v1`](https://github.com/actions/actions/create-release)# References
[Installing an Apple certificate on macOS runners for Xcode development](https://docs.github.com/en/actions/deployment/deploying-xcode-applications/installing-an-apple-certificate-on-macos-runners-for-xcode-development)
c.f. https://localazy.com/blog/how-to-automatically-sign-macos-apps-using-github-actions