mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2024-11-28 23:40:22 +00:00
update docs
This commit is contained in:
parent
79e7636507
commit
014ca77051
11 changed files with 4 additions and 402 deletions
11
.github/actions/docker/action.yml
vendored
11
.github/actions/docker/action.yml
vendored
|
@ -1,11 +0,0 @@
|
||||||
name: 'Run in docker'
|
|
||||||
inputs:
|
|
||||||
run: # id of input
|
|
||||||
description: 'A command to run'
|
|
||||||
required: true
|
|
||||||
default: ''
|
|
||||||
runs:
|
|
||||||
using: 'docker'
|
|
||||||
image: '../../../docker/Dockerfile'
|
|
||||||
args:
|
|
||||||
- ${{ inputs.run }}
|
|
BIN
.github/assets/Born2bSportyV2.ttf
vendored
BIN
.github/assets/Born2bSportyV2.ttf
vendored
Binary file not shown.
BIN
.github/assets/latest-firmware-template.png
vendored
BIN
.github/assets/latest-firmware-template.png
vendored
Binary file not shown.
Before Width: | Height: | Size: 19 KiB |
214
.github/workflows/build.yml
vendored
214
.github/workflows/build.yml
vendored
|
@ -1,214 +0,0 @@
|
||||||
name: 'Build'
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
- "release*"
|
|
||||||
tags:
|
|
||||||
- '*'
|
|
||||||
pull_request:
|
|
||||||
|
|
||||||
env:
|
|
||||||
TARGETS: f7
|
|
||||||
DEFAULT_TARGET: f7
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
main:
|
|
||||||
runs-on: [self-hosted,FlipperZero]
|
|
||||||
steps:
|
|
||||||
- name: 'Cleanup workspace'
|
|
||||||
uses: AutoModality/action-clean@v1
|
|
||||||
|
|
||||||
- name: 'Decontaminate previous build leftovers'
|
|
||||||
run: |
|
|
||||||
if [ -d .git ]
|
|
||||||
then
|
|
||||||
git submodule status \
|
|
||||||
|| git checkout `git rev-list --max-parents=0 HEAD | tail -n 1`
|
|
||||||
fi
|
|
||||||
|
|
||||||
- name: 'Checkout code'
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
with:
|
|
||||||
fetch-depth: 0
|
|
||||||
submodules: true
|
|
||||||
ref: ${{ github.event.pull_request.head.sha }}
|
|
||||||
|
|
||||||
- name: 'Build docker image'
|
|
||||||
uses: ./.github/actions/docker
|
|
||||||
|
|
||||||
- name: 'Make artifacts directory'
|
|
||||||
run: |
|
|
||||||
test -d artifacts && rm -rf artifacts || true
|
|
||||||
mkdir artifacts
|
|
||||||
|
|
||||||
- name: 'Generate suffix and folder name'
|
|
||||||
id: names
|
|
||||||
run: |
|
|
||||||
REF=${{ github.ref }}
|
|
||||||
if [[ ${{ github.event_name }} == 'pull_request' ]]; then
|
|
||||||
REF=${{ github.head_ref }}
|
|
||||||
fi
|
|
||||||
BRANCH_OR_TAG=${REF#refs/*/}
|
|
||||||
SHA=$(git rev-parse --short HEAD)
|
|
||||||
|
|
||||||
if [[ "${{ github.ref }}" == "refs/tags/"* ]]; then
|
|
||||||
SUFFIX=${BRANCH_OR_TAG//\//_}
|
|
||||||
else
|
|
||||||
SUFFIX=${BRANCH_OR_TAG//\//_}-$(date +'%d%m%Y')-${SHA}
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "WORKFLOW_BRANCH_OR_TAG=${BRANCH_OR_TAG}" >> $GITHUB_ENV
|
|
||||||
echo "DIST_SUFFIX=${SUFFIX}" >> $GITHUB_ENV
|
|
||||||
echo "::set-output name=artifacts-path::${BRANCH_OR_TAG}"
|
|
||||||
echo "::set-output name=suffix::${SUFFIX}"
|
|
||||||
echo "::set-output name=short-hash::${SHA}"
|
|
||||||
echo "::set-output name=default-target::${DEFAULT_TARGET}"
|
|
||||||
|
|
||||||
- name: 'Bundle scripts'
|
|
||||||
if: ${{ !github.event.pull_request.head.repo.fork }}
|
|
||||||
run: |
|
|
||||||
tar czpf artifacts/flipper-z-any-scripts-${{steps.names.outputs.suffix}}.tgz scripts
|
|
||||||
|
|
||||||
- name: 'Build the firmware in docker'
|
|
||||||
uses: ./.github/actions/docker
|
|
||||||
with:
|
|
||||||
run: |
|
|
||||||
set -e
|
|
||||||
for TARGET in ${TARGETS}
|
|
||||||
do
|
|
||||||
./fbt TARGET_HW=`echo ${TARGET} | sed 's/f//'` --with-updater updater_package ${{ startsWith(github.ref, 'refs/tags') && 'DEBUG=0 COMPACT=1' || '' }}
|
|
||||||
done
|
|
||||||
|
|
||||||
- name: 'Move upload files'
|
|
||||||
if: ${{ !github.event.pull_request.head.repo.fork }}
|
|
||||||
uses: ./.github/actions/docker
|
|
||||||
with:
|
|
||||||
run: |
|
|
||||||
set -e
|
|
||||||
for TARGET in ${TARGETS}
|
|
||||||
do
|
|
||||||
mv dist/${TARGET}-*/* artifacts/
|
|
||||||
done
|
|
||||||
|
|
||||||
- name: 'Bundle self-update package'
|
|
||||||
if: ${{ !github.event.pull_request.head.repo.fork }}
|
|
||||||
uses: ./.github/actions/docker
|
|
||||||
with:
|
|
||||||
run: |
|
|
||||||
set -e
|
|
||||||
for UPDATEBUNDLE in artifacts/*/
|
|
||||||
do
|
|
||||||
BUNDLE_NAME=`echo $UPDATEBUNDLE | cut -d'/' -f2`
|
|
||||||
echo Packaging ${BUNDLE_NAME}
|
|
||||||
tar czpf artifacts/flipper-z-${BUNDLE_NAME}.tgz -C artifacts ${BUNDLE_NAME}
|
|
||||||
rm -rf artifacts/${BUNDLE_NAME}
|
|
||||||
done
|
|
||||||
|
|
||||||
- name: 'Bundle resources'
|
|
||||||
if: ${{ !github.event.pull_request.head.repo.fork }}
|
|
||||||
run: |
|
|
||||||
tar czpf artifacts/flipper-z-any-resources-${{steps.names.outputs.suffix}}.tgz -C assets resources
|
|
||||||
|
|
||||||
- name: 'Bundle core2 firmware'
|
|
||||||
if: ${{ !github.event.pull_request.head.repo.fork }}
|
|
||||||
uses: ./.github/actions/docker
|
|
||||||
with:
|
|
||||||
run: |
|
|
||||||
./fbt copro_dist
|
|
||||||
tar czpf artifacts/flipper-z-any-core2_firmware-${{steps.names.outputs.suffix}}.tgz -C assets core2_firmware
|
|
||||||
|
|
||||||
- name: 'Upload artifacts to update server'
|
|
||||||
if: ${{ !github.event.pull_request.head.repo.fork }}
|
|
||||||
uses: burnett01/rsync-deployments@5.1
|
|
||||||
with:
|
|
||||||
switches: -avzP --delete --mkpath
|
|
||||||
path: artifacts/
|
|
||||||
remote_path: "${{ secrets.RSYNC_DEPLOY_BASE_PATH }}${{steps.names.outputs.artifacts-path}}/"
|
|
||||||
remote_host: ${{ secrets.RSYNC_DEPLOY_HOST }}
|
|
||||||
remote_port: ${{ secrets.RSYNC_DEPLOY_PORT }}
|
|
||||||
remote_user: ${{ secrets.RSYNC_DEPLOY_USER }}
|
|
||||||
remote_key: ${{ secrets.RSYNC_DEPLOY_KEY }}
|
|
||||||
|
|
||||||
- name: 'Trigger update server reindex'
|
|
||||||
if: ${{ !github.event.pull_request.head.repo.fork }}
|
|
||||||
uses: wei/curl@master
|
|
||||||
with:
|
|
||||||
args: -X POST -F 'key=${{ secrets.REINDEX_KEY }}' ${{ secrets.REINDEX_URL }}
|
|
||||||
|
|
||||||
- name: 'Find Previous Comment'
|
|
||||||
if: ${{ !github.event.pull_request.head.repo.fork && github.event.pull_request }}
|
|
||||||
uses: peter-evans/find-comment@v1
|
|
||||||
id: fc
|
|
||||||
with:
|
|
||||||
issue-number: ${{ github.event.pull_request.number }}
|
|
||||||
comment-author: 'github-actions[bot]'
|
|
||||||
body-includes: 'Compiled firmware for commit'
|
|
||||||
|
|
||||||
- name: 'Create or update comment'
|
|
||||||
if: ${{ !github.event.pull_request.head.repo.fork && github.event.pull_request}}
|
|
||||||
uses: peter-evans/create-or-update-comment@v1
|
|
||||||
with:
|
|
||||||
comment-id: ${{ steps.fc.outputs.comment-id }}
|
|
||||||
issue-number: ${{ github.event.pull_request.number }}
|
|
||||||
body: |
|
|
||||||
**Compiled firmware for commit `${{steps.names.outputs.short-hash}}`:**
|
|
||||||
- [📦 Update package](https://update.flipperzero.one/builds/firmware/${{steps.names.outputs.artifacts-path}}/flipper-z-${{steps.names.outputs.default-target}}-update-${{steps.names.outputs.suffix}}.tgz)
|
|
||||||
- [📥 DFU file](https://update.flipperzero.one/builds/firmware/${{steps.names.outputs.artifacts-path}}/flipper-z-${{steps.names.outputs.default-target}}-full-${{steps.names.outputs.suffix}}.dfu)
|
|
||||||
- [☁️ Web updater](https://my.flipp.dev/?url=https://update.flipperzero.one/builds/firmware/${{steps.names.outputs.artifacts-path}}/flipper-z-${{steps.names.outputs.default-target}}-update-${{steps.names.outputs.suffix}}.tgz&channel=${{steps.names.outputs.artifacts-path}}&version=${{steps.names.outputs.short-hash}})
|
|
||||||
edit-mode: replace
|
|
||||||
|
|
||||||
compact:
|
|
||||||
if: ${{ !startsWith(github.ref, 'refs/tags') }}
|
|
||||||
runs-on: [self-hosted,FlipperZero]
|
|
||||||
steps:
|
|
||||||
- name: 'Cleanup workspace'
|
|
||||||
uses: AutoModality/action-clean@v1
|
|
||||||
|
|
||||||
- name: 'Decontaminate previous build leftovers'
|
|
||||||
run: |
|
|
||||||
if [ -d .git ]
|
|
||||||
then
|
|
||||||
git submodule status \
|
|
||||||
|| git checkout `git rev-list --max-parents=0 HEAD | tail -n 1`
|
|
||||||
fi
|
|
||||||
|
|
||||||
- name: 'Checkout code'
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
with:
|
|
||||||
fetch-depth: 0
|
|
||||||
submodules: true
|
|
||||||
ref: ${{ github.event.pull_request.head.sha }}
|
|
||||||
|
|
||||||
- name: 'Build docker image'
|
|
||||||
uses: ./.github/actions/docker
|
|
||||||
|
|
||||||
- name: 'Generate suffix and folder name'
|
|
||||||
id: names
|
|
||||||
run: |
|
|
||||||
REF=${{ github.ref }}
|
|
||||||
if [[ ${{ github.event_name }} == 'pull_request' ]]; then
|
|
||||||
REF=${{ github.head_ref }}
|
|
||||||
fi
|
|
||||||
BRANCH_OR_TAG=${REF#refs/*/}
|
|
||||||
SHA=$(git rev-parse --short HEAD)
|
|
||||||
|
|
||||||
if [[ "${{ github.ref }}" == "refs/tags/"* ]]; then
|
|
||||||
SUFFIX=${BRANCH_OR_TAG//\//_}
|
|
||||||
else
|
|
||||||
SUFFIX=${BRANCH_OR_TAG//\//_}-$(date +'%d%m%Y')-${SHA}
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "WORKFLOW_BRANCH_OR_TAG=${BRANCH_OR_TAG}" >> $GITHUB_ENV
|
|
||||||
echo "DIST_SUFFIX=${SUFFIX}" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
- name: 'Build the firmware in docker'
|
|
||||||
uses: ./.github/actions/docker
|
|
||||||
with:
|
|
||||||
run: |
|
|
||||||
set -e
|
|
||||||
for TARGET in ${TARGETS}
|
|
||||||
do
|
|
||||||
./fbt TARGET_HW=`echo ${TARGET} | sed 's/f//'` --with-updater updater_package DEBUG=0 COMPACT=1
|
|
||||||
done
|
|
46
.github/workflows/build_toolchain.yml
vendored
46
.github/workflows/build_toolchain.yml
vendored
|
@ -1,46 +0,0 @@
|
||||||
name: 'Build toolchain Docker image'
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
tags:
|
|
||||||
- '*'
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
with:
|
|
||||||
fetch-depth: 0
|
|
||||||
- name: Docker meta
|
|
||||||
id: meta
|
|
||||||
uses: docker/metadata-action@v3
|
|
||||||
with:
|
|
||||||
images: flipperdevices/flipperzero-toolchain
|
|
||||||
flavor: latest=${{ startsWith(github.ref, 'refs/tags/') && !endsWith(github.ref, 'rc')}}
|
|
||||||
tags: |
|
|
||||||
type=ref,event=branch
|
|
||||||
type=ref,event=tag
|
|
||||||
- name: Set up QEMU
|
|
||||||
uses: docker/setup-qemu-action@v1
|
|
||||||
- name: Set up Docker Buildx
|
|
||||||
uses: docker/setup-buildx-action@v1
|
|
||||||
- name: Login to DockerHub
|
|
||||||
uses: docker/login-action@v1
|
|
||||||
with:
|
|
||||||
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
||||||
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
||||||
- name: Build and push
|
|
||||||
id: docker_build
|
|
||||||
uses: docker/build-push-action@v2
|
|
||||||
with:
|
|
||||||
context: docker/
|
|
||||||
push: true
|
|
||||||
tags: ${{ steps.meta.outputs.tags }}
|
|
||||||
labels: ${{ steps.meta.outputs.labels }}
|
|
||||||
platforms: linux/amd64,linux/arm64
|
|
||||||
cache-from: type=registry,ref=flipperdevices/flipperzero-toolchain:buildcache
|
|
||||||
cache-to: type=registry,ref=flipperdevices/flipperzero-toolchain:buildcache,mode=max
|
|
17
.github/workflows/check_submodules.yml
vendored
17
.github/workflows/check_submodules.yml
vendored
|
@ -1,17 +0,0 @@
|
||||||
name: 'Check submodules'
|
|
||||||
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
protobuf:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: 'Checkout code'
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- name: 'Check submodule commit branch'
|
|
||||||
uses: jtmullen/submodule-branch-check-action@v1
|
|
||||||
with:
|
|
||||||
path: assets/protobuf
|
|
||||||
branch: dev
|
|
||||||
fetch_depth: 50
|
|
62
.github/workflows/lint_c.yml
vendored
62
.github/workflows/lint_c.yml
vendored
|
@ -1,62 +0,0 @@
|
||||||
name: 'Lint C/C++ with clang-format'
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
- "release*"
|
|
||||||
tags:
|
|
||||||
- '*'
|
|
||||||
pull_request:
|
|
||||||
|
|
||||||
env:
|
|
||||||
TARGETS: f7
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
lint_c_cpp:
|
|
||||||
runs-on: [self-hosted,FlipperZero]
|
|
||||||
steps:
|
|
||||||
- name: 'Cleanup workspace'
|
|
||||||
uses: AutoModality/action-clean@v1
|
|
||||||
|
|
||||||
- name: 'Decontaminate previous build leftovers'
|
|
||||||
run: |
|
|
||||||
if [ -d .git ]
|
|
||||||
then
|
|
||||||
git submodule status \
|
|
||||||
|| git checkout `git rev-list --max-parents=0 HEAD | tail -n 1`
|
|
||||||
fi
|
|
||||||
|
|
||||||
- name: 'Checkout code'
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
with:
|
|
||||||
fetch-depth: 0
|
|
||||||
submodules: true
|
|
||||||
|
|
||||||
- name: 'Docker cache'
|
|
||||||
uses: satackey/action-docker-layer-caching@v0.0.11
|
|
||||||
continue-on-error: true
|
|
||||||
with:
|
|
||||||
key: docker-cache-${{ hashFiles('docker/**') }}-{hash}
|
|
||||||
restore-keys: docker-cache-${{ hashFiles('docker/**') }}-
|
|
||||||
|
|
||||||
- name: 'Build docker image'
|
|
||||||
uses: ./.github/actions/docker
|
|
||||||
|
|
||||||
- name: 'Check code formatting'
|
|
||||||
id: syntax_check
|
|
||||||
uses: ./.github/actions/docker
|
|
||||||
with:
|
|
||||||
run: SET_GH_OUTPUT=1 ./fbt lint
|
|
||||||
|
|
||||||
- name: Report code formatting errors
|
|
||||||
if: failure() && steps.syntax_check.outputs.errors && github.event.pull_request
|
|
||||||
uses: peter-evans/create-or-update-comment@v1
|
|
||||||
with:
|
|
||||||
issue-number: ${{ github.event.pull_request.number }}
|
|
||||||
body: |
|
|
||||||
Please fix following code formatting errors:
|
|
||||||
```
|
|
||||||
${{ steps.syntax_check.outputs.errors }}
|
|
||||||
```
|
|
||||||
You might want to run `docker compose exec dev make format` for an auto-fix.
|
|
36
.github/workflows/lint_python.yml
vendored
36
.github/workflows/lint_python.yml
vendored
|
@ -1,36 +0,0 @@
|
||||||
name: 'Python Lint'
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
- "release*"
|
|
||||||
tags:
|
|
||||||
- '*'
|
|
||||||
pull_request:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
lint_python:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: 'Cleanup workspace'
|
|
||||||
uses: AutoModality/action-clean@v1
|
|
||||||
|
|
||||||
- name: 'Decontaminate previous build leftovers'
|
|
||||||
run: |
|
|
||||||
if [ -d .git ]
|
|
||||||
then
|
|
||||||
git submodule status \
|
|
||||||
|| git checkout `git rev-list --max-parents=0 HEAD | tail -n 1`
|
|
||||||
fi
|
|
||||||
|
|
||||||
- name: 'Checkout code'
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
with:
|
|
||||||
fetch-depth: 0
|
|
||||||
|
|
||||||
- name: 'Setup python'
|
|
||||||
uses: actions/setup-python@v2
|
|
||||||
|
|
||||||
- name: 'Check python code with black'
|
|
||||||
uses: psf/black@20.8b1
|
|
15
.github/workflows/reindex.yml
vendored
15
.github/workflows/reindex.yml
vendored
|
@ -1,15 +0,0 @@
|
||||||
name: 'Reindex'
|
|
||||||
|
|
||||||
on:
|
|
||||||
release:
|
|
||||||
types: [prereleased,released]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
reindex:
|
|
||||||
name: 'Reindex updates'
|
|
||||||
runs-on: [self-hosted,FlipperZero]
|
|
||||||
steps:
|
|
||||||
- name: Trigger reindex
|
|
||||||
uses: wei/curl@master
|
|
||||||
with:
|
|
||||||
args: -X POST -F 'key=${{ secrets.REINDEX_KEY }}' ${{ secrets.REINDEX_URL }}
|
|
|
@ -11,6 +11,9 @@ An [NRF24](https://www.sparkfun.com/datasheets/Components/SMD/nRF24L01Pluss_Prel
|
||||||
- Select Address and open badusb file
|
- Select Address and open badusb file
|
||||||
- Done
|
- Done
|
||||||
|
|
||||||
|
# Demo (YouTube)
|
||||||
|
[![YouTube](https://img.youtube.com/vi/C5hbyAjuU4k/0.jpg)](https://www.youtube.com/watch?v=C5hbyAjuU4k)
|
||||||
|
|
||||||
## Warning
|
## Warning
|
||||||
These apps are for **educational purposes** only. Please use this code responsibly and only use these apps on your own equipment.
|
These apps are for **educational purposes** only. Please use this code responsibly and only use these apps on your own equipment.
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
|
|
||||||
Flipper zero exploiting vulnerability to open any Sentry Safe and Master Lock electronic safe without any pin code.
|
Flipper zero exploiting vulnerability to open any Sentry Safe and Master Lock electronic safe without any pin code.
|
||||||
|
|
||||||
[Vulnerability described here](https://github.com/H4ckd4ddy/bypass-sentry-safe)
|
[Demo and Vulnerability described here](https://github.com/H4ckd4ddy/bypass-sentry-safe)
|
||||||
|
|
||||||
### Usage
|
### Usage
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue