@lucid-agents/taskmarket 0.5.0 → 0.5.2
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/dist/commands/deposit.js +13 -12
- package/dist/commands/deposit.js.map +1 -1
- package/dist/commands/init.js +42 -5
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/task/download.js +47 -0
- package/dist/commands/task/download.js.map +1 -0
- package/dist/commands/task/index.js +6 -0
- package/dist/commands/task/index.js.map +1 -1
- package/dist/commands/task/select-winner.js +29 -0
- package/dist/commands/task/select-winner.js.map +1 -0
- package/dist/commands/task/submissions.js +41 -0
- package/dist/commands/task/submissions.js.map +1 -0
- package/package.json +3 -3
package/dist/commands/deposit.js
CHANGED
|
@@ -1,10 +1,7 @@
|
|
|
1
1
|
import { Command } from 'commander';
|
|
2
2
|
import { getWalletAddress } from '../lib/signer.js';
|
|
3
3
|
import { isHumanMode, printResult, printError } from '../lib/output.js';
|
|
4
|
-
|
|
5
|
-
const CHAIN_ID = 84532;
|
|
6
|
-
const USDC_CONTRACT = '0x036CbD53842c5426634e7929541eC2318f3dCF7e';
|
|
7
|
-
const FAUCET = 'https://faucet.circle.com';
|
|
4
|
+
import { apiGet } from '../lib/api.js';
|
|
8
5
|
export const depositCommand = new Command('deposit')
|
|
9
6
|
.description('Show wallet address and network info for funding')
|
|
10
7
|
.option('--human', 'Human-readable output')
|
|
@@ -18,13 +15,21 @@ export const depositCommand = new Command('deposit')
|
|
|
18
15
|
const msg = err instanceof Error ? err.message : 'No keystore found. Run `taskmarket init` first.';
|
|
19
16
|
printError(msg, human);
|
|
20
17
|
}
|
|
18
|
+
let networkInfo;
|
|
19
|
+
try {
|
|
20
|
+
const response = (await apiGet('/trpc/network.info'));
|
|
21
|
+
networkInfo = response.result.data;
|
|
22
|
+
}
|
|
23
|
+
catch (err) {
|
|
24
|
+
const msg = err instanceof Error ? err.message : 'Failed to fetch network info from backend.';
|
|
25
|
+
printError(msg, human);
|
|
26
|
+
}
|
|
21
27
|
const data = {
|
|
22
28
|
address: address,
|
|
23
|
-
network:
|
|
24
|
-
chainId:
|
|
29
|
+
network: networkInfo.networkName,
|
|
30
|
+
chainId: networkInfo.chainId,
|
|
25
31
|
currency: 'USDC',
|
|
26
|
-
usdcContract:
|
|
27
|
-
faucet: FAUCET,
|
|
32
|
+
usdcContract: networkInfo.usdcAddress,
|
|
28
33
|
};
|
|
29
34
|
if (!human) {
|
|
30
35
|
printResult(data, human);
|
|
@@ -36,9 +41,5 @@ export const depositCommand = new Command('deposit')
|
|
|
36
41
|
console.log(` Network: ${data.network} (chain ID ${data.chainId})`);
|
|
37
42
|
console.log(` Currency: ${data.currency}`);
|
|
38
43
|
console.log(` Contract: ${data.usdcContract}`);
|
|
39
|
-
console.log('');
|
|
40
|
-
console.log('Get testnet USDC:');
|
|
41
|
-
console.log(` Faucet: ${data.faucet}`);
|
|
42
|
-
console.log(' (select Base Sepolia, paste your address above)');
|
|
43
44
|
});
|
|
44
45
|
//# sourceMappingURL=deposit.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"deposit.js","sourceRoot":"","sources":["../../src/commands/deposit.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"deposit.js","sourceRoot":"","sources":["../../src/commands/deposit.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AACxE,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAUvC,MAAM,CAAC,MAAM,cAAc,GAAG,IAAI,OAAO,CAAC,SAAS,CAAC;KACjD,WAAW,CAAC,kDAAkD,CAAC;KAC/D,MAAM,CAAC,SAAS,EAAE,uBAAuB,CAAC;KAC1C,MAAM,CAAC,KAAK,EAAE,IAAyB,EAAE,EAAE;IAC1C,MAAM,KAAK,GAAG,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAEtC,IAAI,OAAe,CAAC;IACpB,IAAI,CAAC;QACH,OAAO,GAAG,MAAM,gBAAgB,EAAE,CAAC;IACrC,CAAC;IAAC,OAAO,GAAY,EAAE,CAAC;QACtB,MAAM,GAAG,GACP,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,iDAAiD,CAAC;QACzF,UAAU,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IACzB,CAAC;IAED,IAAI,WAAwB,CAAC;IAC7B,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,CAAC,MAAM,MAAM,CAAC,oBAAoB,CAAC,CAEnD,CAAC;QACF,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC;IACrC,CAAC;IAAC,OAAO,GAAY,EAAE,CAAC;QACtB,MAAM,GAAG,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,4CAA4C,CAAC;QAC9F,UAAU,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IACzB,CAAC;IAED,MAAM,IAAI,GAAG;QACX,OAAO,EAAE,OAAQ;QACjB,OAAO,EAAE,WAAY,CAAC,WAAW;QACjC,OAAO,EAAE,WAAY,CAAC,OAAO;QAC7B,QAAQ,EAAE,MAAM;QAChB,YAAY,EAAE,WAAY,CAAC,WAAW;KACvC,CAAC;IAEF,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,WAAW,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACzB,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,sCAAsC,CAAC,CAAC;IACpD,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAChB,OAAO,CAAC,GAAG,CAAC,eAAe,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;IAC3C,OAAO,CAAC,GAAG,CAAC,eAAe,IAAI,CAAC,OAAO,cAAc,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;IACtE,OAAO,CAAC,GAAG,CAAC,eAAe,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;IAC5C,OAAO,CAAC,GAAG,CAAC,eAAe,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;AAClD,CAAC,CAAC,CAAC"}
|
package/dist/commands/init.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Command } from 'commander';
|
|
2
2
|
import { generateKeypair, encryptPrivateKey, saveKeystore, keystoreExists, getKeystorePath, loadKeystore, } from '../lib/keystore.js';
|
|
3
|
-
import { API_URL } from '../lib/api.js';
|
|
3
|
+
import { API_URL, apiGet } from '../lib/api.js';
|
|
4
4
|
import { isHumanMode, printResult } from '../lib/output.js';
|
|
5
5
|
import { pollAgentId } from '../lib/agent.js';
|
|
6
6
|
export const initCommand = new Command('init')
|
|
@@ -18,13 +18,33 @@ export const initCommand = new Command('init')
|
|
|
18
18
|
await saveKeystore({ ...keystore, agentId });
|
|
19
19
|
}
|
|
20
20
|
}
|
|
21
|
+
let networkInfo;
|
|
22
|
+
try {
|
|
23
|
+
const response = (await apiGet('/trpc/network.info'));
|
|
24
|
+
networkInfo = response.result.data;
|
|
25
|
+
}
|
|
26
|
+
catch {
|
|
27
|
+
// Non-fatal
|
|
28
|
+
}
|
|
21
29
|
if (human) {
|
|
22
30
|
console.log('Wallet already exists:', keystore.walletAddress);
|
|
23
31
|
if (agentId)
|
|
24
32
|
console.log('Agent ID:', agentId);
|
|
33
|
+
if (networkInfo) {
|
|
34
|
+
console.log('');
|
|
35
|
+
console.log('Network info:');
|
|
36
|
+
console.log(` Network: ${networkInfo.networkName} (chain ID ${networkInfo.chainId})`);
|
|
37
|
+
console.log(' Currency: USDC');
|
|
38
|
+
console.log(` Contract: ${networkInfo.usdcAddress}`);
|
|
39
|
+
}
|
|
25
40
|
}
|
|
26
41
|
else {
|
|
27
|
-
printResult({
|
|
42
|
+
printResult({
|
|
43
|
+
address: keystore.walletAddress,
|
|
44
|
+
agentId,
|
|
45
|
+
network: networkInfo?.networkName,
|
|
46
|
+
chainId: networkInfo?.chainId,
|
|
47
|
+
}, human);
|
|
28
48
|
}
|
|
29
49
|
return;
|
|
30
50
|
}
|
|
@@ -51,16 +71,33 @@ export const initCommand = new Command('init')
|
|
|
51
71
|
await saveKeystore({ ...keystore, agentId });
|
|
52
72
|
}
|
|
53
73
|
}
|
|
74
|
+
// Fetch network info to show funding details
|
|
75
|
+
let networkInfo;
|
|
76
|
+
try {
|
|
77
|
+
const response = (await apiGet('/trpc/network.info'));
|
|
78
|
+
networkInfo = response.result.data;
|
|
79
|
+
}
|
|
80
|
+
catch {
|
|
81
|
+
// Non-fatal — show fallback text if backend unreachable
|
|
82
|
+
}
|
|
54
83
|
if (human) {
|
|
55
84
|
console.log('Wallet created:', address);
|
|
56
85
|
console.log('Agent ID:', agentId ?? '(pending — run `taskmarket init` again shortly)');
|
|
57
86
|
console.log('Keystore saved to:', getKeystorePath());
|
|
58
87
|
console.log('');
|
|
59
|
-
console.log('
|
|
60
|
-
console.log(
|
|
88
|
+
console.log('Fund your wallet to start using Taskmarket:');
|
|
89
|
+
console.log(` Address: ${address}`);
|
|
90
|
+
if (networkInfo) {
|
|
91
|
+
console.log(` Network: ${networkInfo.networkName} (chain ID ${networkInfo.chainId})`);
|
|
92
|
+
console.log(' Currency: USDC');
|
|
93
|
+
console.log(` Contract: ${networkInfo.usdcAddress}`);
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
console.log(' Run `taskmarket deposit` for network and deposit instructions.');
|
|
97
|
+
}
|
|
61
98
|
}
|
|
62
99
|
else {
|
|
63
|
-
printResult({ address, agentId }, human);
|
|
100
|
+
printResult({ address, agentId, network: networkInfo?.networkName, chainId: networkInfo?.chainId }, human);
|
|
64
101
|
}
|
|
65
102
|
});
|
|
66
103
|
//# sourceMappingURL=init.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/commands/init.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EACL,eAAe,EACf,iBAAiB,EACjB,YAAY,EACZ,cAAc,EACd,eAAe,EACf,YAAY,GACb,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/commands/init.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
import { loadKeystore } from '../../lib/keystore.js';
|
|
3
|
+
import { apiPost } from '../../lib/api.js';
|
|
4
|
+
import { isHumanMode, printError } from '../../lib/output.js';
|
|
5
|
+
import { writeFileSync } from 'fs';
|
|
6
|
+
export const downloadCmd = new Command('download')
|
|
7
|
+
.description('Download a submission file (requester or worker)')
|
|
8
|
+
.argument('<taskId>', 'Task ID (0x-prefixed hex)')
|
|
9
|
+
.requiredOption('--submission <id>', 'Submission ID (from `task submissions`)')
|
|
10
|
+
.option('--output <path>', 'Save to file instead of printing to stdout')
|
|
11
|
+
.option('--human', 'Human-readable output')
|
|
12
|
+
.action(async (taskId, opts) => {
|
|
13
|
+
const human = isHumanMode(opts.human);
|
|
14
|
+
const keystore = await loadKeystore();
|
|
15
|
+
let presignedUrl;
|
|
16
|
+
try {
|
|
17
|
+
const result = (await apiPost(`/api/tasks/${taskId}/submissions/${opts.submission}/preview`, {
|
|
18
|
+
taskId,
|
|
19
|
+
submissionId: opts.submission,
|
|
20
|
+
deviceId: keystore.deviceId,
|
|
21
|
+
apiToken: keystore.apiToken,
|
|
22
|
+
}));
|
|
23
|
+
presignedUrl = result.presignedUrl;
|
|
24
|
+
}
|
|
25
|
+
catch (err) {
|
|
26
|
+
const msg = err instanceof Error ? err.message : 'Failed to get download URL.';
|
|
27
|
+
printError(msg, human);
|
|
28
|
+
}
|
|
29
|
+
const res = await fetch(presignedUrl);
|
|
30
|
+
if (!res.ok) {
|
|
31
|
+
printError(`Failed to download file: ${res.status}`, human);
|
|
32
|
+
}
|
|
33
|
+
const content = await res.text();
|
|
34
|
+
if (opts.output) {
|
|
35
|
+
writeFileSync(opts.output, content, 'utf8');
|
|
36
|
+
if (human) {
|
|
37
|
+
console.log(`Saved to ${opts.output}`);
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
process.stdout.write(JSON.stringify({ ok: true, data: { savedTo: opts.output } }) + '\n');
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
process.stdout.write(content);
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
//# sourceMappingURL=download.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"download.js","sourceRoot":"","sources":["../../../src/commands/task/download.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAC3C,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC9D,OAAO,EAAE,aAAa,EAAE,MAAM,IAAI,CAAC;AAEnC,MAAM,CAAC,MAAM,WAAW,GAAG,IAAI,OAAO,CAAC,UAAU,CAAC;KAC/C,WAAW,CAAC,kDAAkD,CAAC;KAC/D,QAAQ,CAAC,UAAU,EAAE,2BAA2B,CAAC;KACjD,cAAc,CAAC,mBAAmB,EAAE,yCAAyC,CAAC;KAC9E,MAAM,CAAC,iBAAiB,EAAE,4CAA4C,CAAC;KACvE,MAAM,CAAC,SAAS,EAAE,uBAAuB,CAAC;KAC1C,MAAM,CACL,KAAK,EAAE,MAAc,EAAE,IAA8D,EAAE,EAAE;IACvF,MAAM,KAAK,GAAG,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAEtC,MAAM,QAAQ,GAAG,MAAM,YAAY,EAAE,CAAC;IAEtC,IAAI,YAAoB,CAAC;IACzB,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,CAAC,MAAM,OAAO,CAC3B,cAAc,MAAM,gBAAgB,IAAI,CAAC,UAAU,UAAU,EAC7D;YACE,MAAM;YACN,YAAY,EAAE,IAAI,CAAC,UAAU;YAC7B,QAAQ,EAAE,QAAQ,CAAC,QAAQ;YAC3B,QAAQ,EAAE,QAAQ,CAAC,QAAQ;SAC5B,CACF,CAA6B,CAAC;QAC/B,YAAY,GAAG,MAAM,CAAC,YAAY,CAAC;IACrC,CAAC;IAAC,OAAO,GAAY,EAAE,CAAC;QACtB,MAAM,GAAG,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,6BAA6B,CAAC;QAC/E,UAAU,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IACzB,CAAC;IAED,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,YAAa,CAAC,CAAC;IACvC,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;QACZ,UAAU,CAAC,4BAA4B,GAAG,CAAC,MAAM,EAAE,EAAE,KAAK,CAAC,CAAC;IAC9D,CAAC;IACD,MAAM,OAAO,GAAG,MAAM,GAAG,CAAC,IAAI,EAAE,CAAC;IAEjC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;QAC5C,IAAI,KAAK,EAAE,CAAC;YACV,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QACzC,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC;QAC5F,CAAC;IACH,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC;AACH,CAAC,CACF,CAAC"}
|
|
@@ -10,6 +10,9 @@ import { pitchCmd } from './pitch.js';
|
|
|
10
10
|
import { selectWorkerCmd } from './select-worker.js';
|
|
11
11
|
import { proofCmd } from './proof.js';
|
|
12
12
|
import { bidCmd } from './bid.js';
|
|
13
|
+
import { submissionsCmd } from './submissions.js';
|
|
14
|
+
import { selectWinnerCmd } from './select-winner.js';
|
|
15
|
+
import { downloadCmd } from './download.js';
|
|
13
16
|
export const taskCommand = new Command('task').description('Manage tasks');
|
|
14
17
|
taskCommand.addCommand(createCmd);
|
|
15
18
|
taskCommand.addCommand(listCmd);
|
|
@@ -22,4 +25,7 @@ taskCommand.addCommand(pitchCmd);
|
|
|
22
25
|
taskCommand.addCommand(selectWorkerCmd);
|
|
23
26
|
taskCommand.addCommand(proofCmd);
|
|
24
27
|
taskCommand.addCommand(bidCmd);
|
|
28
|
+
taskCommand.addCommand(submissionsCmd);
|
|
29
|
+
taskCommand.addCommand(selectWinnerCmd);
|
|
30
|
+
taskCommand.addCommand(downloadCmd);
|
|
25
31
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/commands/task/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AACtC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/commands/task/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AACtC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C,MAAM,CAAC,MAAM,WAAW,GAAG,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;AAE3E,WAAW,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;AAClC,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;AAChC,WAAW,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAC/B,WAAW,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;AAClC,WAAW,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;AAClC,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;AAChC,WAAW,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;AACjC,WAAW,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;AACjC,WAAW,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;AACxC,WAAW,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;AACjC,WAAW,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAC/B,WAAW,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;AACvC,WAAW,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;AACxC,WAAW,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
import { apiPost } from '../../lib/api.js';
|
|
3
|
+
import { isHumanMode, printResult, printError } from '../../lib/output.js';
|
|
4
|
+
export const selectWinnerCmd = new Command('select-winner')
|
|
5
|
+
.description('Select lowest bidder after auction deadline (requester only)')
|
|
6
|
+
.argument('<taskId>', 'Task ID (0x-prefixed hex)')
|
|
7
|
+
.option('--human', 'Human-readable output')
|
|
8
|
+
.action(async (taskId, opts) => {
|
|
9
|
+
const human = isHumanMode(opts.human);
|
|
10
|
+
let result;
|
|
11
|
+
try {
|
|
12
|
+
result = (await apiPost(`/api/tasks/${taskId}/bids/select-winner`, {
|
|
13
|
+
taskId,
|
|
14
|
+
}));
|
|
15
|
+
}
|
|
16
|
+
catch (err) {
|
|
17
|
+
const msg = err instanceof Error ? err.message : 'Failed to select winner.';
|
|
18
|
+
printError(msg, human);
|
|
19
|
+
}
|
|
20
|
+
if (human) {
|
|
21
|
+
console.log('Winner selected:', result.workerAddress);
|
|
22
|
+
console.log('');
|
|
23
|
+
console.log(`Next: taskmarket task accept ${taskId} --worker ${result.workerAddress}`);
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
printResult(result, human);
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
//# sourceMappingURL=select-winner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"select-winner.js","sourceRoot":"","sources":["../../../src/commands/task/select-winner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAC3C,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAE3E,MAAM,CAAC,MAAM,eAAe,GAAG,IAAI,OAAO,CAAC,eAAe,CAAC;KACxD,WAAW,CAAC,8DAA8D,CAAC;KAC3E,QAAQ,CAAC,UAAU,EAAE,2BAA2B,CAAC;KACjD,MAAM,CAAC,SAAS,EAAE,uBAAuB,CAAC;KAC1C,MAAM,CAAC,KAAK,EAAE,MAAc,EAAE,IAAyB,EAAE,EAAE;IAC1D,MAAM,KAAK,GAAG,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAEtC,IAAI,MAAmD,CAAC;IACxD,IAAI,CAAC;QACH,MAAM,GAAG,CAAC,MAAM,OAAO,CAAC,cAAc,MAAM,qBAAqB,EAAE;YACjE,MAAM;SACP,CAAC,CAAkB,CAAC;IACvB,CAAC;IAAC,OAAO,GAAY,EAAE,CAAC;QACtB,MAAM,GAAG,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,0BAA0B,CAAC;QAC5E,UAAU,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IACzB,CAAC;IAED,IAAI,KAAK,EAAE,CAAC;QACV,OAAO,CAAC,GAAG,CAAC,kBAAkB,EAAE,MAAO,CAAC,aAAa,CAAC,CAAC;QACvD,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAChB,OAAO,CAAC,GAAG,CAAC,gCAAgC,MAAM,aAAa,MAAO,CAAC,aAAa,EAAE,CAAC,CAAC;IAC1F,CAAC;SAAM,CAAC;QACN,WAAW,CAAC,MAAO,EAAE,KAAK,CAAC,CAAC;IAC9B,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
import { apiGet } from '../../lib/api.js';
|
|
3
|
+
import { isHumanMode, printResult, printError } from '../../lib/output.js';
|
|
4
|
+
export const submissionsCmd = new Command('submissions')
|
|
5
|
+
.description('List submissions for a task')
|
|
6
|
+
.argument('<taskId>', 'Task ID (0x-prefixed hex)')
|
|
7
|
+
.option('--human', 'Human-readable output')
|
|
8
|
+
.action(async (taskId, opts) => {
|
|
9
|
+
const human = isHumanMode(opts.human);
|
|
10
|
+
let subs;
|
|
11
|
+
try {
|
|
12
|
+
subs = (await apiGet(`/api/tasks/${taskId}/submissions`));
|
|
13
|
+
}
|
|
14
|
+
catch (err) {
|
|
15
|
+
const msg = err instanceof Error ? err.message : 'Failed to fetch submissions.';
|
|
16
|
+
printError(msg, human);
|
|
17
|
+
}
|
|
18
|
+
if (!human) {
|
|
19
|
+
printResult(subs, human);
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
if (subs.length === 0) {
|
|
23
|
+
console.log('No submissions yet.');
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
console.log(`Found ${subs.length} submission(s):\n`);
|
|
27
|
+
for (const s of subs) {
|
|
28
|
+
console.log(` ID: ${s.id}`);
|
|
29
|
+
const agentSuffix = s.workerAgentId ? ` (agent ${s.workerAgentId})` : '';
|
|
30
|
+
console.log(` Worker: ${s.workerAddress}${agentSuffix}`);
|
|
31
|
+
console.log(` File: ${s.fileUrl}`);
|
|
32
|
+
console.log(` At: ${s.submittedAt}`);
|
|
33
|
+
if (s.workerStats.ratedTasks > 0) {
|
|
34
|
+
const avg = s.workerStats.averageRating.toFixed(1);
|
|
35
|
+
console.log(` Rating: ${avg} (${s.workerStats.ratedTasks} rated tasks)`);
|
|
36
|
+
}
|
|
37
|
+
console.log('');
|
|
38
|
+
}
|
|
39
|
+
console.log(`To accept: taskmarket task accept ${taskId} --worker <address>`);
|
|
40
|
+
});
|
|
41
|
+
//# sourceMappingURL=submissions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"submissions.js","sourceRoot":"","sources":["../../../src/commands/task/submissions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC1C,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAiB3E,MAAM,CAAC,MAAM,cAAc,GAAG,IAAI,OAAO,CAAC,aAAa,CAAC;KACrD,WAAW,CAAC,6BAA6B,CAAC;KAC1C,QAAQ,CAAC,UAAU,EAAE,2BAA2B,CAAC;KACjD,MAAM,CAAC,SAAS,EAAE,uBAAuB,CAAC;KAC1C,MAAM,CAAC,KAAK,EAAE,MAAc,EAAE,IAAyB,EAAE,EAAE;IAC1D,MAAM,KAAK,GAAG,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAEtC,IAAI,IAAkB,CAAC;IACvB,IAAI,CAAC;QACH,IAAI,GAAG,CAAC,MAAM,MAAM,CAAC,cAAc,MAAM,cAAc,CAAC,CAAiB,CAAC;IAC5E,CAAC;IAAC,OAAO,GAAY,EAAE,CAAC;QACtB,MAAM,GAAG,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,8BAA8B,CAAC;QAChF,UAAU,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IACzB,CAAC;IAED,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,WAAW,CAAC,IAAK,EAAE,KAAK,CAAC,CAAC;QAC1B,OAAO;IACT,CAAC;IAED,IAAI,IAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACvB,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;QACnC,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,SAAS,IAAK,CAAC,MAAM,mBAAmB,CAAC,CAAC;IACtD,KAAK,MAAM,CAAC,IAAI,IAAK,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAClC,MAAM,WAAW,GAAG,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;QACzE,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,aAAa,GAAG,WAAW,EAAE,CAAC,CAAC;QAC3D,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;QACvC,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;QAC3C,IAAI,CAAC,CAAC,WAAW,CAAC,UAAU,GAAG,CAAC,EAAE,CAAC;YACjC,MAAM,GAAG,GAAG,CAAC,CAAC,WAAW,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YACnD,OAAO,CAAC,GAAG,CAAC,cAAc,GAAG,KAAK,CAAC,CAAC,WAAW,CAAC,UAAU,eAAe,CAAC,CAAC;QAC7E,CAAC;QACD,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAClB,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,qCAAqC,MAAM,qBAAqB,CAAC,CAAC;AAChF,CAAC,CAAC,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@lucid-agents/taskmarket",
|
|
3
|
-
"version": "0.5.
|
|
3
|
+
"version": "0.5.2",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"bin": {
|
|
6
6
|
"taskmarket": "./dist/index.js"
|
|
@@ -15,8 +15,8 @@
|
|
|
15
15
|
"tsx": "^4.7.0",
|
|
16
16
|
"typescript": "^5.3.3",
|
|
17
17
|
"vitest": "^2.0.0",
|
|
18
|
-
"@taskmarket/
|
|
19
|
-
"@taskmarket/
|
|
18
|
+
"@taskmarket/prettier-config": "0.0.0",
|
|
19
|
+
"@taskmarket/eslint-config": "0.0.0"
|
|
20
20
|
},
|
|
21
21
|
"files": [
|
|
22
22
|
"dist"
|