Update generate-app-headers.yaml
This commit is contained in:
		
							parent
							
								
									0d2db00dc6
								
							
						
					
					
						commit
						d227277311
					
				
							
								
								
									
										104
									
								
								.github/workflows/generate-app-headers.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										104
									
								
								.github/workflows/generate-app-headers.yaml
									
									
									
									
										vendored
									
									
								
							| @ -1,14 +1,11 @@ | |||||||
| name: Update .app-headers in /misc | name: Update .app-headers in /misc | ||||||
| 
 | 
 | ||||||
| on: | on: | ||||||
|   pull_request: |   push: | ||||||
|     types: |     paths: | ||||||
|       - closed |       - 'ct/*'  # Action wird ausgelöst, wenn sich etwas in ct/ ändert | ||||||
|     branches: |     branches: | ||||||
|       - main |       - main | ||||||
|     if: github.event.pull_request.merged == true |  | ||||||
|   schedule: |  | ||||||
|     - cron: "59 23 * * *"  # Führen den Workflow täglich um 23:59 UTC aus |  | ||||||
|   workflow_dispatch: |   workflow_dispatch: | ||||||
| 
 | 
 | ||||||
| jobs: | jobs: | ||||||
| @ -23,103 +20,66 @@ jobs: | |||||||
|       - name: Checkout repository |       - name: Checkout repository | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v4 | ||||||
|         with: |         with: | ||||||
|           fetch-depth: 0  # Fetch all branches for full context |           fetch-depth: 0  # Ensure we have full access to all branches | ||||||
| 
 | 
 | ||||||
|       # Step 2: Set up Git user |       # Step 2: Merge main into update-app-headers branch | ||||||
|       - name: Configure Git user |  | ||||||
|         run: | |  | ||||||
|           git config --global user.name "GitHub Actions" |  | ||||||
|           git config --global user.email "actions@github.com" |  | ||||||
| 
 |  | ||||||
|       # Step 3: Check or create update-app-headers branch |  | ||||||
|       - name: Check or create update-app-headers branch |  | ||||||
|         run: | |  | ||||||
|           git fetch origin |  | ||||||
|           if git show-ref --quiet refs/heads/update-app-headers; then |  | ||||||
|             echo "Switching to 'update-app-headers' branch." |  | ||||||
|             git checkout update-app-headers |  | ||||||
|           else |  | ||||||
|             echo "Creating 'update-app-headers' branch." |  | ||||||
|             git checkout -b update-app-headers origin/main |  | ||||||
|           fi |  | ||||||
| 
 |  | ||||||
|       # Step 4: Merge main into update-app-headers |  | ||||||
|       - name: Merge main into update-app-headers |       - name: Merge main into update-app-headers | ||||||
|         run: | |         run: | | ||||||
|           git merge origin/main --no-edit || echo "No changes to merge from main." |           git fetch origin | ||||||
|  |           git checkout update-app-headers || git checkout -b update-app-headers | ||||||
|  |           git merge origin/main --no-ff --no-edit | ||||||
|  |           git push origin update-app-headers --force | ||||||
| 
 | 
 | ||||||
|       # Step 5: Check all .sh files in ct/ directory that contain APP= |       # Step 3: Ensure .app-headers file exists and initialize it | ||||||
|       - name: Check .sh files in ct/ that contain APP= |       - name: Initialize .app-headers file | ||||||
|         run: | |         run: | | ||||||
|           echo "Checking .sh files in ct/ directory that contain APP=." |           if [ ! -f "ct/.app-headers" ]; then | ||||||
|           SH_FILES=$(find ct/ -type f -name "*.sh" -exec grep -l "APP=" {} \;) |             echo "Creating .app-headers file" | ||||||
| 
 |             touch ct/.app-headers | ||||||
|           if [ -z "$SH_FILES" ]; then |  | ||||||
|             echo "No .sh files with APP= found in ct/ directory." |  | ||||||
|             exit 0 |  | ||||||
|           else |  | ||||||
|             echo "Found .sh files with APP= in ct/ directory:" |  | ||||||
|             echo "$SH_FILES" |  | ||||||
|           fi |           fi | ||||||
| 
 | 
 | ||||||
|       # Step 6: Overwrite .app-headers |       # Step 4: Loop through ct/ scripts and execute figlet if APP= is found | ||||||
|       - name: Overwrite .app-headers file |       - name: Update .app-headers with figlet output | ||||||
|         run: | |         run: | | ||||||
|           # Ensure .app-headers file exists |           echo "Updating .app-headers with figlet output." | ||||||
|           if [ ! -f ".app-headers" ]; then |           for file in ct/*.sh; do | ||||||
|             echo "Creating .app-headers file." |             if grep -q "APP=" "$file"; then | ||||||
|             echo "Generated by CI on $(date)" > .app-headers |               APP_NAME=$(grep -oP 'APP=\K.*' "$file") | ||||||
|           else |               echo "Processing $file for APP: $APP_NAME" | ||||||
|             echo ".app-headers file already exists." |               figlet "$APP_NAME" >> ct/.app-headers | ||||||
|           fi |             fi | ||||||
| 
 |  | ||||||
|           # Overwrite .app-headers with figlet output of each .sh file name containing APP= |  | ||||||
|           echo "Overwriting .app-headers with new entries." |  | ||||||
|           > .app-headers  # Clear the existing file |  | ||||||
|           for FILE in $SH_FILES; do |  | ||||||
|             APP_NAME=$(basename "$FILE" .sh) |  | ||||||
|             echo "$(figlet $APP_NAME)" >> .app-headers |  | ||||||
|           done |           done | ||||||
| 
 |            | ||||||
|       # Step 7: Check for changes and commit |       # Step 5: Commit the changes to .app-headers | ||||||
|       - name: Check for changes and commit |       - name: Commit updated .app-headers | ||||||
|         run: | |         run: | | ||||||
|           git diff --exit-code --quiet .app-headers |           git diff --quiet -- ct/.app-headers || git commit -am "[core]: update .app-headers to latest version" | ||||||
|           if [ $? -eq 1 ]; then |           git push origin update-app-headers --force | ||||||
|             echo ".app-headers has been updated, committing changes." |  | ||||||
|             git commit -am "[core]: update .app-headers to latest version" |  | ||||||
|             git push origin update-app-headers |  | ||||||
|           else |  | ||||||
|             echo "No changes to .app-headers detected, skipping commit." |  | ||||||
|           fi |  | ||||||
| 
 | 
 | ||||||
|       # Step 8: Create Pull Request if changes detected |       # Step 6: Create Pull Request to merge changes into main | ||||||
|       - name: Create Pull Request if changes detected |       - name: Create Pull Request if changes detected | ||||||
|         env: |         env: | ||||||
|           GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} |           GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||||
|         run: | |         run: | | ||||||
|           echo "Checking if PR exists." |  | ||||||
|           PR_EXISTS=$(gh pr list --head "update-app-headers" --json number --jq '.[].number') |           PR_EXISTS=$(gh pr list --head "update-app-headers" --json number --jq '.[].number') | ||||||
|           echo "PR_EXISTS: $PR_EXISTS" |  | ||||||
|           if [ -z "$PR_EXISTS" ]; then |           if [ -z "$PR_EXISTS" ]; then | ||||||
|             echo "Creating a new PR." |             echo "Creating a new PR." | ||||||
|             PR_URL=$(gh pr create --title "[core]: update .app-headers to latest version" \ |             PR_URL=$(gh pr create --title "[core]: update .app-headers to latest version" \ | ||||||
|                                    --body "This PR automatically updates the .app-headers file." \ |                                    --body "This PR automatically updates the .app-headers file." \ | ||||||
|                                    --head update-app-headers \ |                                    --head update-app-headers \ | ||||||
|                                    --base main) |                                    --base main --no-edit -q .url) | ||||||
|             echo "PR created: $PR_URL" |             echo "PR created: $PR_URL" | ||||||
|           else |           else | ||||||
|             echo "PR already exists." |             echo "PR already exists." | ||||||
|           fi |           fi | ||||||
| 
 | 
 | ||||||
|       # Step 9: Automatically merge PR |       # Step 7: Automatically merge PR | ||||||
|       - name: Automatically merge PR |       - name: Automatically merge PR | ||||||
|         env: |         env: | ||||||
|           GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} |           GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||||
|         run: | |         run: | | ||||||
|           echo "Attempting to merge PR." |           echo "Attempting to merge PR." | ||||||
|           PR_NUMBER=$(gh pr list --head "update-app-headers" --json number --jq '.[].number') |           PR_NUMBER=$(gh pr list --head "update-app-headers" --json number --jq '.[].number') | ||||||
|           echo "Found PR number: $PR_NUMBER" |  | ||||||
|           if [ -n "$PR_NUMBER" ]; then |           if [ -n "$PR_NUMBER" ]; then | ||||||
|             gh pr merge "$PR_NUMBER" --merge --admin --delete-branch |             gh pr merge "$PR_NUMBER" --merge --admin --delete-branch | ||||||
|             echo "PR merged successfully." |             echo "PR merged successfully." | ||||||
| @ -127,7 +87,7 @@ jobs: | |||||||
|             echo "No PR found to merge." |             echo "No PR found to merge." | ||||||
|           fi |           fi | ||||||
| 
 | 
 | ||||||
|       # Step 10: Final status output |       # Step 8: Final status output | ||||||
|       - name: Output final status |       - name: Output final status | ||||||
|         run: | |         run: | | ||||||
|           echo "Workflow completed successfully. Branch and PR status updated." |           echo "Workflow completed successfully. Branch and PR status updated." | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 CanbiZ
						CanbiZ