Compare commits
18 Commits
v1.3.5
...
bb166aa29f
Author | SHA1 | Date | |
---|---|---|---|
bb166aa29f | |||
0d718023f8 | |||
b16781043f | |||
dff184ff25 | |||
0ce281221d | |||
bc26c160e8 | |||
c25f41db75 | |||
e107c17f50 | |||
85b9d03ebd | |||
17b188626a | |||
a534c5f872 | |||
93f7582790 | |||
46acc63756 | |||
67a9e1bdce | |||
2b75b64b4a | |||
8d003295e7 | |||
f89500946a | |||
14e745ff06 |
129
.github/workflows/gitea-release.yml
vendored
129
.github/workflows/gitea-release.yml
vendored
@@ -2,16 +2,6 @@ name: Gitea Release
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
workflow_call:
|
workflow_call:
|
||||||
inputs:
|
|
||||||
gitea_server_url:
|
|
||||||
required: true
|
|
||||||
type: string
|
|
||||||
gitea_repository:
|
|
||||||
required: true
|
|
||||||
type: string
|
|
||||||
secrets:
|
|
||||||
GITEA_TOKEN:
|
|
||||||
required: true
|
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
create-release:
|
create-release:
|
||||||
@@ -34,39 +24,11 @@ jobs:
|
|||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install xxd
|
sudo apt-get install xxd
|
||||||
|
|
||||||
- name: Check for SPIFFS changes
|
|
||||||
id: check_spiffs
|
|
||||||
run: |
|
|
||||||
git fetch --unshallow || true
|
|
||||||
CHANGED_FILES=$(git diff --name-only HEAD^..HEAD)
|
|
||||||
if echo "$CHANGED_FILES" | grep -q "^data/\|^html/"; then
|
|
||||||
echo "SPIFFS_CHANGED=true" >> $GITHUB_OUTPUT
|
|
||||||
else
|
|
||||||
echo "SPIFFS_CHANGED=false" >> $GITHUB_OUTPUT
|
|
||||||
fi
|
|
||||||
|
|
||||||
- name: Check for Data changes
|
|
||||||
id: check_data
|
|
||||||
run: |
|
|
||||||
git fetch --unshallow || true
|
|
||||||
CHANGED_FILES=$(git diff --name-only HEAD^..HEAD)
|
|
||||||
if echo "$CHANGED_FILES" | grep -q "^data/"; then
|
|
||||||
echo "DATA_CHANGED=true" >> $GITHUB_OUTPUT
|
|
||||||
else
|
|
||||||
echo "DATA_CHANGED=false" >> $GITHUB_OUTPUT
|
|
||||||
fi
|
|
||||||
|
|
||||||
- name: Get version from platformio.ini
|
|
||||||
id: get_version
|
|
||||||
run: |
|
|
||||||
VERSION=$(grep '^version = ' platformio.ini | cut -d'"' -f2)
|
|
||||||
echo "VERSION=$VERSION" >> $GITHUB_OUTPUT
|
|
||||||
|
|
||||||
- name: Build Firmware
|
- name: Build Firmware
|
||||||
run: |
|
run: |
|
||||||
VERSION=${{ steps.get_version.outputs.VERSION }}
|
VERSION=$(grep '^version = ' platformio.ini | cut -d'"' -f2)
|
||||||
|
|
||||||
# Always build firmware and SPIFFS
|
# Build firmware and SPIFFS
|
||||||
echo "Building firmware and SPIFFS..."
|
echo "Building firmware and SPIFFS..."
|
||||||
pio run -e esp32dev
|
pio run -e esp32dev
|
||||||
pio run -t buildfs
|
pio run -t buildfs
|
||||||
@@ -74,10 +36,10 @@ jobs:
|
|||||||
# Copy firmware binary
|
# Copy firmware binary
|
||||||
cp .pio/build/esp32dev/firmware.bin .pio/build/esp32dev/filaman_${VERSION}.bin
|
cp .pio/build/esp32dev/firmware.bin .pio/build/esp32dev/filaman_${VERSION}.bin
|
||||||
|
|
||||||
# Always create SPIFFS binary
|
# Create SPIFFS binary
|
||||||
cp .pio/build/esp32dev/spiffs.bin .pio/build/esp32dev/webpage_${VERSION}.bin
|
cp .pio/build/esp32dev/spiffs.bin .pio/build/esp32dev/webpage_${VERSION}.bin
|
||||||
|
|
||||||
# Create full binary (always)
|
# Create full binary
|
||||||
(cd .pio/build/esp32dev &&
|
(cd .pio/build/esp32dev &&
|
||||||
esptool.py --chip esp32 merge_bin \
|
esptool.py --chip esp32 merge_bin \
|
||||||
--fill-flash-size 4MB \
|
--fill-flash-size 4MB \
|
||||||
@@ -94,29 +56,11 @@ jobs:
|
|||||||
echo "File sizes:"
|
echo "File sizes:"
|
||||||
(cd .pio/build/esp32dev && ls -lh *.bin)
|
(cd .pio/build/esp32dev && ls -lh *.bin)
|
||||||
|
|
||||||
- name: Prepare binaries
|
- name: Get version from platformio.ini
|
||||||
|
id: get_version
|
||||||
run: |
|
run: |
|
||||||
VERSION=${{ steps.get_version.outputs.VERSION }}
|
VERSION=$(grep '^version = ' platformio.ini | cut -d'"' -f2)
|
||||||
|
echo "VERSION=$VERSION" >> $GITHUB_OUTPUT
|
||||||
# Create full binary only if SPIFFS changed
|
|
||||||
if [[ "${{ steps.check_spiffs.outputs.SPIFFS_CHANGED }}" == "true" ]]; then
|
|
||||||
echo "Creating full binary..."
|
|
||||||
cd .pio/build/esp32dev && \
|
|
||||||
esptool.py --chip esp32 merge_bin \
|
|
||||||
--fill-flash-size 4MB \
|
|
||||||
--flash_mode dio \
|
|
||||||
--flash_freq 40m \
|
|
||||||
--flash_size 4MB \
|
|
||||||
-o filaman_full_${VERSION}.bin \
|
|
||||||
0x0000 bootloader.bin \
|
|
||||||
0x8000 partitions.bin \
|
|
||||||
0x10000 firmware.bin \
|
|
||||||
0x390000 spiffs.bin
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Verify file sizes
|
|
||||||
echo "File sizes:"
|
|
||||||
cd .pio/build/esp32dev && ls -lh *.bin
|
|
||||||
|
|
||||||
- name: Read CHANGELOG.md
|
- name: Read CHANGELOG.md
|
||||||
id: changelog
|
id: changelog
|
||||||
@@ -127,56 +71,19 @@ jobs:
|
|||||||
echo "$CHANGELOG" >> $GITHUB_OUTPUT
|
echo "$CHANGELOG" >> $GITHUB_OUTPUT
|
||||||
echo "EOF" >> $GITHUB_OUTPUT
|
echo "EOF" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
- name: Create Release
|
- name: Create Gitea Release
|
||||||
env:
|
|
||||||
TOKEN: ${{ secrets.GITEA_TOKEN }}
|
|
||||||
run: |
|
run: |
|
||||||
API_URL="${{ inputs.gitea_server_url }}/api/v1"
|
|
||||||
REPO="${{ inputs.gitea_repository }}"
|
|
||||||
VERSION=${{ steps.get_version.outputs.VERSION }}
|
VERSION=${{ steps.get_version.outputs.VERSION }}
|
||||||
|
cd .pio/build/esp32dev
|
||||||
|
|
||||||
# Create release
|
# Prepare files for upload
|
||||||
RESPONSE=$(curl -k -s \
|
FILES=""
|
||||||
-X POST \
|
for file in filaman_${VERSION}.bin webpage_${VERSION}.bin filaman_full_${VERSION}.bin; do
|
||||||
-H "Authorization: token ${TOKEN}" \
|
if [ -f "$file" ]; then
|
||||||
-H "Content-Type: application/json" \
|
FILES="$FILES -a $file"
|
||||||
-d "{
|
|
||||||
\"tag_name\":\"v${VERSION}\",
|
|
||||||
\"name\":\"Release ${VERSION}\",
|
|
||||||
\"body\":\"${{ steps.changelog.outputs.CHANGES }}\"
|
|
||||||
}" \
|
|
||||||
"${API_URL}/repos/${REPO}/releases")
|
|
||||||
|
|
||||||
RELEASE_ID=$(echo "$RESPONSE" | grep -o '"id":[0-9]*' | cut -d':' -f2 | head -n1)
|
|
||||||
|
|
||||||
if [ -n "$RELEASE_ID" ]; then
|
|
||||||
echo "Release created with ID: $RELEASE_ID"
|
|
||||||
|
|
||||||
# Always upload firmware and full binary
|
|
||||||
for file in filaman_${VERSION}.bin filaman_full_${VERSION}.bin; do
|
|
||||||
if [ -f ".pio/build/esp32dev/$file" ]; then
|
|
||||||
echo "Uploading $file..."
|
|
||||||
curl -k -s \
|
|
||||||
-X POST \
|
|
||||||
-H "Authorization: token ${TOKEN}" \
|
|
||||||
-H "Content-Type: application/octet-stream" \
|
|
||||||
--data-binary "@.pio/build/esp32dev/$file" \
|
|
||||||
"${API_URL}/repos/${REPO}/releases/${RELEASE_ID}/assets?name=$file"
|
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
# Upload SPIFFS binary only if it exists (data changes)
|
# Create release using git command
|
||||||
if [ -f ".pio/build/esp32dev/webpage_${VERSION}.bin" ]; then
|
git tag -a "v${VERSION}" -m "Release ${VERSION}"
|
||||||
echo "Uploading webpage binary..."
|
git push origin "v${VERSION}"
|
||||||
curl -k -s \
|
|
||||||
-X POST \
|
|
||||||
-H "Authorization: token ${TOKEN}" \
|
|
||||||
-H "Content-Type: application/octet-stream" \
|
|
||||||
--data-binary "@.pio/build/esp32dev/webpage_${VERSION}.bin" \
|
|
||||||
"${API_URL}/repos/${REPO}/releases/${RELEASE_ID}/assets?name=webpage_${VERSION}.bin"
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "Failed to create release. Response:"
|
|
||||||
echo "$RESPONSE"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
4
.github/workflows/github-release.yml
vendored
4
.github/workflows/github-release.yml
vendored
@@ -6,8 +6,8 @@ on:
|
|||||||
jobs:
|
jobs:
|
||||||
create-release:
|
create-release:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
permissions:
|
#permissions:
|
||||||
contents: write
|
# contents: write
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
242
.github/workflows/release.yml
vendored
242
.github/workflows/release.yml
vendored
@@ -6,253 +6,27 @@ on:
|
|||||||
- 'v*'
|
- 'v*'
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
route:
|
detect-provider:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
outputs:
|
outputs:
|
||||||
provider: ${{ steps.provider.outputs.provider }}
|
provider: ${{ steps.provider.outputs.provider }}
|
||||||
gitea_ref_name: ${{ steps.provider.outputs.gitea_ref_name }}
|
|
||||||
gitea_server_url: ${{ steps.provider.outputs.gitea_server_url }}
|
|
||||||
gitea_repository: ${{ steps.provider.outputs.gitea_repository }}
|
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout Repository
|
|
||||||
uses: actions/checkout@v3
|
|
||||||
|
|
||||||
- name: Debug Environment
|
|
||||||
run: |
|
|
||||||
echo "CI Environment Details:"
|
|
||||||
echo "GITHUB_ACTIONS=${GITHUB_ACTIONS:-not set}"
|
|
||||||
echo "GITEA_ACTIONS=${GITEA_ACTIONS:-not set}"
|
|
||||||
echo "GITEA_REPOSITORY=${GITEA_REPOSITORY:-not set}"
|
|
||||||
echo "GITEA_SERVER_URL=${GITEA_SERVER_URL:-not set}"
|
|
||||||
echo "RUNNER_NAME=${RUNNER_NAME:-not set}"
|
|
||||||
|
|
||||||
- name: Determine CI Provider
|
- name: Determine CI Provider
|
||||||
id: provider
|
id: provider
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
if [ -n "${GITEA_ACTIONS}" ] || [ -n "${GITEA_REPOSITORY}" ] || [[ "${RUNNER_NAME}" == *"gitea"* ]]; then
|
if [ -n "${GITEA_ACTIONS}" ] || [ -n "${GITEA_REPOSITORY}" ] || [[ "${RUNNER_NAME}" == *"gitea"* ]]; then
|
||||||
echo "provider=gitea" >> "$GITHUB_OUTPUT"
|
echo "provider=gitea" >> "$GITHUB_OUTPUT"
|
||||||
echo "gitea_ref_name=${GITHUB_REF_NAME}" >> "$GITHUB_OUTPUT"
|
|
||||||
echo "gitea_server_url=${GITHUB_SERVER_URL}" >> "$GITHUB_OUTPUT"
|
|
||||||
echo "gitea_repository=${GITHUB_REPOSITORY}" >> "$GITHUB_OUTPUT"
|
|
||||||
elif [ "${GITHUB_ACTIONS}" = "true" ]; then
|
|
||||||
echo "provider=github" >> "$GITHUB_OUTPUT"
|
|
||||||
else
|
else
|
||||||
echo "provider=unknown" >> "$GITHUB_OUTPUT"
|
echo "provider=github" >> "$GITHUB_OUTPUT"
|
||||||
fi
|
|
||||||
|
|
||||||
verify-provider:
|
|
||||||
needs: route
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Echo detected provider
|
|
||||||
run: |
|
|
||||||
echo "Detected CI Provider: ${{ needs.route.outputs.provider }}"
|
|
||||||
if [ "${{ needs.route.outputs.provider }}" = "unknown" ]; then
|
|
||||||
echo "::error::Failed to detect CI provider!"
|
|
||||||
exit 1
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
github-release:
|
github-release:
|
||||||
needs: [route, verify-provider]
|
needs: detect-provider
|
||||||
if: needs.route.outputs.provider == 'github'
|
if: needs.detect-provider.outputs.provider == 'github'
|
||||||
runs-on: ubuntu-latest
|
uses: ./.github/workflows/github-release.yml
|
||||||
permissions:
|
|
||||||
contents: write
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v4
|
|
||||||
- name: Set up Python
|
|
||||||
uses: actions/setup-python@v4
|
|
||||||
with:
|
|
||||||
python-version: '3.x'
|
|
||||||
- name: Install PlatformIO
|
|
||||||
run: |
|
|
||||||
python -m pip install --upgrade pip
|
|
||||||
pip install --upgrade platformio esptool
|
|
||||||
- name: Install xxd
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt-get install xxd
|
|
||||||
- name: Check for Data changes
|
|
||||||
id: check_data
|
|
||||||
run: |
|
|
||||||
git fetch --unshallow || true
|
|
||||||
CHANGED_FILES=$(git diff --name-only HEAD^..HEAD)
|
|
||||||
if echo "$CHANGED_FILES" | grep -q "^data/"; then
|
|
||||||
echo "DATA_CHANGED=true" >> $GITHUB_OUTPUT
|
|
||||||
else
|
|
||||||
echo "DATA_CHANGED=false" >> $GITHUB_OUTPUT
|
|
||||||
fi
|
|
||||||
- name: Check for SPIFFS changes
|
|
||||||
id: check_spiffs
|
|
||||||
run: |
|
|
||||||
git fetch --unshallow || true
|
|
||||||
CHANGED_FILES=$(git diff --name-only HEAD^..HEAD)
|
|
||||||
if echo "$CHANGED_FILES" | grep -q "^data/\|^html/"; then
|
|
||||||
echo "SPIFFS_CHANGED=true" >> $GITHUB_OUTPUT
|
|
||||||
else
|
|
||||||
echo "SPIFFS_CHANGED=false" >> $GITHUB_OUTPUT
|
|
||||||
fi
|
|
||||||
- name: Build Firmware
|
|
||||||
run: |
|
|
||||||
VERSION=$(grep '^version = ' platformio.ini | cut -d'"' -f2)
|
|
||||||
echo "Building firmware and SPIFFS..."
|
|
||||||
pio run -e esp32dev
|
|
||||||
pio run -t buildfs
|
|
||||||
cp .pio/build/esp32dev/firmware.bin .pio/build/esp32dev/filaman_${VERSION}.bin
|
|
||||||
cp .pio/build/esp32dev/spiffs.bin .pio/build/esp32dev/webpage_${VERSION}.bin
|
|
||||||
(cd .pio/build/esp32dev && esptool.py --chip esp32 merge_bin --fill-flash-size 4MB --flash_mode dio --flash_freq 40m --flash_size 4MB -o filaman_full_${VERSION}.bin 0x1000 bootloader.bin 0x8000 partitions.bin 0x10000 firmware.bin 0x390000 spiffs.bin)
|
|
||||||
echo "File sizes:"
|
|
||||||
(cd .pio/build/esp32dev && ls -lh *.bin)
|
|
||||||
- name: Get version from platformio.ini
|
|
||||||
id: get_version
|
|
||||||
run: |
|
|
||||||
VERSION=$(grep '^version = ' platformio.ini | cut -d'"' -f2)
|
|
||||||
echo "VERSION=$VERSION" >> $GITHUB_OUTPUT
|
|
||||||
- name: Read CHANGELOG.md
|
|
||||||
id: changelog
|
|
||||||
run: |
|
|
||||||
VERSION=${{ steps.get_version.outputs.VERSION }}
|
|
||||||
CHANGELOG=$(awk "/## \[$VERSION\]/{p=1;print;next} /## \[/{p=0} p" CHANGELOG.md)
|
|
||||||
echo "CHANGES<<EOF" >> $GITHUB_OUTPUT
|
|
||||||
echo "$CHANGELOG" >> $GITHUB_OUTPUT
|
|
||||||
echo "EOF" >> $GITHUB_OUTPUT
|
|
||||||
- name: Create GitHub Release
|
|
||||||
env:
|
|
||||||
GH_TOKEN: ${{ github.token }}
|
|
||||||
run: |
|
|
||||||
VERSION=${{ steps.get_version.outputs.VERSION }}
|
|
||||||
cd .pio/build/esp32dev
|
|
||||||
FILES_TO_UPLOAD=""
|
|
||||||
if [ -f "filaman_${VERSION}.bin" ]; then
|
|
||||||
FILES_TO_UPLOAD="$FILES_TO_UPLOAD filaman_${VERSION}.bin"
|
|
||||||
fi
|
|
||||||
if [ -f "webpage_${VERSION}.bin" ]; then
|
|
||||||
FILES_TO_UPLOAD="$FILES_TO_UPLOAD webpage_${VERSION}.bin"
|
|
||||||
fi
|
|
||||||
if [ -f "filaman_full_${VERSION}.bin" ]; then
|
|
||||||
FILES_TO_UPLOAD="$FILES_TO_UPLOAD filaman_full_${VERSION}.bin"
|
|
||||||
fi
|
|
||||||
if [ -n "$FILES_TO_UPLOAD" ]; then
|
|
||||||
if [ "${{ needs.route.outputs.provider }}" = "github" ]; then
|
|
||||||
gh release create "v${VERSION}" --title "Release ${VERSION}" --notes "${{ steps.changelog.outputs.CHANGES }}" $FILES_TO_UPLOAD
|
|
||||||
elif [ "${{ needs.route.outputs.provider }}" = "gitea" ]; then
|
|
||||||
API_URL="${{ needs.route.outputs.gitea_server_url }}/api/v1"
|
|
||||||
REPO="${{ needs.route.outputs.gitea_repository }}"
|
|
||||||
RESPONSE=$(curl -k -s -X POST -H "Authorization: token ${TOKEN}" -H "Content-Type: application/json" -d "{\"tag_name\":\"v${VERSION}\",\"name\":\"Release ${VERSION}\",\"body\":\"${{ steps.changelog.outputs.CHANGES }}\"}" "${API_URL}/repos/${REPO}/releases")
|
|
||||||
RELEASE_ID=$(echo "$RESPONSE" | grep -o '"id":[0-9]*' | cut -d':' -f2 | head -n1)
|
|
||||||
if [ -n "$RELEASE_ID" ]; then
|
|
||||||
echo "Release created with ID: $RELEASE_ID"
|
|
||||||
for file in $FILES_TO_UPLOAD; do
|
|
||||||
echo "Uploading $file..."
|
|
||||||
curl -k -s -X POST -H "Authorization: token ${TOKEN}" -H "Content-Type: application/octet-stream" --data-binary "@.pio/build/esp32dev/$file" "${API_URL}/repos/${REPO}/releases/${RELEASE_ID}/assets?name=$file"
|
|
||||||
done
|
|
||||||
else
|
|
||||||
echo "Failed to create release. Response:"
|
|
||||||
echo "$RESPONSE"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "Error: Unknown provider"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "Error: No files found to upload"
|
|
||||||
exit 1
|
|
||||||
|
|
||||||
gitea-release:
|
gitea-release:
|
||||||
needs: [route, verify-provider]
|
needs: detect-provider
|
||||||
if: needs.route.outputs.provider == 'gitea'
|
if: needs.detect-provider.outputs.provider == 'gitea'
|
||||||
runs-on: ubuntu-latest
|
uses: ./.github/workflows/gitea-release.yml
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v4
|
|
||||||
- name: Set up Python
|
|
||||||
uses: actions/setup-python@v4
|
|
||||||
with:
|
|
||||||
python-version: '3.x'
|
|
||||||
- name: Install PlatformIO
|
|
||||||
run: |
|
|
||||||
python -m pip install --upgrade pip
|
|
||||||
pip install --upgrade platformio esptool
|
|
||||||
- name: Install xxd
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt-get install xxd
|
|
||||||
- name: Check for SPIFFS changes
|
|
||||||
id: check_spiffs
|
|
||||||
run: |
|
|
||||||
git fetch --unshallow || true
|
|
||||||
CHANGED_FILES=$(git diff --name-only HEAD^..HEAD)
|
|
||||||
if echo "$CHANGED_FILES" | grep -q "^data/\|^html/"; then
|
|
||||||
echo "SPIFFS_CHANGED=true" >> $GITHUB_OUTPUT
|
|
||||||
else
|
|
||||||
echo "SPIFFS_CHANGED=false" >> $GITHUB_OUTPUT
|
|
||||||
fi
|
|
||||||
- name: Check for Data changes
|
|
||||||
id: check_data
|
|
||||||
run: |
|
|
||||||
git fetch --unshallow || true
|
|
||||||
CHANGED_FILES=$(git diff --name-only HEAD^..HEAD)
|
|
||||||
if echo "$CHANGED_FILES" | grep -q "^data/"; then
|
|
||||||
echo "DATA_CHANGED=true" >> $GITHUB_OUTPUT
|
|
||||||
else
|
|
||||||
echo "DATA_CHANGED=false" >> $GITHUB_OUTPUT
|
|
||||||
fi
|
|
||||||
- name: Get version from platformio.ini
|
|
||||||
id: get_version
|
|
||||||
run: |
|
|
||||||
VERSION=$(grep '^version = ' platformio.ini | cut -d'"' -f2)
|
|
||||||
echo "VERSION=$VERSION" >> $GITHUB_OUTPUT
|
|
||||||
- name: Build Firmware
|
|
||||||
run: |
|
|
||||||
VERSION=${{ steps.get_version.outputs.VERSION }}
|
|
||||||
echo "Building firmware and SPIFFS..."
|
|
||||||
pio run -e esp32dev
|
|
||||||
pio run -t buildfs
|
|
||||||
cp .pio/build/esp32dev/firmware.bin .pio/build/esp32dev/filaman_${VERSION}.bin
|
|
||||||
cp .pio/build/esp32dev/spiffs.bin .pio/build/esp32dev/webpage_${VERSION}.bin
|
|
||||||
(cd .pio/build/esp32dev && esptool.py --chip esp32 merge_bin --fill-flash-size 4MB --flash_mode dio --flash_freq 40m --flash_size 4MB -o filaman_full_${VERSION}.bin 0x1000 bootloader.bin 0x8000 partitions.bin 0x10000 firmware.bin 0x390000 spiffs.bin)
|
|
||||||
echo "File sizes:"
|
|
||||||
(cd .pio/build/esp32dev && ls -lh *.bin)
|
|
||||||
- name: Prepare binaries
|
|
||||||
run: |
|
|
||||||
VERSION=${{ steps.get_version.outputs.VERSION }}
|
|
||||||
if [[ "${{ steps.check_spiffs.outputs.SPIFFS_CHANGED }}" == "true" ]]; then
|
|
||||||
echo "Creating full binary..."
|
|
||||||
cd .pio/build/esp32dev && esptool.py --chip esp32 merge_bin --fill-flash-size 4MB --flash_mode dio --flash_freq 40m --flash_size 4MB -o filaman_full_${VERSION}.bin 0x0000 bootloader.bin 0x8000 partitions.bin 0x10000 firmware.bin 0x390000 spiffs.bin
|
|
||||||
fi
|
|
||||||
echo "File sizes:"
|
|
||||||
cd .pio/build/esp32dev && ls -lh *.bin
|
|
||||||
- name: Read CHANGELOG.md
|
|
||||||
id: changelog
|
|
||||||
run: |
|
|
||||||
VERSION=${{ steps.get_version.outputs.VERSION }}
|
|
||||||
CHANGELOG=$(awk "/## \[$VERSION\]/{p=1;print;next} /## \[/{p=0} p" CHANGELOG.md)
|
|
||||||
echo "CHANGES<<EOF" >> $GITHUB_OUTPUT
|
|
||||||
echo "$CHANGELOG" >> $GITHUB_OUTPUT
|
|
||||||
echo "EOF" >> $GITHUB_OUTPUT
|
|
||||||
- name: Create Release
|
|
||||||
env:
|
|
||||||
TOKEN: ${{ secrets.GITEA_TOKEN }}
|
|
||||||
run: |
|
|
||||||
API_URL="${{ needs.route.outputs.gitea_server_url }}/api/v1"
|
|
||||||
REPO="${{ needs.route.outputs.gitea_repository }}"
|
|
||||||
VERSION=${{ steps.get_version.outputs.VERSION }}
|
|
||||||
RESPONSE=$(curl -k -s -X POST -H "Authorization: token ${TOKEN}" -H "Content-Type: application/json" -d "{\"tag_name\":\"v${VERSION}\",\"name\":\"Release ${VERSION}\",\"body\":\"${{ steps.changelog.outputs.CHANGES }}\"}" "${API_URL}/repos/${REPO}/releases")
|
|
||||||
RELEASE_ID=$(echo "$RESPONSE" | grep -o '"id":[0-9]*' | cut -d':' -f2 | head -n1)
|
|
||||||
if [ -n "$RELEASE_ID" ]; then
|
|
||||||
echo "Release created with ID: $RELEASE_ID"
|
|
||||||
for file in filaman_${VERSION}.bin filaman_full_${VERSION}.bin; do
|
|
||||||
if [ -f ".pio/build/esp32dev/$file" ]; then
|
|
||||||
echo "Uploading $file..."
|
|
||||||
curl -k -s -X POST -H "Authorization: token ${TOKEN}" -H "Content-Type: application/octet-stream" --data-binary "@.pio/build/esp32dev/$file" "${API_URL}/repos/${REPO}/releases/${RELEASE_ID}/assets?name=$file"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
if [ -f ".pio/build/esp32dev/webpage_${VERSION}.bin" ]; then
|
|
||||||
echo "Uploading webpage binary..."
|
|
||||||
curl -k -s -X POST -H "Authorization: token ${TOKEN}" -H "Content-Type: application/octet-stream" --data-binary "@.pio/build/esp32dev/webpage_${VERSION}.bin" "${API_URL}/repos/${REPO}/releases/${RELEASE_ID}/assets?name=webpage_${VERSION}.bin"
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "Failed to create release. Response:"
|
|
||||||
echo "$RESPONSE"
|
|
||||||
exit 1
|
|
42
CHANGELOG.md
42
CHANGELOG.md
@@ -1,5 +1,47 @@
|
|||||||
# Changelog
|
# Changelog
|
||||||
|
|
||||||
|
## [1.3.11] - 2025-02-21
|
||||||
|
### Changed
|
||||||
|
- update webpages for version v1.3.11
|
||||||
|
- ci: refactor Gitea release workflow by simplifying input handling and removing unnecessary checks
|
||||||
|
|
||||||
|
|
||||||
|
## [1.3.10] - 2025-02-21
|
||||||
|
### Changed
|
||||||
|
- update webpages for version v1.3.10
|
||||||
|
- ci: simplify GitHub release workflow by removing provider verification step
|
||||||
|
|
||||||
|
|
||||||
|
## [1.3.9] - 2025-02-21
|
||||||
|
### Changed
|
||||||
|
- update webpages for version v1.3.9
|
||||||
|
- ci: comment out permissions for GitHub release workflow
|
||||||
|
|
||||||
|
|
||||||
|
## [1.3.8] - 2025-02-21
|
||||||
|
### Added
|
||||||
|
- add Gitea and GitHub release workflows
|
||||||
|
|
||||||
|
### Changed
|
||||||
|
- update webpages for version v1.3.8
|
||||||
|
|
||||||
|
|
||||||
|
## [1.3.7] - 2025-02-21
|
||||||
|
### Added
|
||||||
|
- add GitHub and Gitea release workflows
|
||||||
|
|
||||||
|
### Changed
|
||||||
|
- update webpages for version v1.3.7
|
||||||
|
|
||||||
|
|
||||||
|
## [1.3.6] - 2025-02-21
|
||||||
|
### Changed
|
||||||
|
- update webpages for version v1.3.6
|
||||||
|
|
||||||
|
### Fixed
|
||||||
|
- update GitHub token reference and correct file path in release workflow
|
||||||
|
|
||||||
|
|
||||||
## [1.3.5] - 2025-02-21
|
## [1.3.5] - 2025-02-21
|
||||||
### Added
|
### Added
|
||||||
- enhance release workflow to support Gitea alongside GitHub
|
- enhance release workflow to support Gitea alongside GitHub
|
||||||
|
@@ -9,7 +9,7 @@
|
|||||||
; https://docs.platformio.org/page/projectconf.html
|
; https://docs.platformio.org/page/projectconf.html
|
||||||
|
|
||||||
[common]
|
[common]
|
||||||
version = "1.3.5"
|
version = "1.3.11"
|
||||||
|
|
||||||
[env:esp32dev]
|
[env:esp32dev]
|
||||||
platform = espressif32
|
platform = espressif32
|
||||||
|
Reference in New Issue
Block a user