From ec472de4431d8654646c20f29f1db89dacb90bcd Mon Sep 17 00:00:00 2001 From: "(Holloway) Chew, Kean Ho" Date: Fri, 7 Jun 2024 13:49:36 +0800 Subject: [PATCH] root: fully implemented srcNODE with CI Since we now have a working srcNODE technology, we can implement its technological support and its CI. Hence, let's do this. This patch fully implements srcNODE with CI in root repository. Co-authored-by: Shuralyov, Jean Co-authored-by: Galyna, Cory Co-authored-by: (Holloway) Chew, Kean Ho Signed-off-by: (Holloway) Chew, Kean Ho --- CONFIG.toml | 113 +++++- README.md | 5 +- automataCI/SECRETS-template.toml | 107 +++--- automataCI/_package-npm_unix-any.sh | 80 ++++ automataCI/_package-npm_windows-any.ps1 | 73 ++++ automataCI/_release-npm_unix-any.sh | 67 ++++ automataCI/_release-npm_windows-any.ps1 | 68 ++++ automataCI/common_unix-any.sh | 6 + automataCI/common_windows-any.ps1 | 5 + automataCI/notarize_unix-any.sh | 3 +- automataCI/notarize_windows-any.ps1 | 6 +- automataCI/package_unix-any.sh | 11 +- automataCI/package_windows-any.ps1 | 11 +- automataCI/release_unix-any.sh | 22 +- automataCI/release_windows-any.ps1 | 22 +- automataCI/services/archive/tar.ps1 | 93 ++++- automataCI/services/archive/tar.sh | 87 ++++- automataCI/services/archive/zip.ps1 | 12 +- automataCI/services/archive/zip.sh | 15 +- automataCI/services/compilers/citation.ps1 | 19 +- automataCI/services/compilers/flatpak.ps1 | 2 +- automataCI/services/compilers/node.ps1 | 414 +++++++++++++++++++- automataCI/services/compilers/node.sh | 426 ++++++++++++++++++++- automataCI/services/io/fs.ps1 | 65 +++- automataCI/services/io/fs.sh | 51 ++- automataCI/services/io/net/http.ps1 | 33 +- automataCI/services/io/net/http.sh | 18 + automataCI/services/io/os.ps1 | 23 ++ automataCI/services/io/os.sh | 25 ++ src/.ci/_package-archive_unix-any.sh | 2 + src/.ci/_package-archive_windows-any.ps1 | 2 + src/.ci/_package-deb_unix-any.sh | 2 + src/.ci/_package-deb_windows-any.ps1 | 2 + src/.ci/_package-docker_unix-any.sh | 2 + src/.ci/_package-docker_windows-any.ps1 | 2 + src/.ci/_package-flatpak_unix-any.sh | 2 + src/.ci/_package-flatpak_windows-any.ps1 | 2 + src/.ci/_package-ipk_unix-any.sh | 2 + src/.ci/_package-ipk_windows-any.ps1 | 2 + src/.ci/_package-npm_unix-any.sh | 54 +++ src/.ci/_package-npm_windows-any.ps1 | 55 +++ src/.ci/_package-rpm_unix-any.sh | 2 + src/.ci/_package-rpm_windows-any.ps1 | 2 + src/.ci/package_unix-any.sh | 1 + src/.ci/package_windows-any.ps1 | 1 + srcANGULAR/.ci/build_unix-any.sh | 1 - srcANGULAR/.ci/build_windows-any.ps1 | 1 - srcNODE/.ci/build_unix-any.sh | 238 ++++++++++++ srcNODE/.ci/build_windows-any.ps1 | 228 +++++++++++ srcNODE/.ci/prepare_unix-any.sh | 52 +++ srcNODE/.ci/prepare_windows-any.ps1 | 52 +++ srcNODE/.ci/start_unix-any.sh | 47 +++ srcNODE/.ci/start_windows-any.ps1 | 43 +++ srcNODE/.ci/stop_unix-any.sh | 35 ++ srcNODE/.ci/stop_windows-any.ps1 | 34 ++ srcNODE/.ci/test_unix-any.sh | 76 ++++ srcNODE/.ci/test_windows-any.ps1 | 77 ++++ srcNODE/package-lock.json | 4 +- srcNODE/package.json | 8 +- srcNODE/src/entities.ts | 6 + srcNODE/src/greeters.ts | 16 + srcNODE/src/index.spec.ts | 10 +- srcNODE/src/index.ts | 12 +- srcNODE/src/locations.ts | 3 + 64 files changed, 2787 insertions(+), 173 deletions(-) create mode 100644 automataCI/_package-npm_unix-any.sh create mode 100644 automataCI/_package-npm_windows-any.ps1 create mode 100644 automataCI/_release-npm_unix-any.sh create mode 100644 automataCI/_release-npm_windows-any.ps1 create mode 100644 src/.ci/_package-npm_unix-any.sh create mode 100644 src/.ci/_package-npm_windows-any.ps1 create mode 100644 srcNODE/.ci/build_unix-any.sh create mode 100644 srcNODE/.ci/build_windows-any.ps1 create mode 100644 srcNODE/.ci/prepare_unix-any.sh create mode 100644 srcNODE/.ci/prepare_windows-any.ps1 create mode 100644 srcNODE/.ci/start_unix-any.sh create mode 100644 srcNODE/.ci/start_windows-any.ps1 create mode 100644 srcNODE/.ci/stop_unix-any.sh create mode 100644 srcNODE/.ci/stop_windows-any.ps1 create mode 100644 srcNODE/.ci/test_unix-any.sh create mode 100644 srcNODE/.ci/test_windows-any.ps1 create mode 100644 srcNODE/src/entities.ts create mode 100644 srcNODE/src/greeters.ts create mode 100644 srcNODE/src/locations.ts diff --git a/CONFIG.toml b/CONFIG.toml index b17b0cfd..7e62446e 100644 --- a/CONFIG.toml +++ b/CONFIG.toml @@ -66,13 +66,13 @@ PRODUCT_APP_UUID = "76C7A54E-7360-CB70-1A5E-44D8A00CCB30" # PROJECT_NAME # This is the name of the product used in documentation, marketing addresses # etc only. For programming purposes, PROJECT_SKU is used instead. -PROJECT_NAME = "AutomataCI" +PROJECT_NAME = "Chew Kean Ho's AutomataCI" # PROJECT_PITCH # A short elevator pitch about the project used as a short description. Max # Max: 60 characters. -PROJECT_PITCH = "Solid Foundation for Kickstarting Your Software Development" +PROJECT_PITCH = "A redistributable & semi-autonomous CI infrastructure." # PROJECT_VERSION @@ -103,33 +103,39 @@ PROJECT_CADENCE = "1" PROJECT_LICENSE = "Apache-2.0" +# PROJECT_SCOPE +# The scope of the project being housed in (e.g. +# GitHub Username|Organization Name, NPMJS scope, etc). This is required for +# certain packages' ecosystems such as but not limited to NPM. +PROJECT_SCOPE = "chewkeanho" + + # PROJECT_CONTACT_BRAND -# Entity's short brand name. -# It should be in lowercase and should not be using dash ('-'), -# underscore ('_'), and space (' ') for maximum compatibility. -PROJECT_CONTACT_BRAND = "mybrand" +# Contact Entity's short brand name. It should be in lowercase and should not be +# using dash ('-'), underscore ('_'), and space (' ') for maximum compatibility. +PROJECT_CONTACT_BRAND = "chewkeanho" # PROJECT_CONTACT_BRAND_TITLECASE # The titlecase version of PROJECT_CONTACT_BRAND. Used in certain packager # control scripts like MSI. Conditions is the same as PROJECT_CONTACT_BRAND # except it is in the TitleCase representation. -PROJECT_CONTACT_BRAND_TITLECASE = "myBRAND" +PROJECT_CONTACT_BRAND_TITLECASE = "ChewKeanHo" # PROJECT_CONTACT_NAME # Entity's full name for inquiries. -PROJECT_CONTACT_NAME = "Your Legal Full Name Here" +PROJECT_CONTACT_NAME = "(Holloway) Chew, Kean Ho" # PROJECT_CONTACT_EMAIL # Entity's email channel for email communications. -PROJECT_CONTACT_EMAIL = "contact@youremail.example" +PROJECT_CONTACT_EMAIL = "hello@hollowaykeanho.com" # PROJECT_CONTACT_WEBSITE # Entity's website channel for sourcing information. -PROJECT_CONTACT_WEBSITE = "https://your-product.website.here" +PROJECT_CONTACT_WEBSITE = "https://github.com/ChewKeanHo/AutomataCI" # PROJECT_SOURCE_URL @@ -166,8 +172,8 @@ AUTOMATACI_LANG = "" # This is a control variable used for enabling Angular technology and also # defining its source codes directory relative to PROJECT_PATH_ROOT. Depending # on the offered service (e.g. GitHub Actions), setting this variable with value -# shall notify the CI provider to setup Go development environment -# automatically. +# shall notify the CI provider to setup a localized virtual environment for +# development automatically. # # To enable it: simply supply the path (e.g. default is 'srcANGULAR'). # To disable it: simply supply an empty path (e.g. default is ''). @@ -183,7 +189,8 @@ PROJECT_ANGULAR = '' # This is a control variable used for enabling C technology and also defining # its source codes directory relative to PROJECT_PATH_ROOT. Depending on the # offered service (e.g. GitHub Actions), setting this variable with value shall -# notify the CI provider to setup Go development environment automatically. +# notify the CI provider to setup a localized virtual environment for +# development automatically. # # To enable it: simply supply the path (e.g. default is 'srcC'). # To disable it: simply supply an empty path (e.g. default is ''). @@ -393,7 +400,8 @@ GOOGLEAI_BLOCK_HARASSMENT = 'BLOCK_NONE' # This is a control variable used for enabling LibreOffice technology and also # defining its source directory relative to PROJECT_PATH_ROOT. Depending on the # offered service (e.g. GitHub Actions), setting this variable with value shall -# notify the CI provider to setup Go development environment automatically. +# notify the CI provider to setup a localized virtual environment for +# development automatically. # # To enable it: simply supply the path (e.g. default is 'srcLIBREOFFICE'). # To disable it: simply supply an empty path (e.g. default is ''). @@ -430,7 +438,8 @@ PROJECT_LIBREOFFICE_VERSION = "24.2.1" # This is a control variable used for enabling Go technology and also defining # its source codes directory relative to PROJECT_PATH_ROOT. Depending on the # offered service (e.g. GitHub Actions), setting this variable with value shall -# notify the CI provider to setup Go development environment automatically. +# notify the CI provider to setup a localized virtual environment for +# development automatically. # # To enable it: simply supply the path (e.g. default is 'srcGO'). # To disable it: simply supply an empty path (e.g. default is ''). @@ -452,7 +461,8 @@ PROJECT_PATH_GO_ENGINE = "go-engine" # This is a control variable used for enabling Nim technology and also defining # its source codes directory relative to PROJECT_PATH_ROOT. Depending on the # offered service (e.g. GitHub Actions), setting this variable with value shall -# notify the CI provider to setup Go development environment automatically. +# notify the CI provider to setup a localized virtual environment for +# development automatically. # # To enable it: simply supply the path (e.g. default is 'srcNIM'). # To disable it: simply supply an empty path (e.g. default is ''). @@ -467,6 +477,67 @@ PROJECT_PATH_NIM_ENGINE = "nim-engine" +###################### +# NODE TECHNOLOGY # +###################### +# PROJECT_NODE +# This is a control variable used for enabling NodeJS technology and also +# defining its source codes directory relative to PROJECT_PATH_ROOT. Depending +# on the offered service (e.g. GitHub Actions), setting this variable with value +# shall notify the CI provider to setup a localized virtual environment for +# development automatically. +# +# To enable it: simply supply the path (e.g. default is 'srcNODE'). +# To disable it: simply supply an empty path (e.g. default is ''). +PROJECT_NODE = 'srcNODE' + + +# PROJECT_PATH_NODE_ENGINE +# This is a relative pathing to PROJECT_PATH_ROOT + PROJECT_PATH_TOOLS for +# setting up localized virtual environment. +PROJECT_PATH_NODE_ENGINE = "node-engine" + + +# PROJECT_NODE_VERSION +# This is to specify which version of node to be downloaded for the project +# as the localized virtual environment engine. Please refer to: +# https://nodejs.org/en/download/prebuilt-binaries/current +# for values. +# +# Leaving it empty shall set AutomataCI to use the system-level NodeJS +# (e.g: your pre-configured NodeJS). +# +# To enable: specify a version (e.g. 'v22.2.0') +# To disable: keep it empty (''). +PROJECT_NODE_VERSION = 'v22.2.0' + + +# PROJECT_NODE_LOCALIZED +# This is a flag environment variable when a localized virtual environment for +# NodeJS is active. This is useful for detecting which nodeJS engine you're +# currently using for the project in a given terminal. +# +# When active, The variable's value is the pathing to the engine itself. +# +# This variable is reserved by the activator script created autonomously by +# AutomataCI. +#PROJECT_NODE_LOCALIZED - Reserved + + +# PROJECT_NODE_NPM_REGISTRY +# The registry URL for publishing the NPM packages. +# +# The following are identified: +# +# GitHub Packages: 'https://npm.pkg.github.com' +# NPMJS : 'https://registry.npmjs.com' +# +# Default is: 'https://npm.pkg.github.com' +PROJECT_NODE_NPM_REGISTRY = 'https://npm.pkg.github.com' + + + + ###################### # PYTHON TECHNOLOGY # ###################### @@ -474,12 +545,12 @@ PROJECT_PATH_NIM_ENGINE = "nim-engine" # This is a control variable used for enabling Python technology and also # defining its source codes directory relative to PROJECT_PATH_ROOT. # Depending on the offered service (e.g. GitHub Actions), setting this -# variable with value shall notify the CI provider to setup Python development -# environment automatically. +# variable with value shall notify the CI provider to setup a localized virtual +# environment for development automatically. # # To enable it: simply supply the path (e.g. default is 'srcPYTHON'). # To disable it: simply supply an empty path (e.g. default is ''). -PROJECT_PYTHON = 'srcPYTHON' +PROJECT_PYTHON = '' # PROJECT_PATH_PYTHON_ENGINE @@ -725,14 +796,14 @@ PROJECT_STATIC_REPO_DIRECTORY = "static" # security access or the ecosystem is not using Release Job at all (e.g. GitHub # Actions). # -# PROJECT_SIMULATE_RELEASE_REPO = "" # Reserved - provided by external. +# PROJECT_SIMULATE_RELEASE_REPO = "" # Reserved - provided externally. # PROJECT_ROBOT_RUN # A flag to indicate the run is operating inside a CI service by its # autonomous robot. # -# PROJECT_ROBOT_RUN = "" # Reserved - provided by external. +# PROJECT_ROBOT_RUN = "" # Reserved - provided externally. # PROJECT_STATIC_URL diff --git a/README.md b/README.md index 0a1e6fed..42ea5ab1 100644 --- a/README.md +++ b/README.md @@ -1,8 +1,8 @@ # AutomataCI [![AutomataCI](src/icons/banner_1200x200.svg)](#automataci) -A multi-purpose Git template repository with built-in natively operable -semi-autonomous CI infrastructure. +An open-source, redistributable, template-guided, and semi-autonomous CI +infrastructure readily available your next project. ***Run the CI with full-force anywhere anytime without solely depending on any 3rd-party provider***. @@ -93,6 +93,7 @@ compile cross-platform images whenever possible. 1. [Standard Go](https://go.dev/) * Javascript & Typescript Web Frameworks 1. [Angular](https://angular.io/) (*`srcANGULAR`*) + 2. [NodeJS](https://nodejs.org/) (*`srcNODE`*) * [Nim Programming Language](https://nim-lang.org/) (*`srcNIM`*) * [Python Programming Language](https://www.python.org/) (*`srcPYTHON`*) * [Rust Programming Language](https://www.rust-lang.org/) (*`srcRUST`*) diff --git a/automataCI/SECRETS-template.toml b/automataCI/SECRETS-template.toml index c37a4cea..f45f490d 100644 --- a/automataCI/SECRETS-template.toml +++ b/automataCI/SECRETS-template.toml @@ -1,27 +1,30 @@ -###################### -# PYTHON TECHNOLOGY # -###################### -# TWINE_USERNAME -# Use for logging in a PyPi server. This is the account username. Only used -# when PROJECT_PYTHON is enabled. -TWINE_USERNAME = "" +########################## +# APPLE # +########################## +# APPLE_DEVELOPER_ID +# The developer ID used for notarization process. +APPLE_DEVELOPER_ID = "" +# APPLE_KEYCHAIN_PROFILE +# The keychain access used for accessing notarization credentials. +APPLE_KEYCHAIN_PROFILE = "" -# TWINE_PASSWORD -# Use for logging in a PyPi server. This is the account password. Only used -# when PROJECT_PYTHON is enabled. -TWINE_PASSWORD = "" +########################## +# CONTAINER # +########################## +# CONTAINER_USERNAME +# Use to login your container image's registry's service provider (e.g. Docker, +# GitHub Packages) etc. This is the account username. +CONTAINER_USERNAME = "" -###################### -# RUST TECHNOLOGY # -###################### -# CARGO_PASSWORD -# Use for logging in a Cargo registry server. This is the account -# password/secret token. Only used when PROJECT_RUST is enabled. -CARGO_PASSWORD = "" + +# CONTAINER_PASSWORD +# Use to login your container image's registry's service provider (e.g. Docker, +# GitHub Packages) etc. This is the account password or token value. +CONTAINER_PASSWORD = "" @@ -35,16 +38,18 @@ CARGO_PASSWORD = "" PROJECT_GPG_ID ="" -# CONTAINER_USERNAME -# Use to login your container image's registry's service provider (e.g. Docker, -# GitHub Packages) etc. This is the account username. -CONTAINER_USERNAME = "" -# CONTAINER_PASSWORD -# Use to login your container image's registry's service provider (e.g. Docker, -# GitHub Packages) etc. This is the account password or token value. -CONTAINER_PASSWORD = "" +###################### +# GOOGLE AI # +###################### +# GOOGLEAI_API_TOKEN +# This is the authentication API token provided by Google AI using Google AI +# Studio. A token can be procured from: +# (1) https://aistudio.google.com/ (look for 'Get API Key' button) +# +# Without this token, GOOGLEAI library will not function at all. +GOOGLEAI_API_TOKEN = '' @@ -103,27 +108,43 @@ MICROSOFT_CERT_PASSWORD = "" -########################## -# APPLE # -########################## -# APPLE_DEVELOPER_ID -# The developer ID used for notarization process. -APPLE_DEVELOPER_ID = "" +###################### +# NPM TECHNOLOGY # +###################### +# NPM_USERNAME +# The username for login. +NPM_USERNAME = "" -# APPLE_KEYCHAIN_PROFILE -# The keychain access used for accessing notarization credentials. -APPLE_KEYCHAIN_PROFILE = "" + +# NPM_TOKEN +# The Authentication token (e.g. _authToken) for logging into the corresponding +# NPM registry defined in the CONFIG.toml. +NPM_TOKEN = "" ###################### -# GOOGLE AI # +# PYTHON TECHNOLOGY # ###################### -# GOOGLEAI_API_TOKEN -# This is the authentication API token provided by Google AI using Google AI -# Studio. A token can be procured from: -# (1) https://aistudio.google.com/ (look for 'Get API Key' button) -# -# Without this token, GOOGLEAI library will not function at all. -GOOGLEAI_API_TOKEN = '' +# TWINE_USERNAME +# Use for logging in a PyPi server. This is the account username. Only used +# when PROJECT_PYTHON is enabled. +TWINE_USERNAME = "" + + +# TWINE_PASSWORD +# Use for logging in a PyPi server. This is the account password. Only used +# when PROJECT_PYTHON is enabled. +TWINE_PASSWORD = "" + + + + +###################### +# RUST TECHNOLOGY # +###################### +# CARGO_PASSWORD +# Use for logging in a Cargo registry server. This is the account +# password/secret token. Only used when PROJECT_RUST is enabled. +CARGO_PASSWORD = "" diff --git a/automataCI/_package-npm_unix-any.sh b/automataCI/_package-npm_unix-any.sh new file mode 100644 index 00000000..ef5c70e0 --- /dev/null +++ b/automataCI/_package-npm_unix-any.sh @@ -0,0 +1,80 @@ +#!/bin/sh +# Copyright 2024 (Holloway) Chew, Kean Ho +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy of +# the License at: +# http://www.apache.org/licenses/LICENSE-2.0 +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations under +# the License. +. "${LIBS_AUTOMATACI}/services/io/os.sh" +. "${LIBS_AUTOMATACI}/services/io/fs.sh" +. "${LIBS_AUTOMATACI}/services/i18n/translations.sh" + + + + +# initialize +if [ "$PROJECT_PATH_ROOT" = "" ]; then + >&2 printf "[ ERROR ] - Please run me from automataCI/ci.sh.ps1 instead!\n" + return 1 +fi + + + + +PACKAGE_Run_NPM() { + #__line="$1" + + + # parse input + __line="$1" + + _dest="${__line%%|*}" + __line="${__line#*|}" + + _target="${__line%%|*}" + __line="${__line#*|}" + + _target_filename="${__line%%|*}" + __line="${__line#*|}" + + _target_os="${__line%%|*}" + __line="${__line#*|}" + + _target_arch="${__line%%|*}" + __line="${__line#*|}" + + + # copy all complimentary files to the workspace + cmd="PACKAGE_Assemble_NPM_Content" + I18N_Check_Function "$cmd" + OS_Is_Command_Available "$cmd" + if [ $? -ne 0 ]; then + I18N_Check_Failed + return 1 + fi + + I18N_Assemble_Package + "$cmd" "$_target" "$_dest" "$_target_filename" "$_target_os" "$_target_arch" + case $? in + 10) + I18N_Assemble_Skipped + return 0 + ;; + 0) + # accepted + ;; + *) + I18N_Assemble_Failed + return 1 + ;; + esac + + + # report status + return 0 +} diff --git a/automataCI/_package-npm_windows-any.ps1 b/automataCI/_package-npm_windows-any.ps1 new file mode 100644 index 00000000..8a84999c --- /dev/null +++ b/automataCI/_package-npm_windows-any.ps1 @@ -0,0 +1,73 @@ +# Copyright 2024 (Holloway) Chew, Kean Ho +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy +# of the License at: +# http://www.apache.org/licenses/LICENSE-2.0 +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. +. "${env:LIBS_AUTOMATACI}\services\io\os.ps1" +. "${env:LIBS_AUTOMATACI}\services\io\fs.ps1" +. "${env:LIBS_AUTOMATACI}\services\i18n\translations.ps1" + + + + +# initialize +if (-not (Test-Path -Path $env:PROJECT_PATH_ROOT)) { + Write-Error "[ ERROR ] - Please run from automataCI\ci.sh.ps1 instead!`n" + return +} + + + + +function PACKAGE-Run-NPM { + param ( + [string]$__line + ) + + + # parse input + $__list = $__line -split "\|" + $_dest = $__list[0] + $_target = $__list[1] + $_target_filename = $__list[2] + $_target_os = $__list[3] + $_target_arch = $__list[4] + + + # copy all complimentary files to the workspace + $cmd = "PACKAGE-Assemble-NPM-Content" + $null = I18N-Check-Function "$cmd" + $___process = OS-Is-Command-Available "$cmd" + if ($___process -ne 0) { + $null = I18N-Check-Failed + return 1 + } + + $null = I18N-Assemble-Package + $___process = PACKAGE-Assemble-NPM-Content ` + "${_target}" ` + "${_dest}" ` + "${_target_filename}" ` + "${_target_os}" ` + "${_target_arch}" + switch ($___process) { + 10 { + $null = I18N-Assemble-Skipped + return 0 + } 0 { + # accepted + } Default { + $null = I18N-Assemble-Failed + return 1 + }} + + + # report status + return 0 +} diff --git a/automataCI/_release-npm_unix-any.sh b/automataCI/_release-npm_unix-any.sh new file mode 100644 index 00000000..771263b6 --- /dev/null +++ b/automataCI/_release-npm_unix-any.sh @@ -0,0 +1,67 @@ +#!/bin/sh +# Copyright 2024 (Holloway) Chew, Kean Ho +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy of +# the License at: +# http://www.apache.org/licenses/LICENSE-2.0 +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations under +# the License. +. "${LIBS_AUTOMATACI}/services/io/fs.sh" +. "${LIBS_AUTOMATACI}/services/io/os.sh" +. "${LIBS_AUTOMATACI}/services/i18n/translations.sh" +. "${LIBS_AUTOMATACI}/services/compilers/node.sh" + + + + +# initialize +if [ "$PROJECT_PATH_ROOT" = "" ]; then + >&2 printf "[ ERROR ] - Please run me from automataCI/ci.sh.ps1 instead!\n" + return 1 +fi + + + + +RELEASE_Run_NPM() { + #_target="$1" + + + # validate input + NODE_NPM_Is_Valid "$1" + if [ $? -ne 0 ]; then + return 0 + fi + + I18N_Activate_Environment + NODE_Activate_Local_Environment + if [ $? -ne 0 ]; then + I18N_Activate_Failed + return 1 + fi + + + # execute + I18N_Check_Login "NPM" + NODE_NPM_Check_Login + if [ $? -eq 0 ]; then + I18N_Publish "$1" + if [ $(OS_Is_Run_Simulated) -eq 0 ]; then + I18N_Simulate_Publish "$1" + else + NODE_NPM_Publish "$1" + if [ $? -ne 0 ]; then + I18N_Publish_Failed + return 1 + fi + fi + fi + + + # report status + return 0 +} diff --git a/automataCI/_release-npm_windows-any.ps1 b/automataCI/_release-npm_windows-any.ps1 new file mode 100644 index 00000000..be16bf19 --- /dev/null +++ b/automataCI/_release-npm_windows-any.ps1 @@ -0,0 +1,68 @@ +# Copyright 2024 (Holloway) Chew, Kean Ho +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy +# of the License at: +# http://www.apache.org/licenses/LICENSE-2.0 +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. +. "${env:LIBS_AUTOMATACI}\services\io\fs.ps1" +. "${env:LIBS_AUTOMATACI}\services\io\os.ps1" +. "${env:LIBS_AUTOMATACI}\services\i18n\translations.ps1" +. "${env:LIBS_AUTOMATACI}\services\compilers\node.ps1" + + + + +# initialize +if (-not (Test-Path -Path $env:PROJECT_PATH_ROOT)) { + Write-Error "[ ERROR ] - Please run from automataCI\ci.sh.ps1 instead!`n" + return +} + + + + +function RELEASE-Run-NPM { + param( + [string]$_target + ) + + + # validate input + $___process = NODE-NPM-Is-Valid "${_target}" + if ($___process -ne 0) { + return 0 + } + + $null = I18N-Activate-Environment + $___process = NODE-Activate-Local-Environment + if ($___process -ne 0) { + $null = I18N-Activate-Failed + return 1 + } + + + # execute + $null = I18N-Check-Login "NPM" + $___process = NODE-NPM-Check-Login + if ($___process -eq 0) { + $null = I18N-Publish "${_target}" + if ($(OS-Is-Run-Simulated) -ne 0) { + $null = I18N-Simulate-Publish "${_target}" + } else { + $___process = NODE-NPM-Publish "${_target}" + if ($___process -ne 0) { + $null = I18N-Publish-Failed + return 1 + } + } + } + + + # report status + return 0 +} diff --git a/automataCI/common_unix-any.sh b/automataCI/common_unix-any.sh index 0a975514..0aeae351 100644 --- a/automataCI/common_unix-any.sh +++ b/automataCI/common_unix-any.sh @@ -104,6 +104,12 @@ if [ $? -ne 0 ]; then fi +Run_Subroutine_Exec "$PROJECT_NODE" "NODE" +if [ $? -ne 0 ]; then + return 1 +fi + + Run_Subroutine_Exec "$PROJECT_PYTHON" "PYTHON" if [ $? -ne 0 ]; then return 1 diff --git a/automataCI/common_windows-any.ps1 b/automataCI/common_windows-any.ps1 index 8c8d9c1d..29bd9a2d 100644 --- a/automataCI/common_windows-any.ps1 +++ b/automataCI/common_windows-any.ps1 @@ -98,6 +98,11 @@ if ($___process -ne 0) { return 1 } +$___process = RUN-Subroutine-Exec "${env:PROJECT_NODE}" "NODE" +if ($___process -ne 0) { + return 1 +} + $___process = RUN-Subroutine-Exec "${env:PROJECT_PYTHON}" "PYTHON" if ($___process -ne 0) { return 1 diff --git a/automataCI/notarize_unix-any.sh b/automataCI/notarize_unix-any.sh index 8c6ec6ae..12e0f008 100644 --- a/automataCI/notarize_unix-any.sh +++ b/automataCI/notarize_unix-any.sh @@ -60,7 +60,8 @@ for i in "${PROJECT_PATH_ROOT}/${PROJECT_PATH_BUILD}"/*; do # parse build candidate I18N_Detected "$i" - TARGET_FILENAME="${i##*${PROJECT_PATH_ROOT}/${PROJECT_PATH_BUILD}/}" + TARGET_FILENAME="$(FS_Get_File "$i")" + TARGET_FILENAME="$(FS_Extension_Remove "$TARGET_FILENAME")" TARGET_FILENAME="${TARGET_FILENAME%.*}" TARGET_OS="${TARGET_FILENAME##*_}" TARGET_FILENAME="${TARGET_FILENAME%%_*}" diff --git a/automataCI/notarize_windows-any.ps1 b/automataCI/notarize_windows-any.ps1 index f78324db..6b15dbab 100644 --- a/automataCI/notarize_windows-any.ps1 +++ b/automataCI/notarize_windows-any.ps1 @@ -59,10 +59,8 @@ foreach ($i in (Get-ChildItem -Path "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH # parse build candidate $null = I18N-Detected "$i" - $TARGET_FILENAME = Split-Path -Leaf $i - $TARGET_FILENAME = $TARGET_FILENAME -replace ` - (Join-Path $env:PROJECT_PATH_ROOT $env:PROJECT_PATH_BUILD), "" - $TARGET_FILENAME = $TARGET_FILENAME -replace "\..*$" + $TARGET_FILENAME = FS-Get-File "$i" + $TARGET_FILENAME = FS-Extension-Remove "$TARGET_FILENAME" $TARGET_OS = $TARGET_FILENAME -replace ".*_" $TARGET_FILENAME = $TARGET_FILENAME -replace "_.*" $TARGET_ARCH = $TARGET_OS -replace ".*-" diff --git a/automataCI/package_unix-any.sh b/automataCI/package_unix-any.sh index bd90175a..2e018896 100644 --- a/automataCI/package_unix-any.sh +++ b/automataCI/package_unix-any.sh @@ -36,6 +36,7 @@ fi . "${LIBS_AUTOMATACI}/_package-homebrew_unix-any.sh" . "${LIBS_AUTOMATACI}/_package-ipk_unix-any.sh" . "${LIBS_AUTOMATACI}/_package-msi_unix-any.sh" +. "${LIBS_AUTOMATACI}/_package-npm_unix-any.sh" . "${LIBS_AUTOMATACI}/_package-pdf_unix-any.sh" . "${LIBS_AUTOMATACI}/_package-pypi_unix-any.sh" . "${LIBS_AUTOMATACI}/_package-rpm_unix-any.sh" @@ -155,7 +156,7 @@ for i in "${PROJECT_PATH_ROOT}/${PROJECT_PATH_BUILD}"/*; do TARGET_FILENAME="${TARGET_FILENAME%.*}" TARGET_OS="${TARGET_FILENAME##*_}" TARGET_FILENAME="${TARGET_FILENAME%%_*}" - TARGET_ARCH="${TARGET_ARCH##*-}" + TARGET_ARCH="${TARGET_OS##*-}" TARGET_ARCH="${TARGET_ARCH%%.*}" TARGET_OS="${TARGET_OS%%-*}" TARGET_OS="${TARGET_OS%%.*}" @@ -252,6 +253,14 @@ ${__common}|${__log}|PACKAGE_Run_MSI return 1 fi + __log="${__log_directory}/npm_${TARGET_FILENAME}_${TARGET_OS}-${TARGET_ARCH}.log" + FS_Append_File "$__serial_control" "\ +${__common}|${__log}|PACKAGE_Run_NPM +" + if [ $? -ne 0 ]; then + return 1 + fi + __log="${__log_directory}/pdf_${TARGET_FILENAME}_${TARGET_OS}-${TARGET_ARCH}.log" FS_Append_File "$__parallel_control" "\ ${__common}|${__log}|PACKAGE_Run_PDF diff --git a/automataCI/package_windows-any.ps1 b/automataCI/package_windows-any.ps1 index cc2f5235..e41163c1 100644 --- a/automataCI/package_windows-any.ps1 +++ b/automataCI/package_windows-any.ps1 @@ -112,6 +112,7 @@ function SUBROUTINE-Package { $null = . "${env:LIBS_AUTOMATACI}\_package-homebrew_windows-any.ps1" $null = . "${env:LIBS_AUTOMATACI}\_package-ipk_windows-any.ps1" $null = . "${env:LIBS_AUTOMATACI}\_package-msi_windows-any.ps1" + $null = . "${env:LIBS_AUTOMATACI}\_package-npm_windows-any.ps1" $null = . "${env:LIBS_AUTOMATACI}\_package-pdf_windows-any.ps1" $null = . "${env:LIBS_AUTOMATACI}\_package-pypi_windows-any.ps1" $null = . "${env:LIBS_AUTOMATACI}\_package-rpm_windows-any.ps1" @@ -170,7 +171,7 @@ foreach ($file in (Get-ChildItem -Path "${env:PROJECT_PATH_ROOT}\${env:PROJECT_P $TARGET_FILENAME = $TARGET_FILENAME -replace "\..*$" $TARGET_OS = $TARGET_FILENAME -replace ".*_" $TARGET_FILENAME = $TARGET_FILENAME -replace "_.*" - $TARGET_ARCH = $TARGET_ARCH -replace ".*-" + $TARGET_ARCH = $TARGET_OS -replace ".*-" $TARGET_ARCH = $TARGET_ARCH -replace "\..*$" $TARGET_OS = $TARGET_OS -replace "-.*" $TARGET_OS = $TARGET_OS -replace "\..*$" @@ -267,6 +268,14 @@ ${__common}|${__log}|PACKAGE-Run-MSI return 1 } + $__log = "${__log_directory}\npm_${TARGET_FILENAME}_${TARGET_OS}-${TARGET_ARCH}.log" + $___process = FS-Append-File "${__serial_control}" @" +${__common}|${__log}|PACKAGE-Run-NPM +"@ + if ($___process -ne 0) { + return 1 + } + $__log = "${__log_directory}\PDF_${TARGET_FILENAME}_${TARGET_OS}-${TARGET_ARCH}.log" $___process = FS-Append-File "${__parallel_control}" @" ${__common}|${__log}|PACKAGE-Run-PDF diff --git a/automataCI/release_unix-any.sh b/automataCI/release_unix-any.sh index 23becfed..ce493196 100644 --- a/automataCI/release_unix-any.sh +++ b/automataCI/release_unix-any.sh @@ -32,6 +32,7 @@ fi . "${LIBS_AUTOMATACI}/_release-deb_unix-any.sh" . "${LIBS_AUTOMATACI}/_release-docker_unix-any.sh" . "${LIBS_AUTOMATACI}/_release-homebrew_unix-any.sh" +. "${LIBS_AUTOMATACI}/_release-npm_unix-any.sh" . "${LIBS_AUTOMATACI}/_release-pypi_unix-any.sh" . "${LIBS_AUTOMATACI}/_release-rpm_unix-any.sh" . "${LIBS_AUTOMATACI}/_release-staticrepo_unix-any.sh" @@ -97,42 +98,47 @@ for TARGET in "${PROJECT_PATH_ROOT}/${PROJECT_PATH_PKG}"/*; do fi I18N_Processing "$TARGET" - RELEASE_Run_DEB "$TARGET" "$STATIC_REPO" + RELEASE_Run_CARGO "$TARGET" if [ $? -ne 0 ]; then return 1 fi - RELEASE_Run_RPM "$TARGET" "$STATIC_REPO" + RELEASE_Run_CHOCOLATEY "$TARGET" "$CHOCOLATEY_REPO" if [ $? -ne 0 ]; then return 1 fi - RELEASE_Run_DOCKER "$TARGET" + RELEASE_Run_CITATION_CFF "$TARGET" if [ $? -ne 0 ]; then return 1 fi - RELEASE_Run_PYPI "$TARGET" + RELEASE_Run_DEB "$TARGET" "$STATIC_REPO" if [ $? -ne 0 ]; then return 1 fi - RELEASE_Run_CARGO "$TARGET" + RELEASE_Run_DOCKER "$TARGET" if [ $? -ne 0 ]; then return 1 fi - RELEASE_Run_CITATION_CFF "$TARGET" + RELEASE_Run_HOMEBREW "$TARGET" "$HOMEBREW_REPO" if [ $? -ne 0 ]; then return 1 fi - RELEASE_Run_HOMEBREW "$TARGET" "$HOMEBREW_REPO" + RELEASE_Run_NPM "$TARGET" if [ $? -ne 0 ]; then return 1 fi - RELEASE_Run_CHOCOLATEY "$TARGET" "$CHOCOLATEY_REPO" + RELEASE_Run_PYPI "$TARGET" + if [ $? -ne 0 ]; then + return 1 + fi + + RELEASE_Run_RPM "$TARGET" "$STATIC_REPO" if [ $? -ne 0 ]; then return 1 fi diff --git a/automataCI/release_windows-any.ps1 b/automataCI/release_windows-any.ps1 index 862d26bc..19bfa646 100644 --- a/automataCI/release_windows-any.ps1 +++ b/automataCI/release_windows-any.ps1 @@ -31,6 +31,7 @@ if (-not (Test-Path -Path $env:PROJECT_PATH_ROOT)) { . "${env:LIBS_AUTOMATACI}\_release-deb_windows-any.ps1" . "${env:LIBS_AUTOMATACI}\_release-docker_windows-any.ps1" . "${env:LIBS_AUTOMATACI}\_release-homebrew_windows-any.ps1" +. "${env:LIBS_AUTOMATACI}\_release-npm_windows-any.ps1" . "${env:LIBS_AUTOMATACI}\_release-pypi_windows-any.ps1" . "${env:LIBS_AUTOMATACI}\_release-rpm_windows-any.ps1" . "${env:LIBS_AUTOMATACI}\_release-staticrepo_windows-any.ps1" @@ -100,42 +101,47 @@ if (Test-Path -PathType Container -Path "${PACKAGE_DIRECTORY}") { $null = I18N-Processing "${TARGET}" - $___process = RELEASE-Run-DEB "$TARGET" "$STATIC_REPO" + $___process = RELEASE-Run-CARGO "$TARGET" if ($___process -ne 0) { return 1 } - $___process = RELEASE-Run-RPM "$TARGET" "$STATIC_REPO" ` + $___process = RELEASE-Run-CITATION-CFF "$TARGET" if ($___process -ne 0) { return 1 } - $___process = RELEASE-Run-DOCKER "$TARGET" + $___process = RELEASE-Run-CHOCOLATEY "$TARGET" "$CHOCOLATEY_REPO" if ($___process -ne 0) { return 1 } - $___process = RELEASE-Run-PYPI "$TARGET" + $___process = RELEASE-Run-DEB "$TARGET" "$STATIC_REPO" if ($___process -ne 0) { return 1 } - $___process = RELEASE-Run-CARGO "$TARGET" + $___process = RELEASE-Run-DOCKER "$TARGET" if ($___process -ne 0) { return 1 } - $___process = RELEASE-Run-CITATION-CFF "$TARGET" + $___process = RELEASE-Run-HOMEBREW "$TARGET" "$HOMEBREW_REPO" if ($___process -ne 0) { return 1 } - $___process = RELEASE-Run-HOMEBREW "$TARGET" "$HOMEBREW_REPO" + $___process = RELEASE-Run-NPM "$TARGET" if ($___process -ne 0) { return 1 } - $___process = RELEASE-Run-CHOCOLATEY "$TARGET" "$CHOCOLATEY_REPO" + $___process = RELEASE-Run-PYPI "$TARGET" + if ($___process -ne 0) { + return 1 + } + + $___process = RELEASE-Run-RPM "$TARGET" "$STATIC_REPO" ` if ($___process -ne 0) { return 1 } diff --git a/automataCI/services/archive/tar.ps1 b/automataCI/services/archive/tar.ps1 index bb0e0a8c..a73ab550 100644 --- a/automataCI/services/archive/tar.ps1 +++ b/automataCI/services/archive/tar.ps1 @@ -1,4 +1,4 @@ -# Copyright 2023 (Holloway) Chew, Kean Ho +# Copyright 2023 (Holloway) Chew, Kean Ho # # Licensed under the Apache License, Version 2.0 (the "License"); you may not # use this file except in compliance with the License. You may obtain a copy @@ -116,6 +116,11 @@ function TAR-Create-GZ { return 1 } + $___process = GZ-Is-Available + if ($___process -ne 0) { + return 1 + } + # create tar archive $___dest = $___destination -replace '\.gz.*$' @@ -184,3 +189,89 @@ function TAR-Create-XZ { # report status return 0 } + + + + +function TAR-Extract-GZ { + param ( + [string]$___destination, + [string]$___source + ) + + + # validate input + if (($(STRINGS-Is-Empty "${___destination}") -eq 0) -or + ($(STRINGS-Is-Empty "${___source}") -eq 0)) { + return 1 + } + + $___process = FS-Is-File "${___destination}" + if ($___process -eq 0) { + return 1 + } + + $___process = FS-Is-File "${___source}" + if ($___process -ne 0) { + return 1 + } + + $___process = GZ-Is-Available + if ($___process -ne 0) { + return 1 + } + + + # unpack tar.gz + $___process = OS-Exec "tar" "-xzf `"${___destination}`" -C `"${___source}`"" + if ($___process -ne 0) { + return 1 + } + + + # report status + return 0 +} + + + + +function TAR-Extract-XZ { + param ( + [string]$___destination, + [string]$___source + ) + + + # validate input + if (($(STRINGS-Is-Empty "${___destination}") -eq 0) -or + ($(STRINGS-Is-Empty "${___source}") -eq 0)) { + return 1 + } + + $___process = FS-Is-File "${___destination}" + if ($___process -eq 0) { + return 1 + } + + $___process = FS-Is-File "${___source}" + if ($___process -ne 0) { + return 1 + } + + $___process = XZ-Is-Available + if ($___process -ne 0) { + return 1 + } + + + # unpack tar.xz + $___process = OS-Exec "tar" "-xf `"${___destination}`" -C `"${___source}`"" + if ($___process -ne 0) { + return 1 + } + + + # report status + return 0 +} diff --git a/automataCI/services/archive/tar.sh b/automataCI/services/archive/tar.sh index 5a8ab132..56a46890 100644 --- a/automataCI/services/archive/tar.sh +++ b/automataCI/services/archive/tar.sh @@ -1,5 +1,5 @@ #!/bin/sh -# Copyright 2023 (Holloway) Chew, Kean Ho +# Copyright 2023 (Holloway) Chew, Kean Ho # # Licensed under the Apache License, Version 2.0 (the "License"); you may not # use this file except in compliance with the License. You may obtain a copy of @@ -105,6 +105,11 @@ TAR_Create_GZ() { return 1 fi + GZ_Is_Available + if [ $? -ne 0 ]; then + return 1 + fi + # create tar archive TAR_Create "${1%.gz*}" "$2" "$3" "$4" @@ -172,3 +177,83 @@ TAR_Create_XZ() { # report status return 0 } + + + + +TAR_Extract_GZ() { + #___destination="$1" + #___source="$2" + + + # validate input + if [ $(STRINGS_Is_Empty "$1") -eq 0 ] || [ $(STRINGS_Is_Empty "$2") -eq 0 ]; then + return 1 + fi + + FS_Is_File "$1" + if [ $? -eq 0 ]; then + return 1 + fi + + FS_Is_File "$2" + if [ $? -ne 0 ]; then + return 1 + fi + + GZ_Is_Available + if [ $? -ne 0 ]; then + return 1 + fi + + + # unpack tar.gz + tar -xzf "$2" -C "$1" + if [ $? -ne 0 ]; then + return 1 + fi + + + # report status + return 0 +} + + + + +TAR_Extract_XZ() { + #___destination="$1" + #___source="$2" + + + # validate input + if [ $(STRINGS_Is_Empty "$1") -eq 0 ] || [ $(STRINGS_Is_Empty "$2") -eq 0 ]; then + return 1 + fi + + FS_Is_File "$1" + if [ $? -eq 0 ]; then + return 1 + fi + + FS_Is_File "$2" + if [ $? -ne 0 ]; then + return 1 + fi + + XZ_Is_Available + if [ $? -ne 0 ]; then + return 1 + fi + + + # unpack tar.xz + tar -xf "$2" -C "$1" + if [ $? -ne 0 ]; then + return 1 + fi + + + # report status + return 0 +} diff --git a/automataCI/services/archive/zip.ps1 b/automataCI/services/archive/zip.ps1 index 2dde8d6b..cbe7d3c6 100644 --- a/automataCI/services/archive/zip.ps1 +++ b/automataCI/services/archive/zip.ps1 @@ -1,4 +1,4 @@ -# Copyright 2023 (Holloway) Chew, Kean Ho +# Copyright 2023 (Holloway) Chew, Kean Ho # # Licensed under the Apache License, Version 2.0 (the "License"); you may not # use this file except in compliance with the License. You may obtain a copy @@ -10,6 +10,7 @@ # License for the specific language governing permissions and limitations # under the License. . "${env:LIBS_AUTOMATACI}\services\io\fs.ps1" +. "${env:LIBS_AUTOMATACI}\services\io\os.ps1" @@ -50,26 +51,25 @@ function ZIP-Extract { # validate input - $___process = FS-Is-File "${___source}" + $___process = FS-Is-Directory "${___destination}" if ($___process -ne 0) { return 1 } - $___process = FS-Is-File "${___destination}" - if ($___process -eq 0) { + $___process = FS-Is-File "${___source}" + if ($___process -ne 0) { return 1 } # execute + $null = FS-Make-Directory "${___destination}" try { - $null = FS-Make-Directory "${___destination}" $null = Expand-Archive -Path $___source -DestinationPath $___destination } catch { return 1 } - # report status return 0 } diff --git a/automataCI/services/archive/zip.sh b/automataCI/services/archive/zip.sh index 905a3127..7aa63540 100644 --- a/automataCI/services/archive/zip.sh +++ b/automataCI/services/archive/zip.sh @@ -1,5 +1,5 @@ #!/bin/sh -# Copyright 2023 (Holloway) Chew, Kean Ho +# Copyright 2023 (Holloway) Chew, Kean Ho # # Licensed under the Apache License, Version 2.0 (the "License"); you may not # use this file except in compliance with the License. You may obtain a copy of @@ -10,8 +10,8 @@ # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the # License for the specific language governing permissions and limitations under # the License. -. "${LIBS_AUTOMATACI}/services/io/os.sh" . "${LIBS_AUTOMATACI}/services/io/fs.sh" +. "${LIBS_AUTOMATACI}/services/io/os.sh" @@ -53,13 +53,13 @@ ZIP_Extract() { return 1 fi - FS_Is_File "$___source" + FS_Is_Directory "$___destination" if [ $? -ne 0 ]; then return 1 fi - FS_Is_File "$___destination" - if [ $? -eq 0 ]; then + FS_Is_File "$___source" + if [ $? -ne 0 ]; then return 1 fi @@ -86,6 +86,11 @@ ZIP_Is_Available() { return 0 fi + OS_Is_Command_Available "unzip" + if [ $? -eq 0 ]; then + return 0 + fi + # report status return 1 diff --git a/automataCI/services/compilers/citation.ps1 b/automataCI/services/compilers/citation.ps1 index f161f005..6c98bcfc 100644 --- a/automataCI/services/compilers/citation.ps1 +++ b/automataCI/services/compilers/citation.ps1 @@ -1,4 +1,4 @@ -# Copyright 2023 (Holloway) Chew, Kean Ho +# Copyright 2023 (Holloway) Chew, Kean Ho # # Licensed under the Apache License, Version 2.0 (the "License"); you may not # use this file except in compliance with the License. You may obtain a copy @@ -64,6 +64,7 @@ function CITATION-Build { cff-version: `"${___cff_version}`" type: `"${___type}`" + "@ if ($___process -ne 0) { return 1 @@ -72,6 +73,7 @@ type: `"${___type}`" if ($(STRINGS-Is-Empty "${___date}") -ne 0) { $___process = FS-Append-File "${___filepath}" @" date-released: `"${___date}`" + "@ if ($___process -ne 0) { return 1 @@ -81,6 +83,7 @@ date-released: `"${___date}`" if ($(STRINGS-Is-Empty "${___title}") -ne 0) { $___process = FS-Append-File "${___filepath}" @" title: `"${___title}`" + "@ if ($___process -ne 0) { return 1 @@ -90,6 +93,7 @@ title: `"${___title}`" if ($(STRINGS-Is-Empty "${___version}") -ne 0) { $___process = FS-Append-File "${___filepath}" @" version: `"${___version}`" + "@ if ($___process -ne 0) { return 1 @@ -99,6 +103,7 @@ version: `"${___version}`" if ($(STRINGS-Is-Empty "${___license}") -ne 0) { $___process = FS-Append-File "${___filepath}" @" license: `"${___license}`" + "@ if ($___process -ne 0) { return 1 @@ -108,6 +113,7 @@ license: `"${___license}`" if ($(STRINGS-Is-Empty "${___repo}") -ne 0) { $___process = FS-Append-File "${___filepath}" @" repository: `"${___repo}`" + "@ if ($___process -ne 0) { return 1 @@ -117,6 +123,7 @@ repository: `"${___repo}`" if ($(STRINGS-Is-Empty "${___repo_code}") -ne 0) { $___process = FS-Append-File "${___filepath}" @" repository-code: `"${___repo_code}`" + "@ if ($___process -ne 0) { return 1 @@ -126,6 +133,7 @@ repository-code: `"${___repo_code}`" if ($(STRINGS-Is-Empty "${___repo_artifact}") -ne 0) { $___process = FS-Append-File "${___filepath}" @" repository-artifact: `"${___repo_artifact}`" + "@ if ($___process -ne 0) { return 1 @@ -135,6 +143,7 @@ repository-artifact: `"${___repo_artifact}`" if ($(STRINGS-Is-Empty "${___contact_website}") -ne 0) { $___process = FS-Append-File "${___filepath}" @" url: `"${___contact_website}`" + "@ if ($___process -ne 0) { return 1 @@ -147,6 +156,7 @@ url: `"${___contact_website}`" $___process = FS-Append-File "${___filepath}" @" contact: - affiliation: `"${___contact_name}`" + "@ if ($___process -ne 0) { return 1 @@ -155,6 +165,7 @@ contact: if ($(STRINGS-Is-Empty "${___contact_email}") -ne 0) { $___process = FS-Append-File "${___filepath}" @" email: `"${___contact_email}`" + "@ if ($___process -ne 0) { return 1 @@ -164,6 +175,7 @@ contact: if ($(STRINGS-Is-Empty "${___contact_website}") -ne 0) { $___process = FS-Append-File "${___filepath}" @" website: `"${___contact_website}`" + "@ if ($___process -ne 0) { return 1 @@ -176,6 +188,7 @@ contact: if ($___process -eq 0) { $___process = FS-Append-File "${___filepath}" @" abstract: |- + "@ if ($___process -ne 0) { return 1 @@ -192,7 +205,7 @@ abstract: |- $___line = " ${___line}" } - $___process = FS-Append-File "${___filepath}" "${___line}" + $___process = FS-Append-File "${___filepath}" "${___line}`n" if ($___process -ne 0) { return 1 } @@ -210,7 +223,7 @@ abstract: |- continue } - $___process = FS-Append-File "${___filepath}" "${___line}" + $___process = FS-Append-File "${___filepath}" "${___line}`n" if ($___process -ne 0) { return 1 } diff --git a/automataCI/services/compilers/flatpak.ps1 b/automataCI/services/compilers/flatpak.ps1 index 9475d06f..b32158aa 100644 --- a/automataCI/services/compilers/flatpak.ps1 +++ b/automataCI/services/compilers/flatpak.ps1 @@ -132,7 +132,7 @@ function FLATPAK-Is-Available { # check compatible target os switch ($___os) { - { $_ -in linux, any } { + { $_ -in "linux", "any" } { # accepted } Default { return 2 diff --git a/automataCI/services/compilers/node.ps1 b/automataCI/services/compilers/node.ps1 index 8de6601d..b90be7d1 100644 --- a/automataCI/services/compilers/node.ps1 +++ b/automataCI/services/compilers/node.ps1 @@ -9,33 +9,433 @@ # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the # License for the specific language governing permissions and limitations # under the License. +. "${env:LIBS_AUTOMATACI}\services\io\fs.ps1" . "${env:LIBS_AUTOMATACI}\services\io\os.ps1" +. "${env:LIBS_AUTOMATACI}\services\io\strings.ps1" +. "${env:LIBS_AUTOMATACI}\services\io\net\http.ps1" +. "${env:LIBS_AUTOMATACI}\services\archive\tar.ps1" +. "${env:LIBS_AUTOMATACI}\services\archive\zip.ps1" -function NODE-Setup { +function NODE-Activate-Local-Environment { # validate input - $null = OS-Sync - - $___process = OS-Is-Command-Available "npm" + $___process = NODE-Is-Localized if ($___process -eq 0) { + $___process = NODE-Is-Available + if ($___process -ne 0) { + return 1 + } + return 0 } - $___process = OS-Is-Command-Available "choco" + + # execute + $___location = "$(NODE-Get-Activator-Path)" + $___process = FS-Is-File "${___location}" if ($___process -ne 0) { return 1 } + . "${___location}" + $___process = NODE-Is-Localized + if ($___process -ne 0) { + return 1 + } + + $___process = NODE-Is-Available + if ($___process -ne 0) { + return 1 + } + + + # report status + return 0 +} + + + + +function NODE-Get-Activator-Path { + return "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_TOOLS}\${env:PROJECT_PATH_NODE_ENGINE}\Activate.ps1" +} + + + +function NODE-Is-Available { # execute - $___process = OS-Exec "choco" "install node -y" + if ($(STRINGS-Is-Empty "${env:PROJECT_NODE_VERSION}") -ne 0) { + ## check existing localized engine + $___target = "$(NODE-Get-Activator-Path)" + $___process = FS-Is-File "${___target}" + if ($___process -ne 0) { + return 1 + } + $___target = "$(FS-Get-Directory "${___target}")" + + ## check localized node command availability + $___process = FS-Is-File "${___target}\node.exe" + if ($___process -ne 0) { + return 1 + } + + ## check localized npm command availability + $___process = FS-Is-File "${___target}\npm" + if ($___process -ne 0) { + return 1 + } + + ## check localized npm command availability + $___process = FS-Is-File "${___target}\npx" + if ($___process -ne 0) { + return 1 + } + + return 0 + } + + $___process = OS-Is-Command-Available "npm" + if ($___process -ne 0) { + return 1 + } + + $___process = OS-Is-Command-Available "npx" if ($___process -ne 0) { return 1 } - $null = OS-Sync + $___process = OS-Is-Command-Available "node" + if ($___process -ne 0) { + return 1 + } + + + # report status + return 1 +} + + + + +function NODE-Is-Localized { + # execute + if ($(STRINGS-Is-Empty "${env:PROJECT_NODE_LOCALIZED}") -ne 0) { + return 0 + } + + + # report status + return 1 +} + + + + +function NODE-NPM-Check-Login { + # execute + if ($(STRINGS-Is-Empty "${env:PROJECT_NODE_NPM_REGISTRY}") -eq 0) { + return 1 + } + + if ($(STRINGS-Is-Empty "${env:NPM_USERNAME}") -eq 0) { + return 1 + } + + if ($(STRINGS-Is-Empty "${env:NPM_TOKEN}") -eq 0) { + return 1 + } + + if ($(STRINGS-Is-Empty "${env:PROJECT_SCOPE}") -eq 0) { + return 1 + } + + + # report status + return 0 +} + + + + +function NODE-NPM-Install-Dependencies-All { + # validate input + $___process = NODE-Is-Available + if ($___process -ne 0) { + return 1 + } + + + # execute + $___process = OS-Exec "npm" "install" + if ($___process -ne 0) { + return 1 + } + + + # report status + return 0 +} + + + + +function NODE-NPM-Is-Valid { + param( + [string]$___target + ) + + + # validate input + if ($(STRINGS-Is-Empty "${___target}") -eq 0) { + return 1 + } + + $___process = FS-Is-File "$1" + if ($___process -ne 0) { + return 1 + } + + + # execute + $___process = FS-Is-Target-A-NPM "$1" + if ($___process -ne 0) { + return 1 + } + + + # report status + return 0 +} + + + + +function NODE-NPM-Publish { + param( + [string]$___target + ) + + + # validate input + if ($(STRINGS-Is-Empty "$1") -eq 0) { + return 1 + } + + $___process = FS-Is-File "${___target}" + if ($___process -ne 0) { + return 1 + } + + $___process = NODE-Is-Available + if ($___process -ne 0) { + return 1 + } + + + # execute + $___workspace = "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_TEMP}\release-npm" + $___package = "${env:PROJECT_SKU}.tgz" + $___npmrc = ".npmrc" + + ## setup workspace + $___process = FS-Remake-Directory "${___workspace}" + $___current_path = Get-Location + $null = Set-Location "${___workspace}" + + $___process = FS-Copy-File "${___target}" "${___package}" + if ($___process -ne 0) { + return 1 + } + + $___process = FS-Write-File "${___npmrc}" @" +registry=${env:PROJECT_NODE_NPM_REGISTRY} +scope=@${env:PROJECT_SCOPE} +email=$env:NPM_USERNAME +//${PROJECT_NODE_NPM_REGISTRY#*://}/:_authToken=${env:NPM_TOKEN} +"@ + if ($___process -ne 0) { + $null = FS-Remove-Silently "${___npmrc}" + return 1 + } + + $___process = FS-Is-File "${___npmrc}" + if ($___process -ne 0) { + return 1 + } + + ## publish + $___process = OS-Exec "npm" "publish `"${___package}`"" + $null = FS-Remove-Silently "${___npmrc}" + $null = Set-Location "${___current_path}" + $null = Remove-Variable ___current_path + if ($___process -ne 0) { + return 1 + } + + + # report status + return 0 +} + + + + +function NODE-NPM-Run { + param( + [string]$___name + ) + + + # validate input + $___process = NODE-Is-Available + if ($___process -ne 0) { + return 1 + } + + if ($(STRINGS-Is-Empty "${___name}") -eq 0) { + return 1 + } + + + # execute + $___process = OS-Exec "npm" "run `"${___name}`"" + if ($___process -ne 0) { + return 1 + } + + + # report status + return 0 +} + + + + +function NODE-Setup { + # validate input + $___process = NODE-Is-Available + if ($___process -eq 0) { + return 0 + } + + + # execute + $___filepath = "" + switch ("${env:PROJECT_ARCH}") { + "amd64" { + $___filepath = "x64" + } "arm" { + $___filepath = "armv7l" + } "arm64" { + $___filepath = "arm64" + } "ppc64le" { + $___filepath = "ppc64le" + } "s390x" { + $___filepath = "s390x" + } default { + return 1 + }} + + switch ("${env:PROJECT_OS}") { + "aix" { + $___filepath = "aix-${___filepath}.tar.xz" + } "darwin" { + $___filepath = "darwin-${___filepath}.tar.xz" + } "windows" { + $___filepath = "win-${___filepath}.zip" + } "linux" { + $___filepath = "linux-${___filepath}.tar.xz" + } default { + return 1 + }} + + ## download engine + $___filepath = "node-${env:PROJECT_NODE_VERSION}-${___filepath}" + $___url = "https://nodejs.org/dist/${env:PROJECT_NODE_VERSION}/${___filepath}" + $___filepath = "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_TOOLS}\${___filepath}" + + $null = FS-Make-Housing-Directory "${___filepath}" + $null = FS-Remove-Silently "${___filepath}" + $___process = HTTP-Download "GET" "${___url}" "${___filepath}" + if ($___process -ne 0) { + return 1 + } + + ## unpack engine + $___process = FS-Is-File "${___filepath}" + if ($___process -ne 0) { + return 1 + } + + $___location = "$(NODE-Get-Activator-Path)" + $null = FS-Remove-Silently "$(FS-Get-Directory "${___location}")" + + $___target = "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_TOOLS}\" + switch ("${env:PROJECT_OS}") { + "windows" { + $___process = ZIP-Extract "${___target}" "${___filepath}" + $null = FS-Remove-Silently "${___filepath}" + $___target = FS-Extension-Replace "${___filepath}" ".zip" "" + } default { + $___process = TAR-Extract-XZ "${___target}" "${___filepath}" + $null = FS-Remove-Silently "${___filepath}" + $___target = FS-Extension-Replace "${___filepath}" ".tar.xz" "" + }} + if ($___process -ne 0) { + return 1 + } + + $___process = FS-Move "${___target}" "$(FS-Get-Directory "${___location}")" + if ($___process -ne 0) { + return 1 + } + + + ## create activator script + $___label = "(${env:PROJECT_PATH_NODE_ENGINE})" + $___target = "$(FS-Get-Directory "${___location}")" + $null = FS-Write-File "${___location}" @" +`$___target = `"${___target}`" + + +function deactivate { + `$env:Path = (`$env:Path.Split(';') | Where-Object { `$_ -ne "`${___target}" }) -join ';' + + `${env:PROJECT_NODE_LOCALIZED} = `$null + Copy-Item -Path Function:_OLD_PROMPT -Destination Function:prompt + Remove-Item -Path Function:_OLD_PROMPT +} + + +# check existing +if (-not [string]::IsNullOrEmpty(`${env:PROJECT_NODE_LOCALIZED})) { + return +} + + +# activate +`$env:Path = `$env:Path + ";" + "`${___target}" + +`${env:PROJECT_NODE_LOCALIZED} = "${___location}" +`$null = Copy-Item -Path function:prompt -Destination function:_OLD_PROMPT +function global:prompt { + Write-Host -NoNewline -ForegroundColor Green "(${___label}) " + _OLD_VIRTUAL_PROMPT +} +"@ + $___process = FS-Is-File "${___location}" + if ($___process -ne 0) { + return 1 + } + + ## test activator script + $___process = NODE-Activate-Local-Environment + if ($___process -ne 0) { + return 1 + } # report status diff --git a/automataCI/services/compilers/node.sh b/automataCI/services/compilers/node.sh index 349ed6fb..dc21a0b8 100644 --- a/automataCI/services/compilers/node.sh +++ b/automataCI/services/compilers/node.sh @@ -10,30 +10,448 @@ # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the # License for the specific language governing permissions and limitations under # the License. +. "${LIBS_AUTOMATACI}/services/io/fs.sh" . "${LIBS_AUTOMATACI}/services/io/os.sh" +. "${LIBS_AUTOMATACI}/services/io/strings.sh" +. "${LIBS_AUTOMATACI}/services/io/net/http.sh" +. "${LIBS_AUTOMATACI}/services/archive/tar.sh" +. "${LIBS_AUTOMATACI}/services/archive/zip.sh" -NODE_Setup() { +NODE_Activate_Local_Environment() { # validate input - OS_Is_Command_Available "npm" + NODE_Is_Localized if [ $? -eq 0 ]; then + NODE_Is_Available + if [ $? -ne 0 ]; then + return 1 + fi + return 0 fi - OS_Is_Command_Available "brew" + + # execute + ___location="$(NODE_Get_Activator_Path)" + FS_Is_File "$___location" + if [ $? -ne 0 ]; then + return 1 + fi + + . "$___location" + NODE_Is_Localized + if [ $? -ne 0 ]; then + return 1 + fi + + NODE_Is_Available if [ $? -ne 0 ]; then return 1 fi + # report status + return 0 +} + + + + +NODE_Get_Activator_Path() { + printf -- "${PROJECT_PATH_ROOT}/${PROJECT_PATH_TOOLS}/${PROJECT_PATH_NODE_ENGINE}/activate.sh" +} + + + + +NODE_Is_Available() { # execute - brew install node + if [ $(STRINGS_Is_Empty "$PROJECT_NODE_VERSION") -ne 0 ]; then + ## check existing localized engine + ___target="$(NODE_Get_Activator_Path)" + FS_Is_File "$___target" + if [ $? -ne 0 ]; then + return 1 + fi + ___target="$(FS_Get_Directory "$___target")" + + ## check localized node command availablity + FS_Is_File "${___target}/bin/node" + if [ $? -ne 0 ]; then + return 1 + fi + + ## check localized npm command availablity + FS_Is_File "${___target}/bin/npm" + if [ $? -ne 0 ]; then + return 1 + fi + + ## check localized npm command availablity + FS_Is_File "${___target}/bin/npx" + if [ $? -ne 0 ]; then + return 1 + fi + + return 0 + fi + + OS_Is_Command_Available "npm" + if [ $? -ne 0 ]; then + return 1 + fi + + OS_Is_Command_Available "npx" if [ $? -ne 0 ]; then return 1 fi + OS_Is_Command_Available "node" + if [ $? -ne 0 ]; then + return 1 + fi + + + # report status + return 1 +} + + + + +NODE_Is_Localized() { + # execute + if [ $(STRINGS_Is_Empty "$PROJECT_NODE_LOCALIZED") -ne 0 ] ; then + return 0 + fi + + + # report status + return 1 +} + + + + +NODE_NPM_Check_Login() { + # execute + if [ $(STRINGS_Is_Empty "$PROJECT_NODE_NPM_REGISTRY") -eq 0 ]; then + return 1 + fi + + if [ $(STRINGS_Is_Empty "$NPM_USERNAME") -eq 0 ]; then + return 1 + fi + + if [ $(STRINGS_Is_Empty "$NPM_TOKEN") -eq 0 ]; then + return 1 + fi + + if [ $(STRINGS_Is_Empty "$PROJECT_SCOPE") -eq 0 ]; then + return 1 + fi + + + # report status + return 0 +} + + + + +NODE_NPM_Install_Dependencies_All() { + # validate input + NODE_Is_Available + if [ $? -ne 0 ]; then + return 1 + fi + + + # execute + npm install + if [ $? -ne 0 ]; then + return 1 + fi + + + # report status + return 0 +} + + + + +NODE_NPM_Is_Valid() { + #___target="$1" + + + # validate input + if [ $(STRINGS_Is_Empty "$1") -eq 0 ]; then + return 1 + fi + + FS_Is_File "$1" + if [ $? -ne 0 ]; then + return 1 + fi + + + # execute + FS_Is_Target_A_NPM "$1" + if [ $? -ne 0 ]; then + return 1 + fi + + + # report status + return 0 +} + + + + +NODE_NPM_Publish() { + #___target="$1" + + + # validate input + if [ $(STRINGS_Is_Empty "$1") -eq 0 ]; then + return 1 + fi + + FS_Is_File "$1" + if [ $? -ne 0 ]; then + return 1 + fi + + NODE_Is_Available + if [ $? -ne 0 ]; then + return 1 + fi + + + # execute + ___workspace="${PROJECT_PATH_ROOT}/${PROJECT_PATH_TEMP}/release-npm" + ___package="${PROJECT_SKU}.tgz" + ___npmrc=".npmrc" + + ## setup workspace + FS_Remake_Directory "$___workspace" + ___current_path="$PWD" && cd "$___workspace" + + FS_Copy_File "$1" "$___package" + if [ $? -ne 0 ]; then + return 1 + fi + + FS_Write_File "$___npmrc" "\ +registry=${PROJECT_NODE_NPM_REGISTRY} +scope=@${PROJECT_SCOPE} +email=${NPM_USERNAME} +//${PROJECT_NODE_NPM_REGISTRY#*://}/:_authToken=${NPM_TOKEN} +" + if [ $? -ne 0 ]; then + FS_Remove_Silently "$___npmrc" + return 1 + fi + + FS_Is_File "$___npmrc" + if [ $? -ne 0 ]; then + return 1 + fi + + ## publish + npm publish "$___package" + ___process=$? + FS_Remove_Silently "$___npmrc" + cd "$___current_path" && ___current_path + if [ $___process -ne 0 ]; then + return 1 + fi + + + # report status + return 0 +} + + + + +NODE_NPM_Run() { + #___name="$1" + + + # validate input + NODE_Is_Available + if [ $? -ne 0 ]; then + return 1 + fi + + if [ $(STRINGS_Is_Empty "$1") -eq 0 ]; then + return 1 + fi + + + # execute + npm run "$1" + if [ $? -ne 0 ]; then + return 1 + fi + + + # report status + return 0 +} + + + + +NODE_Setup() { + # validate input + NODE_Is_Available + if [ $? -eq 0 ]; then + return 0 + fi + + + # execute + ___filepath="" + case "$PROJECT_ARCH" in + amd64) + ___filepath="x64" + ;; + arm) + ___filepath="armv7l" + ;; + arm64) + ___filepath="arm64" + ;; + ppc64le) + ___filepath="ppc64le" + ;; + s390x) + ___filepath="s390x" + ;; + *) + return 1 + ;; + esac + + case "$PROJECT_OS" in + aix) + ___filepath="aix-${___filepath}.tar.xz" + ;; + darwin) + ___filepath="darwin-${___filepath}.tar.xz" + ;; + windows) + ___filepath="win-${___filepath}.zip" + ;; + linux) + ___filepath="linux-${___filepath}.tar.xz" + ;; + *) + return 1 + ;; + esac + + ## download engine + ___filepath="node-${PROJECT_NODE_VERSION}-${___filepath}" + ___url="https://nodejs.org/dist/${PROJECT_NODE_VERSION}/${___filepath}" + ___filepath="${PROJECT_PATH_ROOT}/${PROJECT_PATH_TOOLS}/${___filepath}" + + FS_Make_Housing_Directory "$___filepath" + FS_Remove_Silently "$___filepath" + HTTP_Download "GET" "$___url" "$___filepath" + if [ $? -ne 0 ]; then + return 1 + fi + + ## unpack engine + FS_Is_File "$___filepath" + if [ $? -ne 0 ]; then + return 1 + fi + + ___location="$(NODE_Get_Activator_Path)" + FS_Remove_Silently "$(FS_Get_Directory "$___location")" + + ___target="${PROJECT_PATH_ROOT}/${PROJECT_PATH_TOOLS}/" + case "$PROJECT_OS" in + windows) + ZIP_Extract "$___target" "$___filepath" + ___process=$? + FS_Remove_Silently "$___filepath" + ___target="$(FS_Extension_Replace "$___filepath" ".zip" "")" + ;; + *) + TAR_Extract_XZ "$___target" "$___filepath" + ___process=$? + FS_Remove_Silently "$___filepath" + ___target="$(FS_Extension_Replace "$___filepath" ".tar.xz" "")" + ;; + esac + if [ $___process -ne 0 ]; then + return 1 + fi + + FS_Move "$___target" "$(FS_Get_Directory "$___location")" + if [ $? -ne 0 ]; then + return 1 + fi + + + ## create activator script + ___label="($PROJECT_PATH_NODE_ENGINE)" + ___target="$(FS_Get_Directory "$___location")/bin" + FS_Write_File "$___location" "\ +#!/bin/sh +___target=\"${___target}\" + + +deactivate() { + ___path=:\$PATH: + ___path=\${___path/:\$___target:/:} + ___path=\${___path%:} + ___path=\${___path#:} + PATH=\$___path + + export PS1=\"\${PS1##*${___label} }\" + unset PROJECT_NODE_LOCALIZED + return 0 +} + + + + +# check +if [ ! -z \"\$PROJECT_NODE_LOCALIZED\" ]; then + return 0 +fi + + + + +# activate +export PATH=\"\${___target}:\${PATH}\" + +export PROJECT_NODE_LOCALIZED='${___location}' +export PS1=\"${___label} \${PS1}\" +return 0 +" + FS_Is_File "$___location" + if [ $? -ne 0 ]; then + return 1 + fi + + ## test activator script + NODE_Activate_Local_Environment + if [ $? -ne 0 ] ; then + return 1 + fi + # report status return 0 diff --git a/automataCI/services/io/fs.ps1 b/automataCI/services/io/fs.ps1 index b1dfd0d0..82d9d0d5 100644 --- a/automataCI/services/io/fs.ps1 +++ b/automataCI/services/io/fs.ps1 @@ -23,7 +23,7 @@ function FS-Append-File { # perform file write - $null = Add-Content -Path $___target -Value $___content + $null = Add-Content -Path $___target -Value $___content -NoNewline if ($?) { return 0 } @@ -106,47 +106,55 @@ function FS-Extension-Remove { function FS-Extension-Replace { param ( - [string]$__target, + [string]$___path, [string]$___extension, [string]$___candidate ) # validate input - if ([string]::IsNullOrEmpty($__target)) { + if ([string]::IsNullOrEmpty($___path)) { return "" } # execute + ## prepare working parameters + $___target = Split-Path -Leaf "${___path}" + if ($___extension -eq "*") { - $___target = Split-Path -Leaf "${__target}" + ## trim all extensions to the first period $___target = $___target -replace '(\.\w+)+$' - if (-not [string]::IsNullOrEmpty($(Split-Path -Parent "${__target}"))) { - $___target = $(Split-Path -Parent "${__target}") + "\" + "${___target}" + ## restore directory pathing when available + if (-not [string]::IsNullOrEmpty($(Split-Path -Parent "${___path}"))) { + $___target = $(Split-Path -Parent "${___path}") + "\" + "${___target}" } } elseif (-not [string]::IsNullOrEmpty($___extension)) { + ## trim off existing extension if ($___extension.Substring(0,1) -eq ".") { $___extension = $___extension.Substring(1) } - - $___target = Split-Path -Leaf "${__target}" $___target = $___target -replace "\.${___extension}$" - if (-not [string]::IsNullOrEmpty($___candidate)) { - if ($___candidate.Substring(0,1) -eq ".") { - $___target += "." + $___candidate.Substring(1) - } else { - $___target += "." + $___candidate + ## append new extension when available + if ($___target -ne $___path) { + if (-not [string]::IsNullOrEmpty($___candidate)) { + if ($___candidate.Substring(0,1) -eq ".") { + $___target += "." + $___candidate.Substring(1) + } else { + $___target += "." + $___candidate + } } } - if (-not [string]::IsNullOrEmpty($(Split-Path -Parent "${__target}"))) { - $___target = $(Split-Path -Parent "${__target}") + "\" + "${___target}" + ## restore directory pathing when available + if (-not [string]::IsNullOrEmpty($(Split-Path -Parent "${___path}"))) { + $___target = $(Split-Path -Parent "${___path}") + "\" + "${___target}" } } else { - $___target = $__target + ## do nothing + $___target = $___path } @@ -474,6 +482,25 @@ function FS-Is-Target-A-MSI { +function FS-Is-Target-A-NPM { + param ( + [string]$___target + ) + + + # execute + if ($("${___target}" -replace '^.*_js-js.tgz') -ne "${___target}") { + return 0 + } + + + # report status + return 1 +} + + + + function FS-Is-Target-A-Nupkg { param ( [string]$___target @@ -500,7 +527,7 @@ function FS-Is-Target-A-PDF { # execute - if (($("${___target}" -replace '^.*.pdf') -ne "${___target}")) { + if ($("${___target}" -replace '^.*.pdf') -ne "${___target}") { return 0 } @@ -519,7 +546,7 @@ function FS-Is-Target-A-PYPI { # execute - if (($("${___target}" -replace '^.*-pypi') -ne "${___target}")) { + if ($("${___target}" -replace '^.*-pypi') -ne "${___target}") { return 0 } @@ -879,7 +906,7 @@ function FS-Write-File { # perform file write - $null = Set-Content -Path $___target -Value $___content + $null = Set-Content -Path $___target -Value $___content -NoNewline if ($?) { return 0 } diff --git a/automataCI/services/io/fs.sh b/automataCI/services/io/fs.sh index aacfa076..0e12c067 100644 --- a/automataCI/services/io/fs.sh +++ b/automataCI/services/io/fs.sh @@ -94,7 +94,7 @@ FS_Extension_Remove() { FS_Extension_Replace() { - #___target="$1" + #___path="$1" #___extension="$2" #___candidate="$3" @@ -107,34 +107,27 @@ FS_Extension_Replace() { # execute + ## prepare working parameters + ___target="${1##*/}" + if [ "$2" = "*" ]; then - ___target="${1##*/}" + ## trim all extensions to the first period ___target="${___target%%.*}" + ## restore directory pathing when available if [ ! -z "${1%/*}" ] && [ ! "${1%/*}" = "$1" ]; then ___target="${1%/*}/${___target}" fi elif [ ! -z "$2" ]; then + ## trim off existing extension if [ "$(printf -- "%.1s" "$2")" = "." ]; then ___extension="${2#*.}" else ___extension="$2" fi + ___target="${___target%.${___extension}*}" - ___target="${1##*/}" - while true; do - if [ "${___target#*.}" = "${___extension}" ]; then - ___target="${___target%.${___extension}*}" - continue - fi - - if [ ! "${___target##*.}" = "${___extension}" ]; then - break - fi - - ___target="${___target%.${___extension}*}" - done - + ## append new extension when available if [ ! "${___target}" = "${1##*/}" ]; then if [ ! -z "$3" ]; then if [ "$(printf -- "%.1s" "$3")" = "." ]; then @@ -145,17 +138,18 @@ FS_Extension_Replace() { fi fi + ## restore directory pathing when available if [ ! -z "${1%/*}" ] && [ ! "${1%/*}" = "$1" ]; then ___target="${1%/*}/${___target}" fi else + ## do nothing ___target="$1" fi - printf -- "%s" "$___target" - # report status + printf -- "%s" "$___target" return 0 } @@ -445,6 +439,25 @@ FS_Is_Target_A_MSI() { +FS_Is_Target_A_NPM() { + #___target="$1" + + + # execute + if [ "${1#*_js-js.tgz}" != "$1" ]; then + printf -- "0" + return 0 + fi + + + # report status + printf -- "1" + return 1 +} + + + + FS_Is_Target_A_Nupkg() { #___target="$1" @@ -821,7 +834,7 @@ FS_Write_File() { # perform file write - printf -- "%b" "$2" >> "$1" + printf -- "%b" "$2" > "$1" if [ $? -eq 0 ]; then return 0 fi diff --git a/automataCI/services/io/net/http.ps1 b/automataCI/services/io/net/http.ps1 index 83cf6551..9d40732d 100644 --- a/automataCI/services/io/net/http.ps1 +++ b/automataCI/services/io/net/http.ps1 @@ -41,52 +41,75 @@ function HTTP-Download { $null = FS-Make-Directory (Split-Path -Path $___filepath) -ErrorAction SilentlyContinue $___user_agent = "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/16.0 Safari/605.1.15" - ## download payload if (-not [string]::IsNullOrEmpty($___auth_header)) { if (Get-Command curl -ErrorAction SilentlyContinue) { - curl --location ` + $null = curl --location ` --header $___user_agent ` --header $___auth_header ` --output $___filepath ` --request $___method ` $___url if ($LASTEXITCODE -ne 0) { + $null = Remove-Item $___filepath ` + -Force ` + -Recurse ` + -ErrorAction SilentlyContinue return 1 } } elseif (Get-Command wget -ErrorAction SilentlyContinue) { - wget --max-redirect 16 ` + $null = wget --max-redirect 16 ` --header $___user_agent ` --header=$___auth_header ` --output-file=$___filepath ` --method=$___method ` $___url if ($LASTEXITCODE -ne 0) { + $null = Remove-Item $___filepath ` + -Force ` + -Recurse ` + -ErrorAction SilentlyContinue return 1 } } else { + $null = Remove-Item $___filepath ` + -Force ` + -Recurse ` + -ErrorAction SilentlyContinue return 1 } } else { if (Get-Command curl -ErrorAction SilentlyContinue) { - curl --location ` + $null = curl --location ` --header $___user_agent ` --output $___filepath ` --request $___method ` $___url if ($LASTEXITCODE -ne 0) { + $null = Remove-Item $___filepath ` + -Force ` + -Recurse ` + -ErrorAction SilentlyContinue return 1 } } elseif (Get-Command wget -ErrorAction SilentlyContinue) { - wget --max-redirect 16 ` + $null = wget --max-redirect 16 ` --header $___user_agent ` --output-file=$___filepath ` --method=$___method ` $___url if ($LASTEXITCODE -ne 0) { + $null = Remove-Item $___filepath ` + -Force ` + -Recurse ` + -ErrorAction SilentlyContinue return 1 } } else { + $null = Remove-Item $___filepath ` + -Force ` + -Recurse ` + -ErrorAction SilentlyContinue return 1 } } diff --git a/automataCI/services/io/net/http.sh b/automataCI/services/io/net/http.sh index 9179c48c..8953209b 100644 --- a/automataCI/services/io/net/http.sh +++ b/automataCI/services/io/net/http.sh @@ -48,6 +48,10 @@ HTTP_Download() { --output "$___filepath" \ --request "$___method" \ "$___url" + if [ $? -ne 0 ]; then + rm -rf "$___filepath" &> /dev/null + return 1 + fi elif [ ! -z "$(type -t wget)" ]; then wget --max-redirect 16 \ --header "$___user_agent" \ @@ -55,7 +59,12 @@ HTTP_Download() { --output-file"$___filepath" \ --method="$___method" \ "$___url" + if [ $? -ne 0 ]; then + rm -rf "$___filepath" &> /dev/null + return 1 + fi else + rm -rf "$___filepath" &> /dev/null return 1 fi else @@ -65,13 +74,22 @@ HTTP_Download() { --output "$___filepath" \ --request "$___method" \ "$___url" + if [ $? -ne 0 ]; then + rm -rf "$___filepath" &> /dev/null + return 1 + fi elif [ ! -z "$(type -t wget)" ]; then wget --max-redirect 16 \ --header "$___user_agent" \ --output-file"$___filepath" \ --method="$___method" \ "$___url" + if [ $? -ne 0 ]; then + rm -rf "$___filepath" &> /dev/null + return 1 + fi else + rm -rf "$___filepath" &> /dev/null return 1 fi fi diff --git a/automataCI/services/io/os.ps1 b/automataCI/services/io/os.ps1 index e95420a7..e9df5602 100644 --- a/automataCI/services/io/os.ps1 +++ b/automataCI/services/io/os.ps1 @@ -212,6 +212,29 @@ function OS-Is-Run-Simulated { +function OS-Remove-Path { + param( + [string]$___path + ) + + + # validate input + if ([string]::IsNullOrEmpty("${___path}")) { + return 1 + } + + + # execute + $env:Path = ($env:Path.Split(';') | Where-Object { $_ -ne "${___path}" }) -join ';' + + + # report status + return 0 +} + + + + function OS-Sync { $env:Path = [System.Environment]::GetEnvironmentVariable("Path","Machine") ` + ";" ` diff --git a/automataCI/services/io/os.sh b/automataCI/services/io/os.sh index edcaad12..e5f4ba14 100644 --- a/automataCI/services/io/os.sh +++ b/automataCI/services/io/os.sh @@ -147,6 +147,31 @@ OS_Is_Run_Simulated() { +OS_Remove_Path() { + #___path="$1" + + + # validate input + if [ -z "$1" ]; then + return 1 + fi + + + # execute + ___paths=:$PATH: + ___paths=${___paths/:$1:/:} + ___paths=${___paths%:} + ___paths=${___paths#:} + PATH=$___paths + + + # report status + return 0 +} + + + + OS_Sync() { # execute sync diff --git a/src/.ci/_package-archive_unix-any.sh b/src/.ci/_package-archive_unix-any.sh index c29a7084..81c934b2 100644 --- a/src/.ci/_package-archive_unix-any.sh +++ b/src/.ci/_package-archive_unix-any.sh @@ -87,6 +87,8 @@ PACKAGE_Assemble_ARCHIVE_Content() { return 10 # not applicable elif [ $(FS_Is_Target_A_PDF "$_target") -eq 0 ]; then return 10 # not applicable + elif [ $(FS_Is_Target_A_NPM "$_target") -eq 0 ]; then + return 10 # not applicable else I18N_Assemble "$_target" "$_directory" FS_Copy_File "$_target" "$_directory" diff --git a/src/.ci/_package-archive_windows-any.ps1 b/src/.ci/_package-archive_windows-any.ps1 index 88413eeb..38b15bb5 100644 --- a/src/.ci/_package-archive_windows-any.ps1 +++ b/src/.ci/_package-archive_windows-any.ps1 @@ -88,6 +88,8 @@ function PACKAGE-Assemble-ARCHIVE-Content { return 10 # not applicable } elseif ($(FS-Is-Target-A-PDF "${_target}") -eq 0) { return 10 # not applicable + } elseif ($(FS-Is-Target-A-NPM "${_target}") -eq 0) { + return 10 # not applicable } else { $null = I18N-Assemble "${_target}" "${_directory}" $___process = FS-Copy-File "${_target}" "${_directory}" diff --git a/src/.ci/_package-deb_unix-any.sh b/src/.ci/_package-deb_unix-any.sh index 84cb601d..677cf8ac 100644 --- a/src/.ci/_package-deb_unix-any.sh +++ b/src/.ci/_package-deb_unix-any.sh @@ -94,6 +94,8 @@ PACKAGE_Assemble_DEB_Content() { return 10 # not applicable elif [ $(FS_Is_Target_A_PDF "$_target") -eq 0 ]; then return 10 # not applicable + elif [ $(FS_Is_Target_A_NPM "$_target") -eq 0 ]; then + return 10 # not applicable else # copy main program # TIP: (1) usually is: usr/local/bin or usr/local/sbin diff --git a/src/.ci/_package-deb_windows-any.ps1 b/src/.ci/_package-deb_windows-any.ps1 index 716a8abb..c1b868e6 100644 --- a/src/.ci/_package-deb_windows-any.ps1 +++ b/src/.ci/_package-deb_windows-any.ps1 @@ -97,6 +97,8 @@ function PACKAGE-Assemble-DEB-Content { return 10 # not applicable } elseif ($(FS-Is-Target-A-PDF "${_target}") -eq 0) { return 10 # not applicable + } elseif ($(FS-Is-Target-A-NPM "${_target}") -eq 0) { + return 10 # not applicable } else { # copy main program # TIP: (1) usually is: usr/local/bin or usr/local/sbin diff --git a/src/.ci/_package-docker_unix-any.sh b/src/.ci/_package-docker_unix-any.sh index cf3e477b..a981810c 100644 --- a/src/.ci/_package-docker_unix-any.sh +++ b/src/.ci/_package-docker_unix-any.sh @@ -55,6 +55,8 @@ PACKAGE_Assemble_DOCKER_Content() { return 10 # not applicable elif [ $(FS_Is_Target_A_PDF "$_target") -eq 0 ]; then return 10 # not applicable + elif [ $(FS_Is_Target_A_NPM "$_target") -eq 0 ]; then + return 10 # not applicable fi case "$_target_os" in diff --git a/src/.ci/_package-docker_windows-any.ps1 b/src/.ci/_package-docker_windows-any.ps1 index fdfedee8..b1064339 100644 --- a/src/.ci/_package-docker_windows-any.ps1 +++ b/src/.ci/_package-docker_windows-any.ps1 @@ -54,6 +54,8 @@ function PACKAGE-Assemble-DOCKER-Content { return 10 # not applicable } elseif ($(FS-Is-Target-A-MSI "${_target}") -eq 0) { return 10 # not applicable + } elseif ($(FS-Is-Target-A-NPM "${_target}") -eq 0) { + return 10 # not applicable } switch ($_target_os) { diff --git a/src/.ci/_package-flatpak_unix-any.sh b/src/.ci/_package-flatpak_unix-any.sh index 4c7a1515..a9e3be35 100644 --- a/src/.ci/_package-flatpak_unix-any.sh +++ b/src/.ci/_package-flatpak_unix-any.sh @@ -63,6 +63,8 @@ PACKAGE_Assemble_FLATPAK_Content() { return 10 # not applicable elif [ $(FS_Is_Target_A_PDF "$_target") -eq 0 ]; then return 10 # not applicable + elif [ $(FS_Is_Target_A_NPM "$_target") -eq 0 ]; then + return 10 # not applicable elif [ ! "$_target_os" = "linux" ] && [ ! "$_target_os" = "any" ]; then return 10 # not applicable fi diff --git a/src/.ci/_package-flatpak_windows-any.ps1 b/src/.ci/_package-flatpak_windows-any.ps1 index 574197ee..e6062220 100644 --- a/src/.ci/_package-flatpak_windows-any.ps1 +++ b/src/.ci/_package-flatpak_windows-any.ps1 @@ -63,6 +63,8 @@ function PACKAGE-Assemble-FLATPAK-Content { return 10 # not applicable } elseif ($(FS-Is-Target-A-PDF "${_target}") -eq 0) { return 10 # not applicable + } elseif ($(FS-Is-Target-A-NPM "${_target}") -eq 0) { + return 10 # not applicable } elseif (($_target_os -ne "linux") -and ($_target_os -ne "any")) { return 10 # not applicable } diff --git a/src/.ci/_package-ipk_unix-any.sh b/src/.ci/_package-ipk_unix-any.sh index 4e323d51..6c85e03a 100644 --- a/src/.ci/_package-ipk_unix-any.sh +++ b/src/.ci/_package-ipk_unix-any.sh @@ -80,6 +80,8 @@ PACKAGE_Assemble_IPK_Content() { return 10 # not applicable elif [ $(FS_Is_Target_A_PDF "$_target") -eq 0 ]; then return 10 # not applicable + elif [ $(FS_Is_Target_A_NPM "$_target") -eq 0 ]; then + return 10 # not applicable else # copy main program # TIP: (1) usually is: usr/local/bin or usr/local/sbin diff --git a/src/.ci/_package-ipk_windows-any.ps1 b/src/.ci/_package-ipk_windows-any.ps1 index 2ce9eb39..8d23c088 100644 --- a/src/.ci/_package-ipk_windows-any.ps1 +++ b/src/.ci/_package-ipk_windows-any.ps1 @@ -79,6 +79,8 @@ function PACKAGE-Assemble-IPK-Content { return 10 # not applicable } elseif ($(FS-Is-Target-A-PDF "${_target}") -eq 0) { return 10 # not applicable + } elseif ($(FS-Is-Target-A-NPM "${_target}") -eq 0) { + return 10 # not applicable } else { # copy main program # TIP: (1) usually is: usr/local/bin or usr/local/sbin diff --git a/src/.ci/_package-npm_unix-any.sh b/src/.ci/_package-npm_unix-any.sh new file mode 100644 index 00000000..1085301c --- /dev/null +++ b/src/.ci/_package-npm_unix-any.sh @@ -0,0 +1,54 @@ +#!/bin/sh +# Copyright 2024 (Holloway) Chew, Kean Ho +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy of +# the License at: +# http://www.apache.org/licenses/LICENSE-2.0 +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations under +# the License. +. "${LIBS_AUTOMATACI}/services/io/fs.sh" +. "${LIBS_AUTOMATACI}/services/i18n/translations.sh" + + + + +# initialize +if [ "$PROJECT_PATH_ROOT" = "" ]; then + >&2 printf "[ ERROR ] - Please run from automataCI/ci.sh.ps1 instead!\n" + return 1 +fi + + + + +PACKAGE_Assemble_NPM_Content() { + _target="$1" + _directory="$2" + _target_name="$3" + _target_os="$4" + _target_arch="$5" + + + # validate project + if [ $(FS_Is_Target_A_NPM "$_target") -ne 0 ]; then + return 10 # not applicable + fi + + + # execute + __dest="${_directory}/${PROJECT_SKU}_${PROJECT_VERSION}_js-js.tgz" + I18N_Copy "$_target" "$__dest" + FS_Copy_File "$_target" "$__dest" + if [ $? -ne 0 ]; then + I18N_Copy_Failed + return 1 + fi + + + # report status + return 0 +} diff --git a/src/.ci/_package-npm_windows-any.ps1 b/src/.ci/_package-npm_windows-any.ps1 new file mode 100644 index 00000000..3b783071 --- /dev/null +++ b/src/.ci/_package-npm_windows-any.ps1 @@ -0,0 +1,55 @@ +# Copyright 2024 (Holloway) Chew, Kean Ho +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy +# of the License at: +# http://www.apache.org/licenses/LICENSE-2.0 +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. +. "${env:LIBS_AUTOMATACI}\services\io\fs.ps1" +. "${env:LIBS_AUTOMATACI}\services\i18n\translations.ps1" + + + + +# initialize +if (-not (Test-Path -Path $env:PROJECT_PATH_ROOT)) { + Write-Error "[ ERROR ] - Please run from automataCI\ci.sh.ps1 instead!`n" + exit 1 +} + + + + +function PACKAGE-Assemble-NPM-Content { + param ( + [string]$_target, + [string]$_directory, + [string]$_target_name, + [string]$_target_os, + [string]$_target_arch + ) + + + # validate project + if ($(FS-Is-Target-A-NPM "${_target}") -ne 0) { + return 10 # not applicable + } + + + # execute + $__dest = "${_directory}\${env:PROJECT_SKU}_${env:PROJECT_VERSION}_js-js.tgz" + $null = I18N-Copy "${_target}" "${__dest}" + $___process = FS-Copy-File "${_target}" "${__dest}" + if ($___process -ne 0) { + $null = I18N-Copy-Failed + return 1 + } + + + # report status + return 0 +} diff --git a/src/.ci/_package-rpm_unix-any.sh b/src/.ci/_package-rpm_unix-any.sh index bdcf014e..6328f011 100644 --- a/src/.ci/_package-rpm_unix-any.sh +++ b/src/.ci/_package-rpm_unix-any.sh @@ -111,6 +111,8 @@ install -m 0644 copyright %{buildroot}/usr/local/share/doc/lib${PROJECT_SKU}/ return 10 # not applicable elif [ $(FS_Is_Target_A_PDF "$_target") -eq 0 ]; then return 10 # not applicable + elif [ $(FS_Is_Target_A_NPM "$_target") -eq 0 ]; then + return 10 # not applicable else # copy main program # TIP: (1) copy all files into "${__directory}/BUILD" directory. diff --git a/src/.ci/_package-rpm_windows-any.ps1 b/src/.ci/_package-rpm_windows-any.ps1 index 50f833b3..861c293e 100644 --- a/src/.ci/_package-rpm_windows-any.ps1 +++ b/src/.ci/_package-rpm_windows-any.ps1 @@ -112,6 +112,8 @@ install -m 0644 copyright %{buildroot}/usr/local/share/doc/lib${env:PROJECT_SKU} return 10 # not applicable } elseif ($(FS-Is-Target-A-PDF "${_target}") -eq 0) { return 10 # not applicable + } elseif ($(FS-Is-Target-A-NPM "${_target}") -eq 0) { + return 10 # not applicable } else { # copy main program # TIP: (1) usually is: usr/local/bin or usr/local/sbin diff --git a/src/.ci/package_unix-any.sh b/src/.ci/package_unix-any.sh index a3231e08..83a6d867 100644 --- a/src/.ci/package_unix-any.sh +++ b/src/.ci/package_unix-any.sh @@ -29,6 +29,7 @@ fi . "${PROJECT_PATH_ROOT}/${PROJECT_PATH_SOURCE}/${PROJECT_PATH_CI}/_package-homebrew_unix-any.sh" . "${PROJECT_PATH_ROOT}/${PROJECT_PATH_SOURCE}/${PROJECT_PATH_CI}/_package-ipk_unix-any.sh" . "${PROJECT_PATH_ROOT}/${PROJECT_PATH_SOURCE}/${PROJECT_PATH_CI}/_package-msi_unix-any.sh" +. "${PROJECT_PATH_ROOT}/${PROJECT_PATH_SOURCE}/${PROJECT_PATH_CI}/_package-npm_unix-any.sh" . "${PROJECT_PATH_ROOT}/${PROJECT_PATH_SOURCE}/${PROJECT_PATH_CI}/_package-pdf_unix-any.sh" . "${PROJECT_PATH_ROOT}/${PROJECT_PATH_SOURCE}/${PROJECT_PATH_CI}/_package-pypi_unix-any.sh" . "${PROJECT_PATH_ROOT}/${PROJECT_PATH_SOURCE}/${PROJECT_PATH_CI}/_package-rpm_unix-any.sh" diff --git a/src/.ci/package_windows-any.ps1 b/src/.ci/package_windows-any.ps1 index fb5b4fd7..dfb0de3f 100644 --- a/src/.ci/package_windows-any.ps1 +++ b/src/.ci/package_windows-any.ps1 @@ -28,6 +28,7 @@ if (-not (Test-Path -Path $env:PROJECT_PATH_ROOT)) { . "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_SOURCE}\${env:PROJECT_PATH_CI}\_package-homebrew_windows-any.ps1" . "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_SOURCE}\${env:PROJECT_PATH_CI}\_package-ipk_windows-any.ps1" . "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_SOURCE}\${env:PROJECT_PATH_CI}\_package-msi_windows-any.ps1" +. "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_SOURCE}\${env:PROJECT_PATH_CI}\_package-npm_windows-any.ps1" . "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_SOURCE}\${env:PROJECT_PATH_CI}\_package-pdf_windows-any.ps1" . "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_SOURCE}\${env:PROJECT_PATH_CI}\_package-pypi_windows-any.ps1" . "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_SOURCE}\${env:PROJECT_PATH_CI}\_package-rpm_windows-any.ps1" diff --git a/srcANGULAR/.ci/build_unix-any.sh b/srcANGULAR/.ci/build_unix-any.sh index a954a40c..da40b822 100644 --- a/srcANGULAR/.ci/build_unix-any.sh +++ b/srcANGULAR/.ci/build_unix-any.sh @@ -33,7 +33,6 @@ ${PROJECT_SKU}-docs_any-any " -FS_Remake_Directory "${PROJECT_PATH_ROOT}/${PROJECT_PATH_BUILD}" I18N_Activate_Environment diff --git a/srcANGULAR/.ci/build_windows-any.ps1 b/srcANGULAR/.ci/build_windows-any.ps1 index 19c6bd63..75494779 100644 --- a/srcANGULAR/.ci/build_windows-any.ps1 +++ b/srcANGULAR/.ci/build_windows-any.ps1 @@ -32,7 +32,6 @@ $__placeholders = @( ) -$null = FS-Remake-Directory "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_BUILD}" $null = I18N-Activate-Environment diff --git a/srcNODE/.ci/build_unix-any.sh b/srcNODE/.ci/build_unix-any.sh new file mode 100644 index 00000000..a8702d98 --- /dev/null +++ b/srcNODE/.ci/build_unix-any.sh @@ -0,0 +1,238 @@ +#!/bin/sh +# Copyright 2024 (Holloway) Chew, Kean Ho +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy of +# the License at: +# http://www.apache.org/licenses/LICENSE-2.0 +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations under +# the License. + + + + +# initialize +if [ "$PROJECT_PATH_ROOT" = "" ]; then + >&2 printf "[ ERROR ] - Please run from automataCI/ci.sh.ps1 instead!\n" + return 1 +fi + +. "${LIBS_AUTOMATACI}/services/io/fs.sh" +. "${LIBS_AUTOMATACI}/services/io/strings.sh" +. "${LIBS_AUTOMATACI}/services/i18n/translations.sh" +. "${LIBS_AUTOMATACI}/services/archive/tar.sh" +. "${LIBS_AUTOMATACI}/services/compilers/node.sh" + + + + +# define build variables +__workspace_path="${PROJECT_PATH_ROOT}/${PROJECT_PATH_TEMP}/build-${PROJECT_SKU}_js-js" +__placeholders="\ +" + + + + +# execute +I18N_Activate_Environment +NODE_Activate_Local_Environment +if [ $? -ne 0 ]; then + I18N_Activate_Failed + return 1 +fi + + +## build the artifacts and shift it to the workspace +I18N_Build "$PROJECT_NODE" +FS_Remove_Silently "$__workspace_path" +FS_Make_Housing_Directory "$__workspace_path" + +__current_path="$PWD" && cd "${PROJECT_PATH_ROOT}/${PROJECT_NODE}" +NODE_NPM_Run "build" +___process=$? +cd "$__current_path" && unset __current_path +if [ $___process -ne 0 ]; then + I18N_Build_Failed + return 1 +fi + +___source="${PROJECT_PATH_ROOT}/${PROJECT_NODE}/dist/build" +FS_Move "$___source" "$__workspace_path" +if [ $? -ne 0 ]; then + I18N_Build_Failed + return 1 +fi + +___dest="${__workspace_path}/package.json" +___old_IFS="$IFS" +while IFS="" read -r ___line || [ -n "$___line" ]; do + ## overrides name + ___key=' "name": ' + if [ $(STRINGS_Is_Empty "${___line%%${___key}*}") -eq 0 ]; then + ___value="$(STRINGS_To_Lowercase "@${PROJECT_SCOPE}/${PROJECT_SKU}")" + FS_Append_File "$___dest" "${___key}\"${___value}\",\n" + if [ $? -ne 0 ]; then + IFS="$___old_IFS" && unset ___old_IFS + I18N_Build_Failed + return 1 + fi + + continue + fi + + ## overrides version + ___key=' "version": ' + if [ $(STRINGS_Is_Empty "${___line%%${___key}*}") -eq 0 ]; then + FS_Append_File "$___dest" "${___key}\"${PROJECT_VERSION}\",\n" + if [ $? -ne 0 ]; then + IFS="$___old_IFS" && unset ___old_IFS + I18N_Build_Failed + return 1 + fi + + continue + fi + + ## overrides description + ___key=' "description": ' + if [ $(STRINGS_Is_Empty "${___line%%${___key}*}") -eq 0 ]; then + FS_Append_File "$___dest" "${___key}\"${PROJECT_PITCH}\",\n" + if [ $? -ne 0 ]; then + IFS="$___old_IFS" && unset ___old_IFS + I18N_Build_Failed + return 1 + fi + + continue + fi + + ## overrides author + ___key=' "author": ' + if [ $(STRINGS_Is_Empty "${___line%%${___key}*}") -eq 0 ]; then + FS_Append_File "$___dest" "${___key}\"${PROJECT_CONTACT_NAME}\",\n" + if [ $? -ne 0 ]; then + IFS="$___old_IFS" && unset ___old_IFS + I18N_Build_Failed + return 1 + fi + + continue + fi + + ## overrides license + ___key=' "license": ' + if [ $(STRINGS_Is_Empty "${___line%%${___key}*}") -eq 0 ]; then + FS_Append_File "$___dest" "${___key}\"${PROJECT_LICENSE}\",\n" + if [ $? -ne 0 ]; then + IFS="$___old_IFS" && unset ___old_IFS + I18N_Build_Failed + return 1 + fi + + continue + fi + + ## overrides homepage + ___key=' "homepage": ' + if [ $(STRINGS_Is_Empty "${___line%%${___key}*}") -eq 0 ]; then + FS_Append_File "$___dest" "${___key}\"${PROJECT_CONTACT_WEBSITE}\",\n" + if [ $? -ne 0 ]; then + IFS="$___old_IFS" && unset ___old_IFS + I18N_Build_Failed + return 1 + fi + + continue + fi + + ## retain + FS_Append_File "$___dest" "${___line}\n" + if [ $? -ne 0 ]; then + IFS="$___old_IFS" && unset ___old_IFS + I18N_Build_Failed + return 1 + fi +done < "${PROJECT_PATH_ROOT}/${PROJECT_NODE}/package.json" +IFS="$___old_IFS" && unset ___old_IFS + + +## assemble assets and npm metadata files +I18N_Assemble_Package +FS_Copy_File "${PROJECT_PATH_ROOT}/README.md" "${__workspace_path}/README.md" +if [ $? -ne 0 ]; then + I18N_Assemble_Failed + return 1 +fi + +FS_Copy_File "${PROJECT_PATH_ROOT}/LICENSE.txt" "${__workspace_path}/LICENSE.txt" +if [ $? -ne 0 ]; then + I18N_Assemble_Failed + return 1 +fi + + +## export npm tarball +___dest="${PROJECT_PATH_ROOT}/${PROJECT_PATH_BUILD}/${PROJECT_SKU}_js-js.tar.gz" +I18N_Export "$___dest" +FS_Make_Housing_Directory "$___dest" +FS_Remove_Silently "$___dest" + +__current_path="$PWD" && cd "$__workspace_path" +TAR_Create_GZ "$___dest" "." +___process=$? +cd "$__current_path" && unset __current_path +if [ $___process -ne 0 ]; then + I18N_Export_Failed + return 1 +fi + +### IMPORTANT: npm only recognizes .tgz file extension so rename it accordingly. +___source="$___dest" +___dest="${PROJECT_PATH_ROOT}/${PROJECT_PATH_BUILD}/${PROJECT_SKU}_js-js.tgz" +FS_Remove_Silently "$___dest" +FS_Move "$___source" "$___dest" +if [ $___process -ne 0 ]; then + I18N_Export_Failed + return 1 +fi + + + + +# placeholding flag files +__old_IFS="$IFS" +while IFS="" read -r __line || [ -n "$__line" ]; do + if [ $(STRINGS_Is_Empty "$__line") -eq 0 ]; then + continue + fi + + + # build the file + __file="${PROJECT_PATH_ROOT}/${PROJECT_PATH_BUILD}/${__line}" + I18N_Build "$__line" + FS_Remove_Silently "$__file" + FS_Touch_File "$__file" + if [ $? -ne 0 ]; then + I18N_Build_Failed + IFS="$__old_IFS" && unset __old_IFS + return 1 + fi +done < +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy +# of the License at: +# http://www.apache.org/licenses/LICENSE-2.0 +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. + + + + +# initialize +if (-not (Test-Path -Path $env:PROJECT_PATH_ROOT)) { + Write-Error "[ ERROR ] - Please run from automataCI\ci.sh.ps1 instead!`n" + return 1 +} + +. "${env:LIBS_AUTOMATACI}\services\io\fs.ps1" +. "${env:LIBS_AUTOMATACI}\services\i18n\translations.ps1" +. "${env:LIBS_AUTOMATACI}\services\archive\tar.ps1" +. "${env:LIBS_AUTOMATACI}\services\compilers\node.ps1" + + + + +# define build variables +$__workspace_path = "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_TEMP}\build-${env:PROJECT_SKU}_js-js" +$__placeholders = @( +) + + + + +# execute +$null = I18N-Activate-Environment +$___process = NODE-Activate-Local-Environment +if ($___process -ne 0) { + $null = I18N-Activate-Failed + return 1 +} + + +## build the artifacts and shift it to the workspace +$null = I18N-Build "${env:PROJECT_NODE}" +$null = FS-Remove-Silently "${__workspace_path}" +$null = FS-Make-Housing-Directory "${__workspace_path}" + +$__current_path = Get-Location +$null = Set-Location "${env:PROJECT_PATH_ROOT}\${env:PROJECT_NODE}" +$___process = NODE-NPM-Run "build" +$null = Set-Location "${__current_path}" +$null = Remove-Variable __current_path +if ($___process -ne 0) { + $null = I18N-Build-Failed + return 1 +} + +$___source = "${env:PROJECT_PATH_ROOT}\${env:PROJECT_NODE}\dist\build" +$___process = FS-Move "${___source}" "${__workspace_path}" +if ($___process -ne 0) { + $null = I18N-Build-Failed + return 1 +} + +$___dest = "${__workspace_path}\package.json" +foreach ($___line in (Get-Content "${env:PROJECT_PATH_ROOT}\${env:PROJECT_NODE}\package.json")) { + ## overrides name + $___key = ' "name": ' + if ($(STRINGS-Is-Empty "$($___line -replace "^${___key}.*$")") -eq 0) { + $___value = "$(STRINGS-To-Lowercase "@${env:PROJECT_SCOPE}/${env:PROJECT_SKU}")" + $___process = FS-Append-File "${___dest}" "${___key}`"${___value}`",`n" + if ($___process -ne 0) { + $null = I18N-Build-Failed + return 1 + } + + continue + } + + ## overrides version + $___key = ' "version": ' + if ($(STRINGS-Is-Empty "$($___line -replace "^${___key}.*$")") -eq 0) { + $___process = FS-Append-File "${___dest}" "${___key}`"${env:PROJECT_VERSION}`",`n" + if ($___process -ne 0) { + $null = I18N-Build-Failed + return 1 + } + + continue + } + + ## overrides description + $___key = ' "description": ' + if ($(STRINGS-Is-Empty "$($___line -replace "^${___key}.*$")") -eq 0) { + $___process = FS-Append-File "${___dest}" "${___key}`"${env:PROJECT_PITCH}`",`n" + if ($___process -ne 0) { + $null = I18N-Build-Failed + return 1 + } + + continue + } + + ## overrides author + $___key = ' "author": ' + if ($(STRINGS-Is-Empty "$($___line -replace "^${___key}.*$")") -eq 0) { + $___process = FS-Append-File "${___dest}" "${___key}`"${env:PROJECT_CONTACT_NAME}`",`n" + if ($___process -ne 0) { + $null = I18N-Build-Failed + return 1 + } + + continue + } + + ## overrides license + $___key = ' "license": ' + if ($(STRINGS-Is-Empty "$($___line -replace "^${___key}.*$")") -eq 0) { + $___process = FS-Append-File "${___dest}" "${___key}`"${env:PROJECT_LICENSE}`",`n" + if ($___process -ne 0) { + $null = I18N-Build-Failed + return 1 + } + + continue + } + + ## overrides homepage + $___key = ' "homepage": ' + if ($(STRINGS-Is-Empty "$($___line -replace "^${___key}.*$")") -eq 0) { + $___process = FS-Append-File "${___dest}" "${___key}`"${env:PROJECT_CONTACT_WEBSITE}`",`n" + if ($___process -ne 0) { + $null = I18N-Build-Failed + return 1 + } + + continue + } + + ## retain + $___process = FS-Append-File "${___dest}" "${___line}`n" + if ($___process -ne 0) { + $null = I18N-Build-Failed + return 1 + } +} + + +## assemble assets and npm metadata files +$null = I18N-Assemble-Package +$___process = FS-Copy-File ` + "${env:PROJECT_PATH_ROOT}\README.md" ` + "${__workspace_path}\README.md" +if ($___process -ne 0) { + $null = I18N-Assemble-Failed + return 1 +} + +$___process = FS-Copy-File ` + "${env:PROJECT_PATH_ROOT}\LICENSE.txt" ` + "${__workspace_path}\LICENSE.txt" +if ($___process -ne 0) { + $null = I18N-Assemble-Failed + return 1 +} + + +## export npm tarball +$___dest = "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_BUILD}\${env:PROJECT_SKU}_js-js.tar.gz" +$null = I18N-Export "${___dest}" +$null = FS-Make-Housing-Directory "${___dest}" +$null = FS-Remove-Silently "${___dest}" + +$__current_path = Get-Location +$null = Set-Location "${__workspace_path}" +$___process = TAR-Create-GZ "${___dest}" "." +$null = Set-Location "${__current_path}" +$null = Remove-Variable __current_path +if ($___process -ne 0) { + $null = I18N-Export-Failed + return 1 +} + +### IMPORTANT: npm only recognizes .tgz file extension so rename it accordingly. +$___source = "${___dest}" +$___dest = "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_BUILD}\${env:PROJECT_SKU}_js-js.tgz" +$null = FS-Remove-Silently "${___dest}" +$___process = FS-Move "${___source}" "${___dest}" +if ($___process -ne 0) { + $null = I18N-Export-Failed + return 1 +} + + + + +# placeholding flag files +foreach ($__line in $__placeholders) { + if ($(STRINGS-Is-Empty "${__line}") -eq 0) { + continue + } + + + # build the file + $__file = "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_BUILD}\${__line}" + $null = I18N-Build "${__line}" + $null = FS-Remove-Silently "${__file}" + $___process = FS-Touch-File "${__file}" + if ($___process -ne 0) { + $null = I18N-Build-Failed + return 1 + } +} + + + + +# compose documentations + + + + +# report status +return 0 diff --git a/srcNODE/.ci/prepare_unix-any.sh b/srcNODE/.ci/prepare_unix-any.sh new file mode 100644 index 00000000..eb3e632e --- /dev/null +++ b/srcNODE/.ci/prepare_unix-any.sh @@ -0,0 +1,52 @@ +#!/bin/sh +# Copyright 2024 (Holloway) Chew, Kean Ho +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy of +# the License at: +# http://www.apache.org/licenses/LICENSE-2.0 +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations under +# the License. + + + + +# initialize +if [ "$PROJECT_PATH_ROOT" = "" ]; then + >&2 printf "[ ERROR ] - Please run from automataCI/ci.sh.ps1 instead!\n" + return 1 +fi + +. "${LIBS_AUTOMATACI}/services/i18n/translations.sh" +. "${LIBS_AUTOMATACI}/services/compilers/node.sh" + + + + +# execute +I18N_Activate_Environment +NODE_Activate_Local_Environment +if [ $? -ne 0 ]; then + I18N_Activate_Failed + return 1 +fi + + +I18N_Import_Dependencies +__current_path="$PWD" && cd "${PROJECT_PATH_ROOT}/${PROJECT_NODE}" +NODE_NPM_Install_Dependencies_All +___process=$? +cd "$__current_path" && unset __current_path +if [ $___process -ne 0 ]; then + I18N_Import_Failed + return 1 +fi + + + + +# report status +return 0 diff --git a/srcNODE/.ci/prepare_windows-any.ps1 b/srcNODE/.ci/prepare_windows-any.ps1 new file mode 100644 index 00000000..8246ddfe --- /dev/null +++ b/srcNODE/.ci/prepare_windows-any.ps1 @@ -0,0 +1,52 @@ +# Copyright 2024 (Holloway) Chew, Kean Ho +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy +# of the License at: +# http://www.apache.org/licenses/LICENSE-2.0 +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. + + + + +# initialize +if (-not (Test-Path -Path $env:PROJECT_PATH_ROOT)) { + Write-Error "[ ERROR ] - Please run from automataCI\ci.sh.ps1 instead!`n" + return 1 +} + +. "${env:LIBS_AUTOMATACI}\services\i18n\translations.ps1" +. "${env:LIBS_AUTOMATACI}\services\compilers\node.ps1" + + + + +# execute +$null = I18N-Activate-Environment +$___process = NODE-Activate-Local-Environment +if ($___process -ne 0) { + $null = I18N-Activate-Failed + return 1 +} + + +$null = I18N-Import-Dependencies +$__current_path = Get-Location +$null = Set-Location "${env:PROJECT_PATH_ROOT}\${env:PROJECT_NODE}" +$___process = NODE-NPM-Install-Dependencies-All +$null = Set-Location "${__current_path}" +$null = Remove-Variable -Name __current_path +if ($___process -ne 0) { + $null = I18N-Import-Failed + return 1 +} + + + + +# return status +return 0 diff --git a/srcNODE/.ci/start_unix-any.sh b/srcNODE/.ci/start_unix-any.sh new file mode 100644 index 00000000..32d65b43 --- /dev/null +++ b/srcNODE/.ci/start_unix-any.sh @@ -0,0 +1,47 @@ +#!/bin/sh +# Copyright 2024 (Holloway) Chew, Kean Ho +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy of +# the License at: +# http://www.apache.org/licenses/LICENSE-2.0 +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations under +# the License. + + + + +# initialize +if [ "$PROJECT_PATH_ROOT" = "" ]; then + >&2 printf "[ ERROR ] - Please run from automataCI/ci.sh.ps1 instead!\n" + return 1 +fi + +. "${LIBS_AUTOMATACI}/services/i18n/translations.sh" +. "${LIBS_AUTOMATACI}/services/compilers/node.sh" + + + + +# execute +I18N_Activate_Environment +NODE_Activate_Local_Environment +if [ $? -ne 0 ]; then + I18N_Activate_Failed + return 1 +fi + + + + +# execute +I18N_Guide_Start_Source "$PROJECT_NODE_LOCALIZED" + + + + +# report status +return 0 diff --git a/srcNODE/.ci/start_windows-any.ps1 b/srcNODE/.ci/start_windows-any.ps1 new file mode 100644 index 00000000..8c375c56 --- /dev/null +++ b/srcNODE/.ci/start_windows-any.ps1 @@ -0,0 +1,43 @@ +# Copyright 2024 (Holloway) Chew, Kean Ho +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy +# of the License at: +# http://www.apache.org/licenses/LICENSE-2.0 +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. + + + + +# initialize +if (-not (Test-Path -Path $env:PROJECT_PATH_ROOT)) { + Write-Error "[ ERROR ] - Please run from automataCI\ci.sh.ps1 instead!`n" + return 1 +} + +. "${env:LIBS_AUTOMATACI}\services\i18n\translations.ps1" +. "${env:LIBS_AUTOMATACI}\services\compilers\node.ps1" + + + + +# execute +$null = I18N-Activate-Environment +$___process = NODE-Activate-Local-Environment +if ($___process -ne 0) { + $null = I18N-Activate-Failed + return 1 +} + + +$null = I18N-Guide-Start-Source "${env:PROJECT_NODE_LOCALIZED}" + + + + +# report status +return 0 diff --git a/srcNODE/.ci/stop_unix-any.sh b/srcNODE/.ci/stop_unix-any.sh new file mode 100644 index 00000000..aaffa996 --- /dev/null +++ b/srcNODE/.ci/stop_unix-any.sh @@ -0,0 +1,35 @@ +#!/bin/sh +# Copyright 2024 (Holloway) Chew, Kean Ho +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy of +# the License at: +# http://www.apache.org/licenses/LICENSE-2.0 +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations under +# the License. + + + + +# initialize +if [ "$PROJECT_PATH_ROOT" = "" ]; then + >&2 printf "[ ERROR ] - Please run from automataCI/ci.sh.ps1 instead!\n" + return 1 +fi + +. "${LIBS_AUTOMATACI}/services/i18n/translations.sh" + + + + +# execute +I18N_Guide_Stop_Deactivate + + + + +# report status +return 0 diff --git a/srcNODE/.ci/stop_windows-any.ps1 b/srcNODE/.ci/stop_windows-any.ps1 new file mode 100644 index 00000000..59f68889 --- /dev/null +++ b/srcNODE/.ci/stop_windows-any.ps1 @@ -0,0 +1,34 @@ +# Copyright 2024 (Holloway) Chew, Kean Ho +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy +# of the License at: +# http://www.apache.org/licenses/LICENSE-2.0 +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. + + + + +# initialize +if (-not (Test-Path -Path $env:PROJECT_PATH_ROOT)) { + Write-Error "[ ERROR ] - Please run from automataCI\ci.sh.ps1 instead!`n" + exit 1 +} + +. "${env:LIBS_AUTOMATACI}\services\i18n\translations.ps1" + + + + +# execute +$null = I18N-Guide-Stop-Deactivate + + + + +# report status +return 0 diff --git a/srcNODE/.ci/test_unix-any.sh b/srcNODE/.ci/test_unix-any.sh new file mode 100644 index 00000000..15e6d8d3 --- /dev/null +++ b/srcNODE/.ci/test_unix-any.sh @@ -0,0 +1,76 @@ +#!/bin/sh +# Copyright 2024 (Holloway) Chew, Kean Ho +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy of +# the License at: +# http://www.apache.org/licenses/LICENSE-2.0 +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations under +# the License. + + + + +# initialize +if [ "$PROJECT_PATH_ROOT" = "" ]; then + >&2 printf "[ ERROR ] - Please run from automataCI/ci.sh.ps1 instead!\n" + return 1 +fi + +. "${LIBS_AUTOMATACI}/services/io/os.sh" +. "${LIBS_AUTOMATACI}/services/io/fs.sh" +. "${LIBS_AUTOMATACI}/services/i18n/translations.sh" +. "${LIBS_AUTOMATACI}/services/compilers/node.sh" + + + + +# execute +I18N_Activate_Environment +NODE_Activate_Local_Environment +if [ $? -ne 0 ]; then + I18N_Activate_Failed + return 1 +fi + + +I18N_Run_Test_Coverage +__current_path="$PWD" && cd "${PROJECT_PATH_ROOT}/${PROJECT_NODE}" +if [ $(OS_Is_Run_Simulated) -eq 0 ]; then + I18N_Simulate_Testing + return 0 +else + NODE_NPM_Run "test" + if [ $? -ne 0 ]; then + I18N_Run_Failed + return 1 + fi +fi +cd "$__current_path" && unset __current_path + + +I18N_Processing_Test_Coverage +___source="${PROJECT_PATH_ROOT}/${PROJECT_NODE}/dist/coverage" +___dest="${PROJECT_PATH_ROOT}/${PROJECT_PATH_LOG}/node-test-report" +FS_Is_Directory "$___source" +if [ $? -ne 0 ]; then + I18N_Processing_Failed + return 1 +fi + +FS_Remove_Silently "$___dest" +FS_Make_Housing_Directory "$___dest" +FS_Move "$___source" "$___dest" +if [ $? -ne 0 ]; then + I18N_Processing_Failed + return 1 +fi + + + + +# return status +return 0 diff --git a/srcNODE/.ci/test_windows-any.ps1 b/srcNODE/.ci/test_windows-any.ps1 new file mode 100644 index 00000000..5c152822 --- /dev/null +++ b/srcNODE/.ci/test_windows-any.ps1 @@ -0,0 +1,77 @@ +# Copyright 2024 (Holloway) Chew, Kean Ho +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy +# of the License at: +# http://www.apache.org/licenses/LICENSE-2.0 +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. + + + + +# initialize +if (-not (Test-Path -Path $env:PROJECT_PATH_ROOT)) { + Write-Error "[ ERROR ] - Please run from automataCI\ci.sh.ps1 instead!`n" + return 1 +} + +. "${env:LIBS_AUTOMATACI}\services\io\os.ps1" +. "${env:LIBS_AUTOMATACI}\services\io\fs.ps1" +. "${env:LIBS_AUTOMATACI}\services\i18n\translations.ps1" +. "${env:LIBS_AUTOMATACI}\services\compilers\node.ps1" + + + + +# execute +$null = I18N-Activate-Environment +$___process = NODE-Activate-Local-Environment +if ($___process -ne 0) { + $null = I18N-Activate-Failed + return 1 +} + + +$null = I18N-Run-Test-Coverage +$__current_path = Get-Location +$null = Set-Location "${env:PROJECT_PATH_ROOT}\${env:PROJECT_NODE}" +if ($(OS-Is-Run-Simulated) -eq 0) { + $null = I18N-Simulate-Testing + return 0 +} else { + $___process = NODE-NPM-Run "test" + if ($___process -ne 0) { + $null = I18N-Run-Failed + return 1 + } +} +$null = Set-Location "${__current_path}" +$null = Remove-Variable __current_path + + +$null = I18N-Processing-Test-Coverage +$___source = "${env:PROJECT_PATH_ROOT}\${env:PROJECT_ANGULAR}\dist\coverage" +$___dest = "${env:PROJECT_PATH_ROOT}\${env:PROJECT_PATH_LOG}\node-test-report" +$___process = FS-Is-Directory "${___source}" +if ($___process -ne 0) { + $null = I18N-Processing-Failed + return 1 +} + +$null = FS-Remove-Silently "${___dest}" +$null = FS-Make-Housing-Directory "${___dest}" +$___process = FS-Move "${___source}" "${___dest}" +if ($___process -ne 0) { + $null = I18N-Processing-Failed + return 1 +} + + + + +# report status +return 0 diff --git a/srcNODE/package-lock.json b/srcNODE/package-lock.json index 292f974a..26fd7228 100644 --- a/srcNODE/package-lock.json +++ b/srcNODE/package-lock.json @@ -1,11 +1,11 @@ { - "name": "hestiai18n", + "name": "myPackage", "version": "0.0.1", "lockfileVersion": 3, "requires": true, "packages": { "": { - "name": "hestiai18n", + "name": "myPackage", "version": "0.0.1", "license": "Apache-2.0", "devDependencies": { diff --git a/srcNODE/package.json b/srcNODE/package.json index bf334a07..99b86a57 100644 --- a/srcNODE/package.json +++ b/srcNODE/package.json @@ -1,5 +1,5 @@ { - "name": "hestiai18n", + "name": "myPackage", "version": "0.0.1", "type": "module", "description": "One Peaceful Frontend+Backend Software Library Suite: internationalization (i18n).", @@ -9,7 +9,7 @@ }, "repository": { "type": "git", - "url": "git+https://github.com/ChewKeanHo/LIBS_hestiaI18N.git" + "url": "git+https://github.com/ChewKeanHo/AutomataCI.git" }, "keywords": [ "i18n", @@ -18,9 +18,9 @@ "author": " (Holloway)", "license": "Apache-2.0", "bugs": { - "url": "https://github.com/ChewKeanHo/LIBS_hestiaI18N/issues" + "url": "https://github.com/ChewKeanHo/AutomataCI/issues" }, - "homepage": "https://github.com/ChewKeanHo/LIBS_hestiaI18N", + "homepage": "https://github.com/ChewKeanHo/AutomataCI/", "devDependencies": { "@types/jasmine": "^5.1.4", "@types/node": "^20.12.7", diff --git a/srcNODE/src/entities.ts b/srcNODE/src/entities.ts new file mode 100644 index 00000000..7de10c12 --- /dev/null +++ b/srcNODE/src/entities.ts @@ -0,0 +1,6 @@ +// [ COPYRIGHT CLASE HERE] + + + + +export var NAME = 'Jane'; diff --git a/srcNODE/src/greeters.ts b/srcNODE/src/greeters.ts new file mode 100644 index 00000000..4f9a0ca1 --- /dev/null +++ b/srcNODE/src/greeters.ts @@ -0,0 +1,16 @@ +// [ COPYRIGHT CLASE HERE] + + + + +export function Process(name: string, location: string): string { + if (name == "" && location == "") { + return "" + } else if (name == "") { + return "stranger from " + location + "!" + } else if (location == "") { + return name + "!" + } else { + return name + " from " + location + "!" + } +} diff --git a/srcNODE/src/index.spec.ts b/srcNODE/src/index.spec.ts index 9a3817c6..ce461108 100644 --- a/srcNODE/src/index.spec.ts +++ b/srcNODE/src/index.spec.ts @@ -1,7 +1,11 @@ -import { hello } from "./index.js"; +// [ COPYRIGHT CLASE HERE] +import * as Package from "./index.js"; -describe('hello', () => { + + + +describe('Main', () => { it('should perform a proper printout', () => { - expect(hello("World")).toBe("Hello World"); + expect(Package.Main()).toBe("Jane from Sample!"); }); }); diff --git a/srcNODE/src/index.ts b/srcNODE/src/index.ts index 1d6f1207..9201b345 100644 --- a/srcNODE/src/index.ts +++ b/srcNODE/src/index.ts @@ -1,3 +1,11 @@ -export function hello(name: string): string { - return `Hello ${name}`; +// [ COPYRIGHT CLASE HERE] +import * as Entities from "./entities.js"; +import * as Locations from "./locations.js"; +import * as Greeters from "./greeters.js"; + + + + +export function Main() { + return Greeters.Process(Entities.NAME, Locations.NAME); } diff --git a/srcNODE/src/locations.ts b/srcNODE/src/locations.ts new file mode 100644 index 00000000..381f6d14 --- /dev/null +++ b/srcNODE/src/locations.ts @@ -0,0 +1,3 @@ +// [ COPYRIGHT CLASE HERE] + +export const NAME = "Sample";