forked from misskey-dev/misskey
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'main.pooza' into daisskey
- Loading branch information
Showing
340 changed files
with
23,751 additions
and
15,591 deletions.
There are no files selected for viewing
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
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
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
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -5,29 +5,28 @@ on: | |
branches: | ||
- master | ||
- develop | ||
- improve-misskey-js-autogen-check | ||
paths: | ||
- packages/backend/** | ||
|
||
jobs: | ||
check-misskey-js-autogen: | ||
# pull_request_target safety: permissions: read-all, and there are no secrets used in this job | ||
generate-misskey-js: | ||
runs-on: ubuntu-latest | ||
permissions: | ||
pull-requests: write | ||
|
||
env: | ||
api_json_name: "api-head.json" | ||
|
||
contents: read | ||
if: ${{ github.event.pull_request.mergeable == null || github.event.pull_request.mergeable == true }} | ||
steps: | ||
- name: checkout | ||
uses: actions/[email protected] | ||
with: | ||
submodules: true | ||
ref: ${{ github.event.pull_request.head.sha }} | ||
ref: refs/pull/${{ github.event.pull_request.number }}/merge | ||
|
||
- name: setup pnpm | ||
uses: pnpm/action-setup@v3 | ||
with: | ||
version: 8 | ||
version: 9 | ||
|
||
- name: setup node | ||
id: setup-node | ||
|
@@ -39,79 +38,81 @@ jobs: | |
- name: install dependencies | ||
run: pnpm i --frozen-lockfile | ||
|
||
- name: wait get-api-diff | ||
uses: lewagon/[email protected] | ||
# generate api.json | ||
- name: Copy Config | ||
run: cp .config/example.yml .config/default.yml | ||
- name: Build | ||
run: pnpm build | ||
- name: Generate API JSON | ||
run: pnpm --filter backend generate-api-json | ||
|
||
# build misskey js | ||
- name: Build misskey-js | ||
run: |- | ||
cp packages/backend/built/api.json packages/misskey-js/generator/api.json | ||
pnpm run --filter misskey-js-type-generator generate | ||
# packages/misskey-js/generator/built/autogen | ||
- name: Upload Generated | ||
uses: actions/upload-artifact@v4 | ||
with: | ||
ref: ${{ github.event.pull_request.head.sha }} | ||
check-regexp: get-from-misskey .+ | ||
repo-token: ${{ secrets.GITHUB_TOKEN }} | ||
wait-interval: 30 | ||
name: generated-misskey-js | ||
path: packages/misskey-js/generator/built/autogen | ||
|
||
- name: Download artifact | ||
uses: actions/[email protected] | ||
# pull_request_target safety: permissions: read-all, and there are no secrets used in this job | ||
get-actual-misskey-js: | ||
runs-on: ubuntu-latest | ||
permissions: | ||
contents: read | ||
if: ${{ github.event.pull_request.mergeable == null || github.event.pull_request.mergeable == true }} | ||
steps: | ||
- name: checkout | ||
uses: actions/[email protected] | ||
with: | ||
script: | | ||
const fs = require('fs'); | ||
const workflows = await github.rest.actions.listWorkflowRunsForRepo({ | ||
owner: context.repo.owner, | ||
repo: context.repo.repo, | ||
head_sha: `${{ github.event.pull_request.head.sha }}` | ||
}).then(x => x.data.workflow_runs); | ||
console.log(workflows.map(x => ({name: x.name, title: x.display_title}))); | ||
const run_id = workflows.find(x => x.name.includes("Get api.json from Misskey")).id; | ||
let allArtifacts = await github.rest.actions.listWorkflowRunArtifacts({ | ||
owner: context.repo.owner, | ||
repo: context.repo.repo, | ||
run_id: run_id, | ||
}); | ||
let matchArtifacts = allArtifacts.data.artifacts.filter((artifact) => { | ||
return artifact.name.startsWith("api-artifact-") || artifact.name == "api-artifact" | ||
}); | ||
await Promise.all(matchArtifacts.map(async (artifact) => { | ||
let download = await github.rest.actions.downloadArtifact({ | ||
owner: context.repo.owner, | ||
repo: context.repo.repo, | ||
artifact_id: artifact.id, | ||
archive_format: 'zip', | ||
}); | ||
await fs.promises.writeFile(`${process.env.GITHUB_WORKSPACE}/${artifact.name}.zip`, Buffer.from(download.data)); | ||
})); | ||
- name: unzip artifacts | ||
run: |- | ||
find . -mindepth 1 -maxdepth 1 -type f -name '*.zip' -exec unzip {} -d . ';' | ||
ls -la | ||
submodules: true | ||
ref: refs/pull/${{ github.event.pull_request.number }}/merge | ||
|
||
- name: get head checksum | ||
run: |- | ||
checksum=$(realpath head_checksum) | ||
- name: Upload From Merged | ||
uses: actions/upload-artifact@v4 | ||
with: | ||
name: actual-misskey-js | ||
path: packages/misskey-js/src/autogen | ||
|
||
cd packages/misskey-js/src | ||
find autogen -type f -exec sh -c 'echo $(sed -E "s/^\s+\*\s+generatedAt:.+$//" {} | sha256sum | cut -d" " -f 1) {}' \; > $checksum | ||
cd ../../.. | ||
# pull_request_target safety: nothing is cloned from repository | ||
comment-misskey-js-autogen: | ||
runs-on: ubuntu-latest | ||
needs: [generate-misskey-js, get-actual-misskey-js] | ||
permissions: | ||
pull-requests: write | ||
steps: | ||
- name: download generated-misskey-js | ||
uses: actions/download-artifact@v4 | ||
with: | ||
name: generated-misskey-js | ||
path: misskey-js-generated | ||
|
||
- name: build autogen | ||
run: |- | ||
checksum=$(realpath ${api_json_name}_checksum) | ||
mv $api_json_name packages/misskey-js/generator/api.json | ||
- name: download actual-misskey-js | ||
uses: actions/download-artifact@v4 | ||
with: | ||
name: actual-misskey-js | ||
path: misskey-js-actual | ||
|
||
- name: check misskey-js changes | ||
id: check-changes | ||
run: | | ||
diff -r -u --label=generated --label=on-tree ./misskey-js-generated ./misskey-js-actual > misskey-js.diff || true | ||
cd packages/misskey-js/generator | ||
pnpm run generate | ||
cd built | ||
find autogen -type f -exec sh -c 'echo $(sed -E "s/^\s+\*\s+generatedAt:.+$//" {} | sha256sum | cut -d" " -f 1) {}' \; > $checksum | ||
cd ../../../.. | ||
if [ -s misskey-js.diff ]; then | ||
echo "changes=true" >> $GITHUB_OUTPUT | ||
else | ||
echo "changes=false" >> $GITHUB_OUTPUT | ||
fi | ||
- name: check update for type definitions | ||
run: diff head_checksum ${api_json_name}_checksum | ||
- name: Print full diff | ||
run: cat ./misskey-js.diff | ||
|
||
- name: send message | ||
if: failure() | ||
if: steps.check-changes.outputs.changes == 'true' | ||
uses: thollander/actions-comment-pull-request@v2 | ||
with: | ||
comment_tag: check-misskey-js-autogen | ||
|
@@ -125,7 +126,7 @@ jobs: | |
``` | ||
- name: send message | ||
if: success() | ||
if: steps.check-changes.outputs.changes == 'false' | ||
uses: thollander/actions-comment-pull-request@v2 | ||
with: | ||
comment_tag: check-misskey-js-autogen | ||
|
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
name: Check SPDX-License-Identifier | ||
|
||
on: | ||
push: | ||
branches: | ||
- master | ||
- develop | ||
pull_request: | ||
|
||
jobs: | ||
check-spdx-license-id: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout | ||
uses: actions/[email protected] | ||
- name: Check | ||
run: | | ||
counter=0 | ||
search() { | ||
local directory="$1" | ||
find "$directory" -type f \ | ||
'(' \ | ||
-name "*.cjs" -and -not -name '*.config.cjs' -o \ | ||
-name "*.html" -o \ | ||
-name "*.js" -and -not -name '*.config.js' -o \ | ||
-name "*.mjs" -and -not -name '*.config.mjs' -o \ | ||
-name "*.scss" -o \ | ||
-name "*.ts" -and -not -name '*.config.ts' -o \ | ||
-name "*.vue" \ | ||
')' -and \ | ||
-not -name '*eslint*' | ||
} | ||
check() { | ||
local file="$1" | ||
if ! ( | ||
grep -q "SPDX-FileCopyrightText: syuilo and misskey-project" "$file" || | ||
grep -q "SPDX-License-Identifier: AGPL-3.0-only" "$file" | ||
); then | ||
echo "Missing: $file" | ||
((counter++)) | ||
fi | ||
} | ||
directories=( | ||
"cypress/e2e" | ||
"packages/backend/migration" | ||
"packages/backend/src" | ||
"packages/backend/test" | ||
"packages/frontend/.storybook" | ||
"packages/frontend/@types" | ||
"packages/frontend/lib" | ||
"packages/frontend/public" | ||
"packages/frontend/src" | ||
"packages/frontend/test" | ||
"packages/misskey-bubble-game/src" | ||
"packages/misskey-reversi/src" | ||
"packages/sw/src" | ||
"scripts" | ||
) | ||
for directory in "${directories[@]}"; do | ||
for file in $(search $directory); do | ||
check "$file" | ||
done | ||
done | ||
if [ $counter -gt 0 ]; then | ||
echo "SPDX-License-Identifier is missing in $counter files." | ||
exit 1 | ||
else | ||
echo "SPDX-License-Identifier is certainly described in all target files!" | ||
exit 0 | ||
fi |
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
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
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -18,7 +18,7 @@ jobs: | |
|
||
strategy: | ||
matrix: | ||
node-version: [20.10.0] | ||
node-version: [20.12.2] | ||
api-json-name: [api-base.json, api-head.json] | ||
include: | ||
- api-json-name: api-base.json | ||
|
@@ -34,7 +34,7 @@ jobs: | |
- name: Install pnpm | ||
uses: pnpm/action-setup@v3 | ||
with: | ||
version: 8 | ||
version: 9 | ||
run_install: false | ||
- name: Use Node.js ${{ matrix.node-version }} | ||
uses: actions/[email protected] | ||
|
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
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -29,7 +29,7 @@ jobs: | |
submodules: true | ||
- uses: pnpm/action-setup@v3 | ||
with: | ||
version: 8 | ||
version: 9 | ||
run_install: false | ||
- uses: actions/[email protected] | ||
with: | ||
|
@@ -56,7 +56,7 @@ jobs: | |
submodules: true | ||
- uses: pnpm/action-setup@v3 | ||
with: | ||
version: 7 | ||
version: 9 | ||
run_install: false | ||
- uses: actions/[email protected] | ||
with: | ||
|
@@ -82,7 +82,7 @@ jobs: | |
submodules: true | ||
- uses: pnpm/action-setup@v3 | ||
with: | ||
version: 7 | ||
version: 9 | ||
run_install: false | ||
- uses: actions/[email protected] | ||
with: | ||
|
@@ -92,6 +92,6 @@ jobs: | |
- run: pnpm i --frozen-lockfile | ||
- run: pnpm --filter misskey-js run build | ||
if: ${{ matrix.workspace == 'backend' }} | ||
- run: pnpm --filter misskey-reversi run build:tsc | ||
- run: pnpm --filter misskey-reversi run build | ||
if: ${{ matrix.workspace == 'backend' }} | ||
- run: pnpm --filter ${{ matrix.workspace }} run typecheck |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -17,7 +17,7 @@ jobs: | |
|
||
strategy: | ||
matrix: | ||
node-version: [20.10.0] | ||
node-version: [20.12.2] | ||
|
||
steps: | ||
- uses: actions/[email protected] | ||
|
@@ -26,7 +26,7 @@ jobs: | |
- name: Install pnpm | ||
uses: pnpm/action-setup@v3 | ||
with: | ||
version: 8 | ||
version: 9 | ||
run_install: false | ||
- name: Use Node.js ${{ matrix.node-version }} | ||
uses: actions/[email protected] | ||
|
Oops, something went wrong.