@gholl-studio/pier-connector 0.2.11 → 0.2.12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/src/index.js +12 -6
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@gholl-studio/pier-connector",
|
|
3
3
|
"author": "gholl",
|
|
4
|
-
"version": "0.2.
|
|
4
|
+
"version": "0.2.12",
|
|
5
5
|
"description": "OpenClaw plugin that connects to the Pier job marketplace. Automatically fetches, executes, and reports distributed tasks for rewards.",
|
|
6
6
|
"type": "module",
|
|
7
7
|
"main": "src/index.js",
|
package/src/index.js
CHANGED
|
@@ -151,15 +151,16 @@ export default function register(api) {
|
|
|
151
151
|
if (!resp.ok) {
|
|
152
152
|
if (resp.status === 409) {
|
|
153
153
|
logger.warn(`[pier-connector] 🚫 Job ${jobId} was already claimed by someone else.`);
|
|
154
|
+
return { ok: false, alreadyClaimed: true };
|
|
154
155
|
} else {
|
|
155
156
|
const errData = await resp.json().catch(() => ({}));
|
|
156
157
|
logger.error(`[pier-connector] ✖ Failed to claim job ${jobId}: ${errData.error || resp.statusText}`);
|
|
158
|
+
return { ok: false, error: errData.error || resp.statusText };
|
|
157
159
|
}
|
|
158
|
-
return false;
|
|
159
160
|
}
|
|
160
161
|
|
|
161
162
|
logger.info(`[pier-connector] ✅ Successfully claimed job ${jobId}`);
|
|
162
|
-
return true;
|
|
163
|
+
return { ok: true };
|
|
163
164
|
} catch (err) {
|
|
164
165
|
logger.error(`[pier-connector] ✖ Network error claiming job ${jobId}: ${err.message}`);
|
|
165
166
|
return false;
|
|
@@ -821,10 +822,15 @@ export default function register(api) {
|
|
|
821
822
|
// we must ATOMICALLY CLAIM it from the backend before setting isBusy.
|
|
822
823
|
const jobIdToClaim = payload.id;
|
|
823
824
|
if (jobIdToClaim) {
|
|
824
|
-
const
|
|
825
|
-
if (!
|
|
826
|
-
|
|
827
|
-
|
|
825
|
+
const claimResult = await claimJob(jobIdToClaim);
|
|
826
|
+
if (!claimResult.ok) {
|
|
827
|
+
if (claimResult.alreadyClaimed) {
|
|
828
|
+
// Already taken, ACK it so we don't keep getting redelivered
|
|
829
|
+
msg.ack();
|
|
830
|
+
} else {
|
|
831
|
+
// Real error, NAK it just in case someone else can try
|
|
832
|
+
msg.nak();
|
|
833
|
+
}
|
|
828
834
|
return;
|
|
829
835
|
}
|
|
830
836
|
}
|