Compare commits

...

4 Commits

Author SHA1 Message Date
Spyros Roum
221de81657
Merge 264c4e8b40 into 4da57bd76c 2025-01-07 21:50:45 +01:00
Sébastiaan
4da57bd76c
fix: permissions of validate pipelines (#1316)
Some checks are pending
Create Changelog Pull Request / update-changelog-pull-request (push) Waiting to run
Shellcheck / Shellcheck (push) Waiting to run
Validate script formatting / Check changed files (push) Waiting to run
Validate scripts / Check changed files (push) Waiting to run
* Fix permission in validate-filenames pipeline

* Run Github Actions for script validation on pull_request_target with right permissions
2025-01-07 20:34:37 +01:00
Spyros Roum
264c4e8b40 Use tarballs for actualbudget install/update 2025-01-06 16:05:26 +02:00
Spyros Roum
693ae94e7d Install/update ActualBudget based on releases, not latest main 2025-01-05 14:19:43 +02:00
5 changed files with 55 additions and 13 deletions

View File

@ -1,23 +1,36 @@
name: Validate filenames name: Validate filenames
on: on:
pull_request: pull_request_target:
paths: paths:
- "ct/*.sh" - "ct/*.sh"
- "install/*.sh" - "install/*.sh"
- "json/*.json" - "json/*.json"
- ".github/workflows/validate-filenames.yml"
jobs: jobs:
check-files: check-files:
name: Check changed files name: Check changed files
runs-on: ubuntu-latest runs-on: ubuntu-latest
permissions:
pull-requests: write
steps: steps:
- name: Get pull request information
uses: actions/github-script@v7
id: pr
with:
script: |
const { data: pullRequest } = await github.rest.pulls.get({
...context.repo,
pull_number: context.payload.pull_request.number,
});
return pullRequest;
- name: Checkout code - name: Checkout code
uses: actions/checkout@v4 uses: actions/checkout@v4
with: with:
fetch-depth: 0 # Ensure the full history is fetched for accurate diffing fetch-depth: 0 # Ensure the full history is fetched for accurate diffing
ref: ${{ fromJSON(steps.pr.outputs.result).merge_commit_sha }}
- name: Get changed files - name: Get changed files
id: changed-files id: changed-files

View File

@ -4,11 +4,10 @@ on:
push: push:
branches: branches:
- main - main
pull_request: pull_request_target:
paths: paths:
- "**/*.sh" - "**/*.sh"
- "**/*.func" - "**/*.func"
- ".github/workflows/validate-formatting.yaml"
jobs: jobs:
shfmt: shfmt:
@ -18,10 +17,22 @@ jobs:
pull-requests: write pull-requests: write
steps: steps:
- name: Get pull request information
uses: actions/github-script@v7
id: pr
with:
script: |
const { data: pullRequest } = await github.rest.pulls.get({
...context.repo,
pull_number: context.payload.pull_request.number,
});
return pullRequest;
- name: Checkout code - name: Checkout code
uses: actions/checkout@v4 uses: actions/checkout@v4
with: with:
fetch-depth: 0 fetch-depth: 0 # Ensure the full history is fetched for accurate diffing
ref: ${{ fromJSON(steps.pr.outputs.result).merge_commit_sha }}
- name: Get changed files - name: Get changed files
id: changed-files id: changed-files

View File

@ -3,11 +3,10 @@ on:
push: push:
branches: branches:
- main - main
pull_request: pull_request_target:
paths: paths:
- "ct/*.sh" - "ct/*.sh"
- "install/*.sh" - "install/*.sh"
- ".github/workflows/validate-scripts.yml"
jobs: jobs:
check-scripts: check-scripts:
@ -17,10 +16,22 @@ jobs:
pull-requests: write pull-requests: write
steps: steps:
- name: Get pull request information
uses: actions/github-script@v7
id: pr
with:
script: |
const { data: pullRequest } = await github.rest.pulls.get({
...context.repo,
pull_number: context.payload.pull_request.number,
});
return pullRequest;
- name: Checkout code - name: Checkout code
uses: actions/checkout@v4 uses: actions/checkout@v4
with: with:
fetch-depth: ${{ github.event_name == 'pull_request' && 2 || 0 }} fetch-depth: 0 # Ensure the full history is fetched for accurate diffing
ref: ${{fromJSON(steps.pr.outputs.result).merge_commit_sha}}
- name: Set execute permission for .sh files - name: Set execute permission for .sh files
run: | run: |

View File

@ -34,11 +34,16 @@ function update_script() {
fi fi
msg_info "Updating ${APP}" msg_info "Updating ${APP}"
systemctl stop actualbudget.service systemctl stop actualbudget.service
RELEASE=$(curl -s https://api.github.com/repos/actualbudget/actual-server/tags | jq --raw-output '.[0].name')
TEMPD="$(mktemp -d)"
cd "${TEMPD}"
wget -q https://codeload.github.com/actualbudget/actual-server/legacy.tar.gz/refs/tags/${RELEASE} -O - | tar -xz
mv actualbudget-actual-server-*/* /opt/actualbudget/
cd /opt/actualbudget cd /opt/actualbudget
git pull &>/dev/null
yarn install &>/dev/null yarn install &>/dev/null
systemctl start actualbudget.service systemctl start actualbudget.service
msg_ok "Successfully Updated ${APP}" msg_ok "Successfully Updated ${APP} to ${RELEASE}"
rm -rf "${TEMPD}"
exit exit
} }

View File

@ -35,8 +35,10 @@ $STD apt-get install -y nodejs
$STD npm install --global yarn $STD npm install --global yarn
msg_ok "Installed Node.js" msg_ok "Installed Node.js"
msg_info "Installing Actual Budget" RELEASE=$(curl -s https://api.github.com/repos/actualbudget/actual-server/tags | jq --raw-output '.[0].name')
$STD git clone https://github.com/actualbudget/actual-server.git /opt/actualbudget msg_info "Installing Actual Budget $RELEASE"
wget -q https://codeload.github.com/actualbudget/actual-server/legacy.tar.gz/refs/tags/${RELEASE} -O - | tar -xz
mv actualbudget-actual-server-* /opt/actualbudget
mkdir -p /opt/actualbudget/server-files mkdir -p /opt/actualbudget/server-files
chown -R root:root /opt/actualbudget/server-files chown -R root:root /opt/actualbudget/server-files
chmod 755 /opt/actualbudget/server-files chmod 755 /opt/actualbudget/server-files