Skip to content

Commit

Permalink
Add simple build system.
Browse files Browse the repository at this point in the history
  • Loading branch information
sobomax committed Jul 11, 2024
0 parents commit 8f6c599
Show file tree
Hide file tree
Showing 4 changed files with 137 additions and 0 deletions.
73 changes: 73 additions & 0 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
name: Build Docker image

# Controls when the action will run.
on:
# Triggers the workflow on all push or pull request events
push:
pull_request:

# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:

schedule:
- cron: "0 0 * * *"

# added using https://github.com/step-security/secure-repo
permissions:
contents: read

# A workflow run is made up of one or more jobs that can run sequentially or in parallel
jobs:
Docker:
name: Build&Push to DockerHub
runs-on: ubuntu-latest
env:
DOCKER_REPO: sippylabs/webrtc_phone
PLATFORMS: linux/amd64 #,linux/i386,linux/arm/v7,linux/arm64
BASE_IMAGE: sippylabs/rtpproxy:RFC5245_ICE
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
submodules: 'recursive'

- name: Set up QEMU
id: qemu
uses: docker/setup-qemu-action@v3
with:
platforms: arm64,arm

- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3

- name: Log in to Docker Hub
if: github.event_name != 'pull_request'
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}

- name: Extract metadata (tags, labels) for Docker
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.DOCKER_REPO }}
tags: |
type=schedule
type=ref,event=branch
type=ref,event=tag
type=ref,event=pr
type=raw,value=latest,enable={{is_default_branch}}
type=sha
- name: Build Docker image
uses: docker/build-push-action@v6
with:
context: .
file: ./Dockerfile
build-args: BASE_IMAGE=${{ env.BASE_IMAGE }}
push: true
tags: |
${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
platforms: ${{ env.PLATFORMS }}
18 changes: 18 additions & 0 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
ARG BASE_IMAGE
FROM --platform=$TARGETPLATFORM $BASE_IMAGE as build
LABEL maintainer="Maksym Sobolyev <[email protected]>"

USER root

# Set Environment Variables
ENV DEBIAN_FRONTEND noninteractive

WORKDIR /webrtc_phone
COPY . /webrtc_phone/

# Build & install everything
RUN /webrtc_phone/build.sh

EXPOSE 443

ENTRYPOINT [ "npm", "exec", "http-server", "-S", "-C", "/webrtc_phone/server.crt", "-K", "/webrtc_phone/server.key", "/webrtc_phone/SIP.js/demo" ]
24 changes: 24 additions & 0 deletions build.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
#!/bin/sh

set -x
set -e

apt-get -y update -qq
apt-get -y install git python-is-python3 python3-pip npm

git clone -b RFC7118 https://github.com/sippy/b2bua
git clone https://github.com/onsip/SIP.js.git

python3 -m pip install --break-system-packages -U -r b2bua/requirements.txt

cd SIP.js/demo
npm install
npm run build-demo
cd -
npm install http-server

openssl req -newkey rsa:2048 -nodes -keyout server.key -x509 -days 365 -out server.crt -config openssl.cnf

apt-get -y remove git
apt-get -y autoremove
apt-get -y clean
22 changes: 22 additions & 0 deletions openssl.cnf
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
[req]
default_bits = 2048
prompt = no
default_md = sha256
distinguished_name = dn
x509_extensions = v3_req
req_extensions = v3_req

[dn]
C = US
ST = California
L = San Francisco
O = My Company
OU = My Division
CN = localhost
emailAddress = [email protected]

[v3_req]
subjectAltName = @alt_names

[alt_names]
DNS.1 = localhost

0 comments on commit 8f6c599

Please sign in to comment.