Skip to main content

@ncfour-us/projen-utils

Project description

projen-utils

This project contains a couple of constructs which are meant to be used with the projen project. These utilities extend existing projen constructs to enable easier development of TypeScript ESM projects/packages as well as handling pre-commit configuration in projen-managed projects.

Badges

GitHub top language GitHub License GitHub Release GitHub commit activity GitHub Issues or Pull Requests GitHub Issues or Pull Requests

GitHub Actions Workflow Status GitHub Actions Workflow Status

NPM Version NPM Last Update NPM Downloads

Table of Contents

Installation

Install using npm, yarn, or pnpm (preferred).

pnpm add --save-dev @ncfour-us/projen-utils

Getting Started

The TypeScriptESMProject supports both "local" and "Github workflow" styles of build/release handling. (NOTE: "Github workflow" handling is still under development).

Local build and release processing

With "local" style builds/releases, a project is managed from a user's workstation terminal interface, using the pnpm build and pnpm release commands.

Support exists for publishing build artifacts to:

  • "local" archive (a folder on the local workstation)
  • "npm" package registry (the NPM Package registry)
  • "github" creating tagged releases in the associated Github-hosted Git repository

There are some preparatory steps required before publishing to NPM and Github will work.

For publishing to NPM, the package MUST have first been created in NPM by a manual publishing step.

The command to publish to NPM is:

npm publish <file name .tgz file containing the package> --access public

This command will create the package in the NPM registry.

The command to create a Github repository, using the gh GitHub CLI is:

gh repo create ncfour-us/byte-buffer --public --source=. --remote=origin

This command will use the contents of the current folder to create a Git repository on Github and link the remote repository with name origin.

After creating the repository, use git push to link the main branch of the local repository to the main branch in GitHub using command:

git push -u origin main

Once these steps are completed, the publish tasks for NPM and GitHub can be enabled by setting:

    releaseToNpm: true
    releaseToGithub: true

in the constructor options of the TypeScriptESMProject project.

When running pnpm release locally, there is a requirement that the user has active login credentials to both NPM and GitHub. For NPM, 2FA login is required when running a npm publish. If interactive user credentials are being used, the user will be prompted to supply their 2FA login info during the publish:npm task processing.

To login to GitHub, use the gh auth login command. Login status can be checked using the gh auth status command. GitHub login credentials are used during the publish:github task processing.

Contributing

Fork this repository and submit a PR.

Authors

License

The project is covered by the MIT license, see LICENSE.

Acknowledgements

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ncfour_us_projen_utils-0.1.14.tar.gz (128.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ncfour_us_projen_utils-0.1.14-py3-none-any.whl (126.0 kB view details)

Uploaded Python 3

File details

Details for the file ncfour_us_projen_utils-0.1.14.tar.gz.

File metadata

  • Download URL: ncfour_us_projen_utils-0.1.14.tar.gz
  • Upload date:
  • Size: 128.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.14.5

File hashes

Hashes for ncfour_us_projen_utils-0.1.14.tar.gz
Algorithm Hash digest
SHA256 f59b44436e5a609a1c6d9fcc5c01bef047c42a8f688e8208643187beade01ee8
MD5 f698e1ea52499f002fc8a1b0ffba57fa
BLAKE2b-256 47647a1cc6aef6f2a252edd8ff8f0fe6c26819a6a6feead1ced340fe0a96aba3

See more details on using hashes here.

Provenance

The following attestation bundles were made for ncfour_us_projen_utils-0.1.14.tar.gz:

Publisher: release.yml on ncfour-us/projen-utils

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ncfour_us_projen_utils-0.1.14-py3-none-any.whl.

File metadata

File hashes

Hashes for ncfour_us_projen_utils-0.1.14-py3-none-any.whl
Algorithm Hash digest
SHA256 8638cee063cc7a34dd364d04cf1517a139637ca5a7d97fb414bb59a7c935711e
MD5 36a9c916ff2e6760056c2c477ca5e6a5
BLAKE2b-256 17e8e0f75e4ff1c0b6584be1cd3e9c5f48522839113d02c7ea43565a47e83846

See more details on using hashes here.

Provenance

The following attestation bundles were made for ncfour_us_projen_utils-0.1.14-py3-none-any.whl:

Publisher: release.yml on ncfour-us/projen-utils

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page