Compare commits
	
		
			24 Commits
		
	
	
		
			v1.3.6
			...
			b0888e7e63
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| b0888e7e63 | |||
| 238a84a8a2 | |||
| 59cc00ca13 | |||
| ab083f5f57 | |||
| c111573206 | |||
| 52b2494e52 | |||
| 069ec2d7a1 | |||
| 94e35ae86e | |||
| d71e3d8184 | |||
| bb166aa29f | |||
| 0d718023f8 | |||
| b16781043f | |||
| dff184ff25 | |||
| 0ce281221d | |||
| bc26c160e8 | |||
| c25f41db75 | |||
| e107c17f50 | |||
| 85b9d03ebd | |||
| 17b188626a | |||
| a534c5f872 | |||
| 93f7582790 | |||
| 46acc63756 | |||
| 67a9e1bdce | |||
| 2b75b64b4a | 
							
								
								
									
										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 |  | ||||||
							
								
								
									
										14
									
								
								.github/workflows/github-release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								.github/workflows/github-release.yml
									
									
									
									
										vendored
									
									
								
							| @@ -2,6 +2,13 @@ name: GitHub Release | |||||||
|  |  | ||||||
| on: | on: | ||||||
|   workflow_call: |   workflow_call: | ||||||
|  |     secrets: | ||||||
|  |       RELEASE_TOKEN: | ||||||
|  |         description: 'GitHub token for release creation' | ||||||
|  |         required: true | ||||||
|  |  | ||||||
|  | permissions: | ||||||
|  |   contents: write | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   create-release: |   create-release: | ||||||
| @@ -10,6 +17,8 @@ jobs: | |||||||
|       contents: write |       contents: write | ||||||
|     steps: |     steps: | ||||||
|     - uses: actions/checkout@v4 |     - uses: actions/checkout@v4 | ||||||
|  |       with: | ||||||
|  |         fetch-depth: 0 | ||||||
|      |      | ||||||
|     - name: Set up Python |     - name: Set up Python | ||||||
|       uses: actions/setup-python@v4 |       uses: actions/setup-python@v4 | ||||||
| @@ -97,12 +106,12 @@ jobs: | |||||||
|  |  | ||||||
|     - name: Create GitHub Release |     - name: Create GitHub Release | ||||||
|       env: |       env: | ||||||
|         GH_TOKEN: ${{ github.token }} |         GH_TOKEN: ${{ secrets.RELEASE_TOKEN }} | ||||||
|       run: | |       run: | | ||||||
|         VERSION=${{ steps.get_version.outputs.VERSION }} |         VERSION=${{ steps.get_version.outputs.VERSION }} | ||||||
|  |         cd .pio/build/esp32dev | ||||||
|          |          | ||||||
|         # Create release with available files |         # Create release with available files | ||||||
|         cd .pio/build/esp32dev |  | ||||||
|         FILES_TO_UPLOAD="" |         FILES_TO_UPLOAD="" | ||||||
|          |          | ||||||
|         # Always add firmware |         # Always add firmware | ||||||
| @@ -128,4 +137,3 @@ jobs: | |||||||
|         else |         else | ||||||
|           echo "Error: No files found to upload" |           echo "Error: No files found to upload" | ||||||
|           exit 1 |           exit 1 | ||||||
|         fi |  | ||||||
							
								
								
									
										243
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										243
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							| @@ -5,252 +5,35 @@ on: | |||||||
|     tags: |     tags: | ||||||
|       - 'v*' |       - 'v*' | ||||||
|  |  | ||||||
|  | permissions: | ||||||
|  |   contents: write | ||||||
|  |  | ||||||
| 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' |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     permissions: |     permissions: | ||||||
|       contents: write |       contents: write | ||||||
|     steps: |     if: needs.detect-provider.outputs.provider == 'github' | ||||||
|     - uses: actions/checkout@v4 |     uses: ./.github/workflows/github-release.yml | ||||||
|     - name: Set up Python |     secrets: | ||||||
|       uses: actions/setup-python@v4 |       RELEASE_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||||
|       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: ${{ secrets.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 |  | ||||||
|       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 |  | ||||||
							
								
								
									
										52
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										52
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,5 +1,57 @@ | |||||||
| # Changelog | # Changelog | ||||||
|  |  | ||||||
|  | ## [1.3.14] - 2025-02-21 | ||||||
|  | ### Changed | ||||||
|  | - update webpages for version v1.3.14 | ||||||
|  | - ci: update GitHub release workflow to improve file upload handling | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ## [1.3.13] - 2025-02-21 | ||||||
|  | ### Changed | ||||||
|  | - update webpages for version v1.3.13 | ||||||
|  | - ci: update GitHub release workflow to use RELEASE_TOKEN for improved security | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ## [1.3.12] - 2025-02-21 | ||||||
|  | ### Changed | ||||||
|  | - update webpages for version v1.3.12 | ||||||
|  | - ci: enhance GitHub release workflow with token handling and file upload improvements | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ## [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 | ## [1.3.6] - 2025-02-21 | ||||||
| ### Changed | ### Changed | ||||||
| - update webpages for version v1.3.6 | - update webpages for version v1.3.6 | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
| ; https://docs.platformio.org/page/projectconf.html | ; https://docs.platformio.org/page/projectconf.html | ||||||
|  |  | ||||||
| [common] | [common] | ||||||
| version = "1.3.6" | version = "1.3.14" | ||||||
|  |  | ||||||
| [env:esp32dev] | [env:esp32dev] | ||||||
| platform = espressif32 | platform = espressif32 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user