Skip to content

Commit

Permalink
Merge branch 'main' of github.com:sparrell/SbomPoc-sFractal into main
Browse files Browse the repository at this point in the history
  • Loading branch information
TraceyOnim committed Dec 15, 2020
2 parents 0769fbd + 54c4825 commit 162aefc
Show file tree
Hide file tree
Showing 9 changed files with 283 additions and 294 deletions.
4 changes: 2 additions & 2 deletions .github/dependabot.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,10 @@ updates:
directory: "/assets"
target-branch: "develop"
schedule:
interval: "daily"
interval: "monthly"

- package-ecosystem: "mix"
directory: "/"
target-branch: "develop"
schedule:
interval: "daily"
interval: "monthly"
63 changes: 63 additions & 0 deletions .github/workflows/releases.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
on:
push:
tags:
- 'v*'

name: Upload Release Asset

jobs:
build:
name: Upload Release Asset
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Set up Elixir
uses: actions/setup-elixir@v1
with:
elixir-version: '1.11.2' # Define the elixir version [required]
otp-version: '22.3' # Define the OTP version [required]
- name: Restore dependencies cache
uses: actions/cache@v2
with:
path: deps
key: ${{ runner.os }}-mix-${{ hashFiles('**/mix.lock') }}
restore-keys: ${{ runner.os }}-mix-
- name: Setup Node
uses: actions/setup-node@v1
with:
node-version: 14.13.0
- name: Checkout code
uses: actions/checkout@v2
- name: Build project
run: |
curl -L -o cyclonedx-cli https://github.com/CycloneDX/cyclonedx-cli/releases/download/v0.7.0/cyclonedx-linux-x64
chmod a+x cyclonedx-cli
make sbom
- name: Create Release
id: create_release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: ${{ github.ref }}
release_name: Release ${{ github.ref }}
draft: false
prerelease: false
- name: Upload SBOM Json
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ./bom.json
asset_name: bom.json
asset_content_type: application/octet-stream
- name: Upload SBOM XML
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ./bom.xml
asset_name: bom.xml
asset_content_type: application/octet-stream
5 changes: 3 additions & 2 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
# heavily borrowed from https://elixirforum.com/t/cannot-find-libtinfo-so-6-when-launching-elixir-app/24101/11?u=sigu
FROM elixir:1.11.2 AS app_builder
FROM hexpm/elixir:1.11.2-erlang-22.3-debian-buster-20200224 AS app_builder

ARG env=prod

Expand All @@ -14,6 +14,7 @@ RUN mix local.hex --force && mix local.rebar --force

COPY mix.exs .
COPY mix.lock .
RUN apt-get update && apt-get install curl make gcc -y
RUN mix deps.get && mix deps.compile

# Let's make sure we have node
Expand All @@ -23,7 +24,7 @@ RUN curl -sL https://deb.nodesource.com/setup_14.x | bash - && \
# Compile assets
COPY assets ./assets
RUN npm install --prefix ./assets && \
npm run deploy --prefix ./assets
npm run deploy --prefix ./assets

# Now, let's go with the actual elixir code. The order matters: if we only
# change elixir code, all the above layers will be cached ~ less image build time.
Expand Down
11 changes: 7 additions & 4 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -67,10 +67,11 @@ test: ## Run the test suite
.PHONY: format
format: mix format ## Run formatting tools on the code

.PHONY: sbom ## create sbom file for both hex and npm dependancies
sbom:
mix sbom.cyclonedx -o elixir_bom.xml
cd assets && cyclonedx-bom -o ../bom.xml -a ../elixir_bom.xml && cd ..
.PHONY: sbom
sbom: ## creates sbom for both npm and hex dependancies
mix deps.get && mix sbom.cyclonedx -o elixir_bom.xml
cd assets/ && npm install && npm install -g @cyclonedx/bom && cyclonedx-bom -o ../bom.xml -a ../elixir_bom.xml && cd ..
./cyclonedx-cli convert --input-file bom.xml --output-file bom.json


release: ## Build a release of the application with MIX_ENV=prod
Expand Down Expand Up @@ -123,3 +124,5 @@ deploy-existing-image:
.PHONY: update-instance
update-instance:
gcloud compute instances update-container $(instance-name) --container-image gcr.io/twinklymaha/sbom:$(image-tag)


15 changes: 14 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,20 @@ sbom Create SBOM file for hex and npm deps
```
## Generating SBOM file
To generate an sbom file, use the make task `make sbom` to generate an `sbom.xml` file on the project root
To generate an sbom file, use the make task `make sbom` to generate a `bom.json` and `bom.xml` file on the project root.
**Before you begin:**
- [Download cyclonedx-cli tool](https://github.com/CycloneDX/cyclonedx-cli/releases) that supports converting
of sbom in different formats.
- Ensure that the `cyclonedx-cli tool` is executable, if not use the command to make it executable `chmod a+x cyclonedx-cli tool`
- Add the `cyclonedx-cli tool` to the root of the project and rename it to `cyclonedx-cli**
**Note: If you get an error on MacOS**
```shell
cannot be opened because the developer cannot be verified. macOS cannot verify that this app is free from malware
```
You might get an error when running this command on a mac, follow [instructions on stackoverflow](https://stackoverflow.com/a/59899342/4137155) to allow the binary to execute
## BOM analysis tool
If you want to deploy your own bom analysis tool, you can [follow this instructions](./docs/dependancy-tracker.md) to get set up
Expand Down
Loading

0 comments on commit 162aefc

Please sign in to comment.