Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/heroku/cnb-shim
This is a shim to run old buildpacks as Cloud Native Buildpacks
https://github.com/heroku/cnb-shim
heroku-languages
Last synced: 3 months ago
JSON representation
This is a shim to run old buildpacks as Cloud Native Buildpacks
- Host: GitHub
- URL: https://github.com/heroku/cnb-shim
- Owner: heroku
- License: mit
- Created: 2019-03-05T21:03:14.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2024-06-03T07:10:37.000Z (5 months ago)
- Last Synced: 2024-06-19T02:02:06.461Z (5 months ago)
- Topics: heroku-languages
- Language: Go
- Homepage:
- Size: 166 KB
- Stars: 18
- Watchers: 73
- Forks: 12
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
- awesome-cnb - heroku's CNB shim
README
# Cloud Native Buildpack Shim
[![CI](https://github.com/heroku/cnb-shim/actions/workflows/ci.yml/badge.svg)](https://github.com/heroku/cnb-shim/actions/workflows/ci.yml)
> [!WARNING]
> This project is not actively maintained and does not support modern Buildpack API and lifecycle versions.
>
> Please switch to native CNB implementations rather than using this shim.
>
> See [Heroku's natively supported CNB languages](https://github.com/heroku/buildpacks#supported-languages) or [search for community buildpacks](https://registry.buildpacks.io/).This is a Cloud Native Buildpack that acts as a shim for classic [Heroku Buildpacks](https://devcenter.heroku.com/articles/buildpacks).
## Usage
This shim can be used with any buildpack in the [Heroku Buildpack Registry](https://devcenter.heroku.com/articles/buildpack-registry) by specifying a URL in the form:
```
https://cnb-shim.herokuapp.com/v1//
```### Example: Elixir
```
$ pack build elixir-app --buildpack https://cnb-shim.herokuapp.com/v1/hashnuke/elixir --builder heroku/buildpacks:18
```For a complete list of available buildpacks run the following command from the [Heroku CLI](https://devcenter.heroku.com/articles/heroku-cli):
```
$ heroku buildpacks:search
```## Applying the Shim Manually
To use the shim manually, install the target buildpack:
```sh-session
$ sbin/install "path/to/buildpack.toml" "https://example.com/buildpack.tgz"
```Then run this buildpack.
### Example: Elixir
To use this shim with the [hashnuke/elixir](https://github.com/HashNuke/heroku-buildpack-elixir) buildpack, install [`pack` CLI](https://github.com/buildpack/pack) and run:
```
$ cd elixir-cnb$ curl -L https://github.com/heroku/cnb-shim/releases/download/v0.1/cnb-shim-v0.1.tgz | tar xz
$ cat > buildpack.toml << TOML
api = "0.2"[buildpack]
id = "hashnuke.elixir"
version = "0.1"
name = "Elixir"[[stacks]]
id = "heroku-22"
TOML$ sbin/install buildpack.toml https://buildpack-registry.s3.amazonaws.com/buildpacks/hashnuke/elixir.tgz
$ cd ~/my-elixir-app/
$ pack build elixir-app --builder heroku/buildpacks --buildpack ~/path/to/elixir-cnb
```## License
MIT