Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
D
DojoCLI
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
External wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Package registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
GitLab community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Dojo Project (HES-SO)
Projects
UI
DojoCLI
Commits
e6a31edc
Commit
e6a31edc
authored
1 year ago
by
michael.minelli
Browse files
Options
Downloads
Plain Diff
Merge branch 'release_by_ci-cd' into v2.0.0
parents
f83a79c2
8649f186
No related branches found
No related tags found
No related merge requests found
Pipeline
#26315
passed
1 year ago
Stage: build
Changes
2
Pipelines
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
.gitlab-ci.yml
+227
-38
227 additions, 38 deletions
.gitlab-ci.yml
CHANGELOG.md
+21
-19
21 additions, 19 deletions
CHANGELOG.md
with
248 additions
and
57 deletions
.gitlab-ci.yml
+
227
−
38
View file @
e6a31edc
variables
:
variables
:
BIN_FOLDER
:
/binary
BIN_NAME
:
dojo
VERSION_FILE
:
$BIN_FOLDER/VERSION
CLI_PROJECT_FOLDER
:
NodeApp
GIT_SUBMODULE_STRATEGY
:
recursive
GIT_SUBMODULE_STRATEGY
:
recursive
GIT_SUBMODULE_FORCE_HTTPS
:
"
true"
GIT_SUBMODULE_FORCE_HTTPS
:
"
true"
SECURE_FILES_DOWNLOAD_PATH
:
'
./'
SECURE_FILES_DOWNLOAD_PATH
:
'
./'
BIN_NAME
:
dojo
MACOS_PKG_EXTENSION
:
'
.pkg'
MACOS_PKG_BIN_NAME
:
"
${BIN_NAME}${MACOS_PKG_EXTENSION}"
ARTIFACTS_FOLDER
:
/artifacts
BIN_FOLDER_MACOS
:
$ARTIFACTS_FOLDER/macOS
BIN_FOLDER_LINUX
:
$ARTIFACTS_FOLDER/Linux
BIN_FOLDER_WINDOWS
:
$ARTIFACTS_FOLDER/Windows
BIN_FOLDER_MACOS_ARM64
:
$BIN_FOLDER_MACOS/arm64
BIN_FOLDER_MACOS_X64
:
$BIN_FOLDER_MACOS/x64
BIN_FILE_MACOS_ARM64
:
$BIN_FOLDER_MACOS_ARM64/$BIN_NAME
BIN_FILE_MACOS_X64
:
$BIN_FOLDER_MACOS_X64/$BIN_NAME
BIN_PKG_FILE_MACOS_ARM64
:
$BIN_FOLDER_MACOS_ARM64/$MACOS_PKG_BIN_NAME
BIN_PKG_FILE_MACOS_X64
:
$BIN_FOLDER_MACOS_X64/$MACOS_PKG_BIN_NAME
BIN_FILE_LINUX_ARM64
:
$BIN_FOLDER_LINUX/arm64/$BIN_NAME
BIN_FILE_LINUX_X64
:
$BIN_FOLDER_LINUX/x64/$BIN_NAME
BIN_FILE_WINDOWS_ARM64
:
$BIN_FOLDER_WINDOWS/arm64/$BIN_NAME.exe
BIN_FILE_WINDOWS_X64
:
$BIN_FOLDER_WINDOWS/x64/$BIN_NAME.exe
VERSION_FILE
:
$ARTIFACTS_FOLDER/VERSION
VERSION_DEV_SUFFIX
:
'
-dev'
PROJECT_FOLDER
:
NodeApp
PACKAGE_REGISTRY_URL
:
"
${CI_API_V4_URL}/projects/${CI_PROJECT_ID}/packages/generic/${BIN_NAME}"
.get_version
:
script
:
-
IS_DEV=$([[ $CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH ]] && echo
false
|| echo
true
)
-
VERSION=$(jq -r .version $PROJECT_FOLDER/package.json)$([[ $IS_DEV ==
true
]] && echo $VERSION_DEV_SUFFIX || echo '')
.get_packages_url
:
script
:
-
PACKAGE_URL_MACOS_ARM64_BIN="${PACKAGE_REGISTRY_URL}_macOS-arm64/${VERSION}/${BIN_NAME}"
-
PACKAGE_URL_MACOS_X64_BIN="${PACKAGE_REGISTRY_URL}_macOS-x64/${VERSION}/${BIN_NAME}"
-
PACKAGE_URL_MACOS_ARM64_PKG="${PACKAGE_REGISTRY_URL}_macOS-pkg-arm64/${VERSION}/${MACOS_PKG_BIN_NAME}"
-
PACKAGE_URL_MACOS_X64_PKG="${PACKAGE_REGISTRY_URL}_macOS-pkg-x64/${VERSION}/${MACOS_PKG_BIN_NAME}"
-
PACKAGE_URL_LINUX_ARM64_BIN="${PACKAGE_REGISTRY_URL}_Linux-arm64/${VERSION}/${BIN_NAME}"
-
PACKAGE_URL_LINUX_X64_BIN="${PACKAGE_REGISTRY_URL}_Linux-x64/${VERSION}/${BIN_NAME}"
-
PACKAGE_URL_WINDOWS_ARM64_BIN="${PACKAGE_REGISTRY_URL}_Windows-arm64/${VERSION}/${BIN_NAME}"
-
PACKAGE_URL_WINDOWS_X64_BIN="${PACKAGE_REGISTRY_URL}_Windows-x64/${VERSION}/${BIN_NAME}"
.build_cli
:
.build_cli
:
script
:
script
:
-
cd NodeApp
-
cd NodeApp
...
@@ -17,86 +60,232 @@ variables:
...
@@ -17,86 +60,232 @@ variables:
-
npm install
-
npm install
-
npm run build
-
npm run build
# Build binaries
# Build binaries
-
npx pkg . -t node18-macos-arm64 --output $BIN_FOLDER/macOS/arm64/$BIN_NAME --no-bytecode --public-packages "*" --public
## macOS
-
npx pkg . -t node18-macos-x64 --output $BIN_FOLDER/macOS/x64/$BIN_NAME --no-bytecode --public-packages "*" --public
-
npx pkg . -t node18-macos-arm64 --output $BIN_FILE_MACOS_ARM64 --no-bytecode --public-packages "*" --public
-
npx pkg . -t node18-linuxstatic-arm64 --output $BIN_FOLDER/linux/arm64/$BIN_NAME --no-bytecode --public-packages "*" --public
-
npx pkg . -t node18-macos-x64 --output $BIN_FILE_MACOS_X64 --no-bytecode --public-packages "*" --public
-
npx pkg . -t node18-linuxstatic-x64 --output $BIN_FOLDER/linux/x64/$BIN_NAME --no-bytecode --public-packages "*" --public
## Linux
-
npx pkg . -t node18-win-arm64 --output $BIN_FOLDER/Windows/arm64/$BIN_NAME --no-bytecode --public-packages "*" --public
-
npx pkg . -t node18-linuxstatic-arm64 --output $BIN_FILE_LINUX_ARM64 --no-bytecode --public-packages "*" --public
-
npx pkg . -t node18-win-x64 --output $BIN_FOLDER/Windows/x64/$BIN_NAME --no-bytecode --public-packages "*" --public
-
npx pkg . -t node18-linuxstatic-x64 --output $BIN_FILE_LINUX_X64 --no-bytecode --public-packages "*" --public
## Windows
.macos-sign_and_pkg
:
-
npx pkg . -t node18-win-arm64 --output $BIN_FILE_WINDOWS_ARM64 --no-bytecode --public-packages "*" --public
-
npx pkg . -t node18-win-x64 --output $BIN_FILE_WINDOWS_X64 --no-bytecode --public-packages "*" --public
.sign_macos
:
script
:
script
:
# Sign excecutable
# Sign excecutable
-
codesign --force --options=runtime --entitlements ../../../Resources/macApp/Signing/entitlements.plist --sign $SIGN_DEV_ID_APP --keychain $SIGN_LOGIN_KEYCHAIN_PATH --timestamp ${BIN_NAME}
-
codesign --force --options=runtime --entitlements ../../../Resources/macApp/Signing/entitlements.plist --sign $SIGN_DEV_ID_APP --keychain $SIGN_LOGIN_KEYCHAIN_PATH --timestamp ${BIN_NAME}
# Package and notarize the app
# Package and notarize the app
-
xcrun notarytool store-credentials --apple-id $SIGN_APPLE_ID --team-id $SIGN_TEAM_ID --password $SIGN_APP_PASSWORD --keychain $SIGN_LOGIN_KEYCHAIN_PATH $SIGN_KEYCHAIN_PROFILE
-
xcrun notarytool store-credentials --apple-id $SIGN_APPLE_ID --team-id $SIGN_TEAM_ID --password $SIGN_APP_PASSWORD --keychain $SIGN_LOGIN_KEYCHAIN_PATH $SIGN_KEYCHAIN_PROFILE
-
ditto ${BIN_NAME} ${BIN_NAME}_pkg/usr/local/bin/
-
ditto ${BIN_NAME} ${BIN_NAME}_pkg/usr/local/bin/
-
productbuild --identifier $SIGN_IDENTIFIER --version $VERSION --sign $SIGN_DEV_ID_INST --keychain $SIGN_LOGIN_KEYCHAIN_PATH --timestamp --root ${BIN_NAME}_pkg / ${BIN_NAME}
.pkg
-
productbuild --identifier $SIGN_IDENTIFIER --version $VERSION --sign $SIGN_DEV_ID_INST --keychain $SIGN_LOGIN_KEYCHAIN_PATH --timestamp --root ${BIN_NAME}_pkg / ${
MACOS_PKG_
BIN_NAME}
-
xcrun notarytool submit ${BIN_NAME}.pkg --keychain $SIGN_LOGIN_KEYCHAIN_PATH --keychain-profile $SIGN_KEYCHAIN_PROFILE --wait
-
xcrun notarytool submit ${BIN_NAME}.pkg --keychain $SIGN_LOGIN_KEYCHAIN_PATH --keychain-profile $SIGN_KEYCHAIN_PROFILE --wait
-
xcrun stapler staple ${BIN_NAME}.pkg
-
xcrun stapler staple ${BIN_NAME}.pkg
#Clean folder
#Clean folder
-
rm -Rf ${BIN_NAME}_pkg
-
rm -Rf ${BIN_NAME}_pkg
.clean_release
:
script
:
# Delete release if it already exists
-
'
curl
--request
DELETE
--header
"JOB-TOKEN:
$CI_JOB_TOKEN"
"${CI_API_V4_URL}/projects/${CI_PROJECT_ID}/releases/${VERSION}"'
.clean_packages
:
script
:
# Get all packages of the project
-
'
curl
--header
"JOB-TOKEN:
$CI_JOB_TOKEN"
"${CI_API_V4_URL}/projects/${CI_PROJECT_ID}/packages"
>
gitlabPackages.json'
# Filter and select packages to delete (based on version)
-
packagesToDelete=`jq -r '.[] | select(.version=="'${VERSION}'") | ._links.delete_api_path' gitlabPackages.json`
# Delete packages by calling Gitlab API
-
>
for deletePath in $packagesToDelete; do
echo "Deleting package at path : ${deletePath}"
curl --request DELETE --header "JOB-TOKEN: $CI_JOB_TOKEN" "${deletePath}"
done
stages
:
stages
:
-
build
-
build
-
sign
-
sign
-
clean-same-release
-
clean-dev-release
-
upload
-
release
default
:
image
:
node:latest
cache
:
paths
:
-
$CLI_PROJECT_FOLDER/node_modules/
before_script
:
-
mkdir -p $BIN_FOLDER
-
apt update
-
apt install -y jq
-
>
VERSION=$(jq -r .version $CLI_PROJECT_FOLDER/package.json)
test:
build
:
build:
test
:
stage
:
build
stage
:
build
tags
:
tags
:
-
build
-
build
image
:
node:latest
script
:
script
:
-
apt update
-
apt install -y jq
-
!reference
[
.get_version
,
script
]
-
!reference
[
.build_cli
,
script
]
-
!reference
[
.build_cli
,
script
]
rules
:
rules
:
-
if
:
'
$CI_COMMIT_BRANCH
!=
$CI_DEFAULT_BRANCH
&&
$CI_COMMIT_BRANCH
!~
/^v[0-9]+(\.[0-9]+)*$/'
-
if
:
'
$CI_COMMIT_BRANCH
!=
$CI_DEFAULT_BRANCH
&&
$CI_COMMIT_BRANCH
!~
/^v[0-9]+(\.[0-9]+)*$/'
version:
build
:
build:
version
:
stage
:
build
stage
:
build
tags
:
tags
:
-
build
-
build
image
:
node:latest
script
:
script
:
-
apt update
-
apt install -y jq
-
!reference
[
.get_version
,
script
]
-
mkdir -p $ARTIFACTS_FOLDER
-
echo $VERSION > $VERSION_FILE
-
echo $VERSION > $VERSION_FILE
-
!reference
[
.build_cli
,
script
]
-
!reference
[
.build_cli
,
script
]
artifacts
:
artifacts
:
untracked
:
true
untracked
:
true
paths
:
paths
:
-
$
BIN
_FOLDER/*
-
$
ARTIFACTS
_FOLDER/*
expire_in
:
1 hour
expire_in
:
1 hour
rules
:
rules
:
-
if
:
'
$CI_COMMIT_BRANCH
==
$CI_DEFAULT_BRANCH
||
$CI_COMMIT_BRANCH
=~
/^v[0-9]+(\.[0-9]+)*$/'
-
if
:
'
$CI_COMMIT_BRANCH
==
$CI_DEFAULT_BRANCH
||
$CI_COMMIT_BRANCH
=~
/^v[0-9]+(\.[0-9]+)*$/'
sign
_
macos
:
sign
:
macos
:
stage
:
sign
stage
:
sign
needs
:
[
"
version:build"
]
inherit
:
default
:
false
tags
:
tags
:
-
macos_signing
-
macos_signing
dependencies
:
dependencies
:
-
version
:build
-
build:
version
script
:
script
:
-
VERSION=$(cat $VERSION_FILE)
-
VERSION=$(cat $VERSION_FILE)
-
security unlock-keychain -p $SIGN_KEYCHAIN_PASSWORD $SIGN_LOGIN_KEYCHAIN_PATH
-
security unlock-keychain -p $SIGN_KEYCHAIN_PASSWORD $SIGN_LOGIN_KEYCHAIN_PATH
-
cd $BIN_FOLDER
/macOS/arm
64
-
cd $BIN_FOLDER
_MACOS_ARM
64
-
!reference
[
.macos
-sign_and_pkg
,
script
]
-
!reference
[
.
sign_
macos
,
script
]
-
cd $BIN_FOLDER
/macOS/x
64
-
cd $BIN_FOLDER
_MACOS_X
64
-
!reference
[
.macos
-sign_and_pkg
,
script
]
-
!reference
[
.
sign_
macos
,
script
]
artifacts
:
artifacts
:
paths
:
paths
:
-
$BIN_FOLDER/*
-
$ARTIFACTS_FOLDER/*
expire_in
:
1 week
expire_in
:
1 day
rules
:
-
if
:
'
$CI_COMMIT_BRANCH
==
$CI_DEFAULT_BRANCH
||
$CI_COMMIT_BRANCH
=~
/^v[0-9]+(\.[0-9]+)*$/'
clean:release
:
stage
:
clean-same-release
tags
:
-
gitlab_clean
image
:
registry.gitlab.com/gitlab-ci-utils/curl-jq:latest
script
:
-
!reference
[
.get_version
,
script
]
-
!reference
[
.clean_release
,
script
]
rules
:
-
if
:
'
$CI_COMMIT_BRANCH
==
$CI_DEFAULT_BRANCH
||
$CI_COMMIT_BRANCH
=~
/^v[0-9]+(\.[0-9]+)*$/'
clean:packages
:
stage
:
clean-same-release
tags
:
-
gitlab_clean
image
:
registry.gitlab.com/gitlab-ci-utils/curl-jq:latest
script
:
-
!reference
[
.get_version
,
script
]
-
!reference
[
.clean_packages
,
script
]
rules
:
-
if
:
'
$CI_COMMIT_BRANCH
==
$CI_DEFAULT_BRANCH
||
$CI_COMMIT_BRANCH
=~
/^v[0-9]+(\.[0-9]+)*$/'
clean-dev:release
:
stage
:
clean-dev-release
tags
:
-
gitlab_clean
image
:
registry.gitlab.com/gitlab-ci-utils/curl-jq:latest
script
:
-
!reference
[
.get_version
,
script
]
-
VERSION="${VERSION}${VERSION_DEV_SUFFIX}"
-
!reference
[
.clean_release
,
script
]
rules
:
-
if
:
'
$CI_COMMIT_BRANCH
==
$CI_DEFAULT_BRANCH'
clean-dev:packages
:
stage
:
clean-dev-release
tags
:
-
gitlab_clean
image
:
registry.gitlab.com/gitlab-ci-utils/curl-jq:latest
script
:
-
!reference
[
.get_version
,
script
]
-
VERSION="${VERSION}${VERSION_DEV_SUFFIX}"
-
!reference
[
.clean_packages
,
script
]
rules
:
-
if
:
'
$CI_COMMIT_BRANCH
==
$CI_DEFAULT_BRANCH'
upload:packages
:
stage
:
upload
tags
:
-
gitlab_package
dependencies
:
-
sign:macos
image
:
registry.gitlab.com/gitlab-ci-utils/curl-jq:latest
script
:
-
!reference
[
.get_version
,
script
]
-
!reference
[
.get_packages_url
,
script
]
#macOS
-
'
curl
--header
"JOB-TOKEN:
$CI_JOB_TOKEN"
--upload-file
${BIN_FILE_MACOS_ARM64}
"${PACKAGE_URL_MACOS_ARM64_BIN}";'
-
'
curl
--header
"JOB-TOKEN:
$CI_JOB_TOKEN"
--upload-file
${BIN_FILE_MACOS_X64}
"${PACKAGE_URL_MACOS_X64_BIN}";'
-
'
curl
--header
"JOB-TOKEN:
$CI_JOB_TOKEN"
--upload-file
${BIN_PKG_FILE_MACOS_ARM64}
"${PACKAGE_URL_MACOS_ARM64_PKG}";'
-
'
curl
--header
"JOB-TOKEN:
$CI_JOB_TOKEN"
--upload-file
${BIN_PKG_FILE_MACOS_X64}
"${PACKAGE_URL_MACOS_X64_PKG}";'
#Linux
-
'
curl
--header
"JOB-TOKEN:
$CI_JOB_TOKEN"
--upload-file
${BIN_FILE_LINUX_ARM64}
"${PACKAGE_URL_LINUX_ARM64_BIN}";'
-
'
curl
--header
"JOB-TOKEN:
$CI_JOB_TOKEN"
--upload-file
${BIN_FILE_LINUX_X64}
"${PACKAGE_URL_LINUX_X64_BIN}";'
#Windows
-
'
curl
--header
"JOB-TOKEN:
$CI_JOB_TOKEN"
--upload-file
${BIN_FILE_WINDOWS_ARM64}
"${PACKAGE_URL_WINDOWS_ARM64_BIN}";'
-
'
curl
--header
"JOB-TOKEN:
$CI_JOB_TOKEN"
--upload-file
${BIN_FILE_WINDOWS_X64}
"${PACKAGE_URL_WINDOWS_X64_BIN}";'
rules
:
rules
:
-
if
:
'
$CI_COMMIT_BRANCH
==
$CI_DEFAULT_BRANCH
||
$CI_COMMIT_BRANCH
=~
/^v[0-9]+(\.[0-9]+)*$/'
-
if
:
'
$CI_COMMIT_BRANCH
==
$CI_DEFAULT_BRANCH
||
$CI_COMMIT_BRANCH
=~
/^v[0-9]+(\.[0-9]+)*$/'
release_job
:
stage
:
release
tags
:
-
release
image
:
registry.gitlab.com/gitlab-ci-utils/curl-jq:latest
script
:
-
!reference
[
.get_version
,
script
]
-
!reference
[
.get_packages_url
,
script
]
-
echo 'Running release_job'
-
CHANGELOG_LINE_START=`awk '/##\ [0-9]+\.[0-9]+\.[0-9]+/{print NR; exit;}' CHANGELOG.md`
-
CHANGELOG_LINE_END=`awk '/##\ [0-9]+\.[0-9]+\.[0-9]+/{ count++; if(count>1) {print NR; exit;}}' CHANGELOG.md`
-
DESCRIPTION=`awk 'NR > '$CHANGELOG_LINE_START' && NR < '$CHANGELOG_LINE_END'' CHANGELOG.md`
-
>
RELEASE_DATA=$(jq --null-input --arg version "$VERSION" --arg description "# Changelog (version $VERSION) $DESCRIPTION" --arg tag_name "$VERSION" --arg ref "$CI_COMMIT_SHORT_SHA" '{
"name": $version,
"description": $description,
"tag_name": $tag_name,
"ref": $ref,
"assets": {
"links": [
{
"name": "Windows (ARM64) binary",
"url": "'${PACKAGE_URL_WINDOWS_ARM64_BIN}'",
},{
"name": "Windows (x64) binary",
"url": "'${PACKAGE_URL_WINDOWS_X64_BIN}'",
},{
"name": "Linux (ARM64) binary",
"url": "'${PACKAGE_URL_LINUX_ARM64_BIN}'",
},{
"name": "Linux (x64) binary",
"url": "'${PACKAGE_URL_LINUX_X64_BIN}'",
},{
"name": "macOS (Intel) binary",
"url": "'${PACKAGE_URL_MACOS_X64_BIN}'",
},{
"name": "macOS (Apple Silicon) binary",
"url": "'${PACKAGE_URL_MACOS_ARM64_BIN}'",
},{
"name": "macOS (Intel) package",
"url": "'${PACKAGE_URL_MACOS_X64_PKG}'",
},{
"name": "macOS (Apple Silicon) package",
"url": "'${PACKAGE_URL_MACOS_ARM64_PKG}'",
}
]
}
}')
-
>
curl --data "${RELEASE_DATA}" \
--header "Content-Type: application/json" \
--header "JOB-TOKEN: $CI_JOB_TOKEN" \
--request POST "${CI_API_V4_URL}/projects/${CI_PROJECT_ID}/releases"
rules
:
-
if
:
'
$CI_COMMIT_BRANCH
==
$CI_DEFAULT_BRANCH
||
$CI_COMMIT_BRANCH
=~
/^v[0-9]+(\.[0-9]+)*$/'
\ No newline at end of file
This diff is collapsed.
Click to expand it.
CHANGELOG.md
+
21
−
19
View file @
e6a31edc
# Changelog
# Changelog
<!--
### ✨ Feature
### 🤏 Minor change
### 🎨 Interface
### 🐛 Bugfix
### 🔒 Security
### 🚀️ CI / CD
### 🔨 Internal / Developers
### 📚 Documentation
**💥 Breaking:**
**⚠️ Deprecation:**
-->
## 2.0.0 (?)
## 2.0.0 (?)
### Feature
###
✨
Feature
-
Added license: AGPLv3
-
Added license: AGPLv3
### Interface
###
🎨
Interface
-
🔴
Breaking: Renamed
`enonce`
to
`assignment`
-
**💥
Breaking:
**
Renamed
`enonce`
to
`assignment`
-
🔴
Breaking: Renamed
`exercice`
to
`exercise`
-
**💥
Breaking:
**
Renamed
`exercice`
to
`exercise`
### Internal / Developers
###
🔨
Internal / Developers
-
Auto release by pipeline
-
Auto release by pipeline
-
For vX.Y.Z branch create release and tag with
`-dev`
suffix
-
For vX.Y.Z branch create release and tag with
`-dev`
suffix
-
For main branch create definitive release and remove
`-dev`
releases
-
For main branch create definitive release and remove
`-dev`
releases
...
@@ -17,17 +31,5 @@
...
@@ -17,17 +31,5 @@
## 1.0.1 (2023-08-12)
## 1.0.1 (2023-08-12)
### Feature
### ✨ Feature
-
Initial release of the project
-
🎉 Initial release of the project
\ No newline at end of file
<!--
### Feature
### Minor change
### Interface
### Bugfix
### Internal / Developers
### Documentation
🔴 Breaking:
⚠️ Deprecation: ️
-->
\ No newline at end of file
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment