notify-discord.yml 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. name: Discord Notification
  2. on:
  3. release:
  4. types: [published]
  5. workflow_dispatch:
  6. inputs:
  7. tag_name:
  8. description: "Tag name (leave empty for latest release)"
  9. required: false
  10. type: string
  11. jobs:
  12. Discord:
  13. runs-on: ubuntu-latest
  14. name: Discord Notifier
  15. steps:
  16. - uses: actions/checkout@v4
  17. with:
  18. fetch-depth: 0
  19. - name: Get release info
  20. id: release-info
  21. run: |
  22. if [ "${{ github.event_name }}" = "workflow_dispatch" ]; then
  23. # Pour trigger manuel, récupère le dernier release ou utilise l'input
  24. if [ -n "${{ github.event.inputs.tag_name }}" ]; then
  25. TAG_NAME="${{ github.event.inputs.tag_name }}"
  26. else
  27. TAG_NAME=$(gh release list --limit 1 --json tagName --jq '.[0].tagName')
  28. fi
  29. # Récupère les infos du release via GitHub CLI
  30. RELEASE_INFO=$(gh release view "$TAG_NAME" --json name,body,url,author,publishedAt,tagName)
  31. echo "tag_name=$(echo "$RELEASE_INFO" | jq -r '.tagName')" >> $GITHUB_OUTPUT
  32. echo "name=$(echo "$RELEASE_INFO" | jq -r '.name')" >> $GITHUB_OUTPUT
  33. # Utilise EOF pour le body qui peut contenir des caractères spéciaux
  34. echo "body<<EOF" >> $GITHUB_OUTPUT
  35. echo "$RELEASE_INFO" | jq -r '.body' >> $GITHUB_OUTPUT
  36. echo "EOF" >> $GITHUB_OUTPUT
  37. echo "html_url=$(echo "$RELEASE_INFO" | jq -r '.url')" >> $GITHUB_OUTPUT
  38. echo "author_login=$(echo "$RELEASE_INFO" | jq -r '.author.login')" >> $GITHUB_OUTPUT
  39. echo "author_html_url=https://github.com/$(echo "$RELEASE_INFO" | jq -r '.author.login')" >> $GITHUB_OUTPUT
  40. echo "published_at=$(echo "$RELEASE_INFO" | jq -r '.publishedAt')" >> $GITHUB_OUTPUT
  41. else
  42. # Pour trigger automatique, utilise les données de l'événement
  43. echo "tag_name=${{ github.event.release.tag_name }}" >> $GITHUB_OUTPUT
  44. echo "name=${{ github.event.release.name }}" >> $GITHUB_OUTPUT
  45. # Utilise EOF pour le body du release automatique aussi
  46. echo "body<<EOF" >> $GITHUB_OUTPUT
  47. echo "${{ github.event.release.body }}" >> $GITHUB_OUTPUT
  48. echo "EOF" >> $GITHUB_OUTPUT
  49. echo "html_url=${{ github.event.release.html_url }}" >> $GITHUB_OUTPUT
  50. echo "author_login=${{ github.event.release.author.login }}" >> $GITHUB_OUTPUT
  51. echo "author_html_url=${{ github.event.release.author.html_url }}" >> $GITHUB_OUTPUT
  52. echo "published_at=${{ github.event.release.published_at }}" >> $GITHUB_OUTPUT
  53. fi
  54. env:
  55. GH_TOKEN: ${{ github.token }}
  56. - name: Get previous release
  57. id: previous-release
  58. run: |
  59. PREV_TAG=$(git tag --sort=-version:refname | grep -v '${{ steps.release-info.outputs.tag_name }}' | head -n1)
  60. echo "previous_tag=${PREV_TAG}" >> $GITHUB_OUTPUT
  61. - name: Get changed files since last release
  62. id: changed-files
  63. uses: tj-actions/changed-files@v44
  64. with:
  65. base_sha: ${{ steps.previous-release.outputs.previous_tag }}
  66. separator: "\n• "
  67. - name: Create Discord webhook payload
  68. run: |
  69. # Créer un fichier JSON temporaire
  70. cat > discord_payload.json << 'EOF'
  71. {
  72. "avatar_url": "https://github.githubassets.com/images/modules/logos_page/GitHub-Mark.png",
  73. "embeds": [
  74. {
  75. "title": "🚀 New Release: ${{ steps.release-info.outputs.tag_name }}",
  76. "description": "${{ steps.release-info.outputs.name }}\n\n${{ steps.release-info.outputs.body }}",
  77. "url": "${{ steps.release-info.outputs.html_url }}",
  78. "color": 5763719,
  79. "thumbnail": {
  80. "url": "https://github.githubassets.com/images/modules/logos_page/GitHub-Mark.png"
  81. },
  82. "fields": [
  83. {
  84. "name": "📦 Version",
  85. "value": "`${{ steps.release-info.outputs.tag_name }}`",
  86. "inline": true
  87. },
  88. {
  89. "name": "👤 Released by",
  90. "value": "[${{ steps.release-info.outputs.author_login }}](${{ steps.release-info.outputs.author_html_url }})",
  91. "inline": true
  92. },
  93. {
  94. "name": "📁 Repository",
  95. "value": "[${{ github.event.repository.name }}](${{ github.event.repository.html_url }})",
  96. "inline": true
  97. },
  98. {
  99. "name": "🔗 Download",
  100. "value": "[Release Page](${{ steps.release-info.outputs.html_url }})",
  101. "inline": true
  102. },
  103. {
  104. "name": "📝 Files Changed",
  105. "value": "• ${{ steps.changed-files.outputs.all_changed_files }}",
  106. "inline": false
  107. }
  108. ],
  109. "timestamp": "${{ steps.release-info.outputs.published_at }}",
  110. "footer": {
  111. "text": "Workout Cool • Release",
  112. "icon_url": "https://github.githubassets.com/images/modules/logos_page/GitHub-Mark.png"
  113. }
  114. }
  115. ]
  116. }
  117. EOF
  118. - name: Send Discord notification
  119. run: |
  120. curl -H "Content-Type: application/json" \
  121. -d @discord_payload.json \
  122. "${{ secrets.DISCORD_RELEASE_WEBHOOK }}"
  123. # https://stackoverflow.com/a/68068674/19395252
  124. # https://birdie0.github.io/discord-webhooks-guide/structure/embeds.html
  125. # https://github.com/marketplace/actions/changed-files