0e94e84e2c
The K8s log client v1.x closes the follow-stream prematurely due to a known upstream bug — causing the grace timer to fire 30 s after log stream exit even when the container is still running. The old behaviour (`waitForPodTermination` with a hardcoded 120 s timeout) was too short for agents whose opencode runs take several minutes, leading to premature failure and issues stuck in `blocked`. Fix: the grace poller now calls `readNamespacedPod` before resolving the completion promise. If the pod is still Running/Pending, it resets `logExitTime` to defer the grace deadline. A `graceCheckPending` guard prevents concurrent checks. A `graceMaxWaitMs` cap (= completionTimeoutMs when set, 20 min otherwise) ensures we never wait forever for unlimited jobs. Version bumped to 0.1.21. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
40 lines
949 B
JSON
40 lines
949 B
JSON
{
|
|
"name": "paperclip-adapter-opencode-k8s",
|
|
"version": "0.1.21",
|
|
"description": "Paperclip adapter plugin that runs OpenCode agents as Kubernetes Jobs",
|
|
"license": "MIT",
|
|
"type": "module",
|
|
"paperclip": {
|
|
"adapterUiParser": "1.0.0"
|
|
},
|
|
"exports": {
|
|
".": "./dist/index.js",
|
|
"./server": "./dist/server/index.js",
|
|
"./ui-parser": "./dist/ui-parser.js",
|
|
"./cli": "./dist/cli/index.js"
|
|
},
|
|
"files": [
|
|
"dist"
|
|
],
|
|
"scripts": {
|
|
"build": "tsc",
|
|
"clean": "rm -rf dist",
|
|
"typecheck": "tsc --noEmit",
|
|
"test": "vitest run",
|
|
"test:watch": "vitest"
|
|
},
|
|
"dependencies": {
|
|
"@kubernetes/client-node": "^1.0.0",
|
|
"picocolors": "^1.1.1"
|
|
},
|
|
"peerDependencies": {
|
|
"@paperclipai/adapter-utils": ">=2026.415.0-canary.7"
|
|
},
|
|
"devDependencies": {
|
|
"@paperclipai/adapter-utils": "2026.415.0-canary.7",
|
|
"@types/node": "^24.6.0",
|
|
"typescript": "^5.7.3",
|
|
"vitest": "^4.1.4"
|
|
}
|
|
}
|