CHANGED: message in the body #64
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: buildAndSendSignatures | |
on: | |
push: | |
branches: | |
- 'master' | |
paths: | |
- 'data/**.json' | |
- 'templates/template.html' | |
env: | |
GH_ACTIONS_ENV: true | |
EMAIL_USERNAME: ${{ secrets.EMAIL_USERNAME }} | |
EMAIL_PASSWORD: ${{ secrets.EMAIL_PASSWORD }} | |
VICEPRESIDENT_LINKEDIN: ${{ secrets.VICEPRESIDENT_LINKEDIN }} | |
VICEPRESIDENT_POSITION: ${{ secrets.VICEPRESIDENT_POSITION }} | |
VICEPRESIDENT_EMAIL: ${{ secrets.VICEPRESIDENT_EMAIL }} | |
VICEPRESIDENT_NAME: ${{ secrets.VICEPRESIDENT_NAME }} | |
COMMUNICATION_POSITION: ${{ secrets.COMMUNICATION_POSITION }} | |
COMMUNICATION_LINKEDIN: ${{ secrets.COMMUNICATION_LINKEDIN }} | |
COMMUNICATION_EMAIL: ${{ secrets.COMMUNICATION_EMAIL }} | |
COMMUNICATION_NAME: ${{ secrets.COMMUNICATION_NAME }} | |
TREASURER_POSITION: ${{ secrets.TREASURER_POSITION }} | |
TREASURER_LINKEDIN: ${{ secrets.TREASURER_LINKEDIN }} | |
TREASURER_EMAIL: ${{ secrets.TREASURER_EMAIL }} | |
TREASURER_NAME: ${{ secrets.TREASURER_NAME }} | |
SECRETARY_LINKEDIN: ${{ secrets.SECRETARY_LINKEDIN }} | |
SECRETARY_POSITION: ${{ secrets.SECRETARY_POSITION }} | |
SECRETARY_EMAIL: ${{ secrets.SECRETARY_EMAIL }} | |
SECRETARY_NAME: ${{ secrets.SECRETARY_NAME }} | |
PRESIDENT_LINKEDIN: ${{ secrets.PRESIDENT_LINKEDIN }} | |
PRESIDENT_POSITION: ${{ secrets.PRESIDENT_POSITION }} | |
PRESIDENT_EMAIL: ${{ secrets.PRESIDENT_EMAIL }} | |
PRESIDENT_NAME: ${{ secrets.PRESIDENT_NAME }} | |
ALEIXMT_LINKEDIN: ${{ secrets.ALEIXMT_LINKEDIN }} | |
ALEIXMT_POSITION: ${{ secrets.ALEIXMT_POSITION }} | |
ALEIXMT_EMAIL: ${{ secrets.ALEIXMT_EMAIL }} | |
ALEIXMT_NAME: ${{ secrets.ALEIXMT_NAME }} | |
INFORMATICS_LINKEDIN: ${{ secrets.INFORMATICS_LINKEDIN }} | |
INFORMATICS_POSITION: ${{ secrets.INFORMATICS_POSITION }} | |
INFORMATICS_EMAIL: ${{ secrets.INFORMATICS_EMAIL }} | |
INFORMATICS_NAME: ${{ secrets.INFORMATICS_NAME }} | |
jobs: | |
build_and_send_signatures: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
fetch-depth: ${{ github.event_name == 'pull_request' && 2 || 0 }} | |
# https://stackoverflow.com/questions/74265821/get-modified-files-in-github-actions | |
- name: Get changed files | |
id: changed-files | |
run: | | |
# Get modified files as input | |
input_text="" | |
if ${{ github.event_name == 'pull_request' }}; then | |
input_text="$(git diff --name-only -r HEAD^1 HEAD | xargs)" | |
else | |
input_text="$(git diff --name-only ${{ github.event.before }} ${{ github.event.after }} | xargs)" | |
fi | |
# Detect if the template has been modified | |
template_modified=false | |
for file in ${input_text}; do | |
if [ "templates/template.html" = "${file}" ]; then | |
template_modified=true | |
fi | |
done | |
# Select the signatures that are going to be built | |
signatures_to_build="" | |
if [ "${template_modified}" = "false" ]; then | |
for file in ${input_text}; do | |
echo value $file | |
if echo "${file}" | grep -q "/"; then | |
if [ "$(echo "${file}" | cut -f1 -d "/")" = "data" ]; then | |
if echo "${file}" | grep -q "."; then | |
signatures_to_build="$(echo "${file}" | cut -d "/" -f2 | cut -d "." -f1) ${signatures_to_build}" | |
fi | |
fi | |
fi | |
done | |
else # template_modified = true | |
for file in data/*.json; do | |
signatures_to_build="$(echo "${file}" | cut -d "/" -f2 | cut -d "." -f1) ${signatures_to_build}" | |
done | |
fi | |
echo "signatures_to_build=${signatures_to_build}" | |
echo "signatures_to_build=${signatures_to_build}" >> $GITHUB_OUTPUT | |
- name: List changed files | |
run: | | |
echo "Signatures to build:" | |
for file in ${{ steps.changed-files.outputs.signatures_to_build }}; do | |
echo "$file" | |
done | |
- name: Substitute marks (implicit parameters in env) | |
run: | | |
chmod u+x src/substituteMarks.sh | |
./src/substituteMarks.sh ${{ steps.changed-files.outputs.signatures_to_build }} | |
- name: Set up nodeJS | |
uses: actions/setup-node@v4 | |
with: | |
node-version: '20.x' | |
- name: Render signatures | |
run: | | |
npm install | |
node ./src/renderSignatures.js | |
- name: Send emails | |
id: send-emails | |
run: | | |
chmod u+x src/sendEmails.sh | |
./src/sendEmails.sh ${{ steps.changed-files.outputs.signatures_to_build }} | |