Package evidence
@camunda8/[email protected]
Install Lifecycle Remote Or Exec: prepare="git rev-parse --is-inside-work-tree >/dev/null 2>&1 && sh -c 'hp=$(git config --local --get core.hooksPath 2>/dev/null || true); if [ -z \"$hp\" ] || [ \"$hp\" = \".githooks\" ]; then git config --local core.hooksPath .githooks; else echo \"prepare: leaving existing core.hooksPath=$hp\"; fi' || true"
Trust signals
Why this verdict
PkgRadar discounts a release’s score when public reputation argues against novel malware. The verdict above already reflects these — the panel just explains what was applied.
- Publisher
- GitHub ActionsTrusted automation · −70% score
Effective trust discount applied: −70% (max across signals — discounts don’t stack). New install-lifecycle deltas vs the previous release would clear the discount.
Recommended action
Block this updateStatic evidence trips multiple high-signal indicators. Quarantine the release until the publisher validates the change or you can rule out the indicators below.
Block this release in CIcurl · GitHub Actions
Fail the build when this package version is added or upgraded. Replace $PKGRADAR_TOKEN with a Pro / Team API key from your dashboard.
curl -fsS https://pkgradar.com/gate/npm \
-H "Authorization: Bearer $PKGRADAR_TOKEN" \
-H "Content-Type: application/json" \
-d '{"specs":["@camunda8/[email protected]"],"fail_on":"high"}'GitHub Actions step:
- name: PkgRadar gate
run: |
curl -fsS https://pkgradar.com/gate/npm \
-H "Authorization: Bearer ${{ secrets.PKGRADAR_TOKEN }}" \
-H "Content-Type: application/json" \
-d '{"specs":["@camunda8/[email protected]"],"fail_on":"high"}'Why flagged
What the scanner saw
Install Lifecycle Remote Or Exec: prepare="git rev-parse --is-inside-work-tree >/dev/null 2>&1 && sh -c 'hp=$(git config --local --get core.hooksPath 2>/dev/null || true); if [ -z \"$hp\" ] || [ \"$hp\" = \".githooks\" ]; then git config --local core.hooksPath .githooks; else echo \"prepare: leaving existing core.hooksPath=$hp\"; fi' || true"
Not observed: package install, lifecycle script execution, or sandbox execution. PkgRadar only inspects on-disk artifacts.
Availability ledger
available
Status history (1 event)
- new → available · risk high · score 103 · status changed
Related candidates
Linked campaigns and clusters
Install Lifecycle Suppresses Failure — prepare="git rev-parse --is-inside-work-tree >/dev/null 2>&1 && sh -c 'hp=$(git config --local --get core.hookspath 2>/dev/null || true); if [ -z \"$hp\" ] || [ \"$hp\" = \".githooks\" ]; then git config --local core.hookspath .githooks; else echo \"prepare: leaving existing core.hookspath=$hp\"; fi' || true"
2 members · evidence strength 70Install Lifecycle Remote Or Exec — prepare="git rev-parse --is-inside-work-tree >/dev/null 2>&1 && sh -c 'hp=$(git config --local --get core.hookspath 2>/dev/null || true); if [ -z \"$hp\" ] || [ \"$hp\" = \".githooks\" ]; then git config --local core.hookspath .githooks; else echo \"prepare: leaving existing core.hookspath=$hp\"; fi' || true"
2 members · evidence strength 70Evidence
Static findings
8 static · 0 from release diff · showing high-signal first.
| Severity | Kind | Path | Detail | Points |
|---|---|---|---|---|
| high | Install Lifecycle Remote Or Exec | package.json | prepare="git rev-parse --is-inside-work-tree >/dev/null 2>&1 && sh -c 'hp=$(git config --local --get core.hooksPath 2>/dev/null || true); if [ -z \"$hp\" ] || [ \"$hp\" = \".githooks\" ]; then git config --local core.hooksPath .githooks; else echo \"prepare: leaving existing core.hooksPath=$hp\"; fi' || true" | 30 |
| high | Install Lifecycle Suppresses Failure | package.json | prepare="git rev-parse --is-inside-work-tree >/dev/null 2>&1 && sh -c 'hp=$(git config --local --get core.hooksPath 2>/dev/null || true); if [ -z \"$hp\" ] || [ \"$hp\" = \".githooks\" ]; then git config --local core.hooksPath .githooks; else echo \"prepare: leaving existing core.hooksPath=$hp\"; fi' || true" | 20 |
| medium | Remote Payload | package/dist/default-plugins/element-template/c8ctl-plugin.js | matched "raw.githubusercontent.com" | 12 |
| medium | Remote Payload | package/dist/default-plugins/element-template/helpers.js | matched "raw.githubusercontent.com" | 12 |
| medium | Remote Payload | package/dist/default-plugins/element-template/marketplace.js | matched "raw.githubusercontent.com" | 12 |
| medium | Large Javascript Payload | package/dist/vendor/bpmn-element-templates.cjs | 2368802 bytes | 10 |
Show all 8 findings (low-signal and informational)
| Severity | Kind | Path | Detail | Points |
|---|---|---|---|---|
| high | Install Lifecycle Remote Or Exec | package.json | prepare="git rev-parse --is-inside-work-tree >/dev/null 2>&1 && sh -c 'hp=$(git config --local --get core.hooksPath 2>/dev/null || true); if [ -z \"$hp\" ] || [ \"$hp\" = \".githooks\" ]; then git config --local core.hooksPath .githooks; else echo \"prepare: leaving existing core.hooksPath=$hp\"; fi' || true" | 30 |
| high | Install Lifecycle Suppresses Failure | package.json | prepare="git rev-parse --is-inside-work-tree >/dev/null 2>&1 && sh -c 'hp=$(git config --local --get core.hooksPath 2>/dev/null || true); if [ -z \"$hp\" ] || [ \"$hp\" = \".githooks\" ]; then git config --local core.hooksPath .githooks; else echo \"prepare: leaving existing core.hooksPath=$hp\"; fi' || true" | 20 |
| medium | Remote Payload | package/dist/default-plugins/element-template/c8ctl-plugin.js | matched "raw.githubusercontent.com" | 12 |
| medium | Remote Payload | package/dist/default-plugins/element-template/helpers.js | matched "raw.githubusercontent.com" | 12 |
| medium | Remote Payload | package/dist/default-plugins/element-template/marketplace.js | matched "raw.githubusercontent.com" | 12 |
| medium | Large Javascript Payload | package/dist/vendor/bpmn-element-templates.cjs | 2368802 bytes | 10 |
| low | Install-time lifecycle script | package.json | prepare="git rev-parse --is-inside-work-tree >/dev/null 2>&1 && sh -c 'hp=$(git config --local --get core.hooksPath 2>/dev/null || true); if [ -z \"$hp\" ] || [ \"$hp\" = \".githooks\" ]; then git config --local core.hooksPath .githooks; else echo \"prepare: leaving existing core.hooksPath=$hp\"; fi' || true" | 4 |
| low | Obfuscation | package/dist/plugin-loader.js | matched "\\u2014" | 3 |
Manifest
Package metadata
Scripts20
buildnpm run lint && npm run sync:readme && npm run sync:docs && npm run clean && tsc && npm run build:plugins && npm run build:vendor && npm run copy-plugins && npm run copy-templatesbuild:pluginstsc -p tsconfig.plugins.json && node -e "require('fs').rmSync('dist/src',{recursive:true,force:true})"build:vendoresbuild default-plugins/element-template/vendor-src/bundle-entry.js --bundle --format=cjs --platform=node --outfile=dist/vendor/bpmn-element-templates.cjscleannode -e "require('fs').rmSync('dist',{recursive:true,force:true})"clinode src/index.tscopy-pluginsnode -e "const fs=require('fs');const src='default-plugins';const dest='dist/default-plugins';if(fs.existsSync(src)){fs.cpSync(src,dest,{recursive:true,filter:(s)=>!s.endsWith('.ts')})}"copy-templatesnode -e "const fs=require('fs');const src='src/templates';const dest='dist/templates';if(fs.existsSync(src)){fs.cpSync(src,dest,{recursive:true})}"devnode src/index.tslintbiome check src/ tests/ scripts/ default-plugins/lint:srcbiome check src/ scripts/preparegit rev-parse --is-inside-work-tree >/dev/null 2>&1 && sh -c 'hp=$(git config --local --get core.hooksPath 2>/dev/null || true); if [ -z "$hp" ] || [ "$hp" = ".githooks" ]; then git config --local core.hooksPath .githooks; else echo "prepare: leaving existing core.hooksPath=$hp"; fi' || trueprepublishOnlynpm run buildsync:docsnode --experimental-strip-types scripts/sync-readme-commands.ts --docssync:docs:checknode --experimental-strip-types scripts/sync-readme-commands.ts --docs --checksync:readmenode --experimental-strip-types scripts/sync-readme-commands.tssync:readme:checknode --experimental-strip-types scripts/sync-readme-commands.ts --checktestnpm run test:unit && npm run test:integrationtest:integrationnpm run build:vendor && node --experimental-strip-types --experimental-test-isolation=none --test tests/integration/*.test.tstest:unitnpm run build:vendor && node --experimental-strip-types --test tests/unit/*.test.tstypechecktsc --noEmit -p tsconfig.check.json
Dependencies10
@bpmn-io/moddle-utils^0.3.0@camunda8/orchestration-cluster-api^9.1.0@modelcontextprotocol/sdk^1.29.0bpmn-moddle^9.0.1bpmnlint^11.6.1bpmnlint-plugin-camunda-compat^2.43.1feelin^6.2.0ignore^7.0.5semver^7.6.3zeebe-bpmn-moddle^1.11.0