Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sparkbox/carbon-cli
https://github.com/sparkbox/carbon-cli
cli generator template-project
Last synced: about 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/sparkbox/carbon-cli
- Owner: sparkbox
- License: mit
- Created: 2019-09-20T14:13:07.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-01-04T10:59:04.000Z (almost 2 years ago)
- Last Synced: 2024-11-08T18:53:59.228Z (about 2 months ago)
- Topics: cli, generator, template-project
- Language: TypeScript
- Size: 607 KB
- Stars: 1
- Watchers: 16
- Forks: 0
- Open Issues: 16
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# @sparkbox/carbon-cli
[![CircleCI](https://circleci.com/gh/sparkbox/carbon-cli/tree/master.svg?style=svg&circle-token=c14fa75e6d98e89c6314b2f3d609a0151cec0d8f)](https://circleci.com/gh/sparkbox/carbon-cli/tree/master)
[![Maintainability](https://api.codeclimate.com/v1/badges/abad33e5f2d9b765ad90/maintainability)](https://codeclimate.com/github/sparkbox/carbon-cli/maintainability)
[![Test Coverage](https://api.codeclimate.com/v1/badges/abad33e5f2d9b765ad90/test_coverage)](https://codeclimate.com/github/sparkbox/carbon-cli/test_coverage)
[![npm package](https://img.shields.io/npm/v/@sparkbox/carbon-cli/latest)](https://www.npmjs.com/package/@sparkbox/carbon-cli)
[![MIT license](https://img.shields.io/badge/license-MIT-brightgreen.svg)](https://opensource.org/licenses/MIT)## 🚧 Under Development
## Install
```sh
$ npm i -g @sparkbox/carbon-cli
```Alternatively, you can run it without a global install:
```sh
$ npx -p @sparkbox/carbon-cli carbon
```## Why?
Accelerated project setup. Use existing repos as templates.## Usage
### `carbon`
After installing, you should have a `carbon` command. Running with no options will walk you through a repo setup...```sh
$ carbon? GitHub username or email iamnathanj
? GitHub password ◦◦◦◦◦◦◦◦
? GitHub 2FA passcode 508412
? search repos bouncy-ball
? project name /Users/nj/code/bouncy-ball-copy
✔ initialize repo
✔ download bouncy-ball
✔ tidy up package.json
✔ customize project files
✔ create new remote on GitHub
✔ install dependencies
╭────────────────────────────────────────────────────────────────────╮
│ │
│ success! │
│ │
│ ❯ /Users/nj/code/bouncy-ball-copy │
│ │
│ --- │
│ │
│ url https://api.github.com/repos/iAmNathanJ/bouncy-ball-copy │
│ ssh [email protected]:iAmNathanJ/bouncy-ball-copy.git │
│ https https://github.com/iAmNathanJ/bouncy-ball-copy.git │
│ │
╰────────────────────────────────────────────────────────────────────╯
```This command requires authenticating with your GitHub account and selecting a repo as a starting point. The overall flow is:
- login to GitHub
- choose an existing repo to use as a template
- choose a branch to copy from (defaults to `master`)
- choose whether to create a new GitHub remote from the copy (defaults to `true`)After that
### `carbon config`
This `config` command will add a set of configuration files for common front-end tooling. The generated files are intended to follow "best practices" but are somewhat opinionated. These are meant to be used as a starting point, but many will suffice as is.
The `configs` command is non-destructive. It will not overwrite any existing config files unless run in `force` mode.
## GitHub Authentication
The default `carbon` command provides a basic auth flow for GitHub so you can access your repos. You can alternatively provide a [personal access token](https://help.github.com/en/articles/creating-a-personal-access-token-for-the-command-line) via an environment variable called `CARBON_CLI_TOKEN` to skip the login step.To set this up:
1. [create a token](https://help.github.com/en/articles/creating-a-personal-access-token-for-the-command-line#creating-a-token) with selected scopes for "repo" and "admin:org".
![scopes](./images/token-scope.png)
1. export the token value from your `.bashrc` (or similar).One way of doing this is to create a file specifically for personal or secret information.
```sh
# ~/.secrets
export CARBON_CLI_TOKEN=xxxxxxxxxxxxxxxxxxx
```Then `source` that file from your shell startup.
```sh
# .bashrc
source ~/.secrets
```## Contributing
Yes, please!See the [contributing guidelines](./CONTRIBUTING.md) for details.
## Platform Requirements
TODO