fetchfox-sdk 1.0.24 → 1.0.26

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 CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "fetchfox-sdk",
3
- "version": "1.0.24",
3
+ "version": "1.0.26",
4
4
  "description": "AI scraper",
5
5
  "main": "src/index.js",
6
6
  "type": "module",
package/src/agent.js CHANGED
@@ -7,5 +7,5 @@ export async function agent(args) {
7
7
 
8
8
  agent.detach = async (args) => {
9
9
  const data = await call('POST', '/api/agent', { ...args, detach: true });
10
- return new Job(data.jobId, args);
10
+ return new Job(data.jobId, { ...args, name: 'agent' });
11
11
  };
package/src/crawl.js CHANGED
@@ -7,5 +7,5 @@ export async function crawl(args) {
7
7
 
8
8
  crawl.detach = async (args) => {
9
9
  const data = await call('POST', '/api/crawl', { ...args, detach: true });
10
- return new Job(data.jobId, args);
10
+ return new Job(data.jobId, { ...args, name: 'crawl' });
11
11
  };
package/src/detach.js CHANGED
@@ -11,27 +11,55 @@ export function getSocket() {}
11
11
  export const Job = class {
12
12
  #callbacks;
13
13
  #socket;
14
+ #socket2;
15
+ #socket3;
14
16
  #seen;
15
17
  #completed;
16
18
  #failed;
17
19
 
18
20
  constructor(id, options) {
19
21
  this.id = id;
22
+ this.name = options?.name;
20
23
  this.#callbacks = {
21
24
  item: [],
22
25
  completed: [],
23
26
  failed: [],
24
27
  finished: [],
25
28
  progress: [],
29
+
30
+ // new
31
+ update: [],
32
+ children: [],
26
33
  };
27
34
 
28
35
  this.#seen = {};
29
-
30
36
  this.#socket = new io(ws(options));
31
37
  this.#socket.on('progress', (data) => {
32
38
  this.handleProgress(data);
33
39
  });
34
40
  this.#socket.emit('sub', this.id);
41
+
42
+ this.#socket2 = new WebSocket(ws(options) + '/ws/jobs/' + id);
43
+ this.#socket2.onmessage = (data) => {
44
+ let parsed;
45
+ try {
46
+ parsed = JSON.parse(data.data);
47
+ } catch {
48
+ return;
49
+ }
50
+ this.trigger('update', parsed);
51
+ };
52
+
53
+ this.#socket3 = new WebSocket(ws(options) + '/ws/children/' + id);
54
+ this.#socket3.onmessage = (data) => {
55
+ let parsed;
56
+ try {
57
+ parsed = JSON.parse(data.data);
58
+ } catch {
59
+ return;
60
+ }
61
+ this.trigger('children', parsed);
62
+ };
35
63
  }
36
64
 
37
65
  get _finished() {
@@ -39,7 +67,9 @@ export const Job = class {
39
67
  }
40
68
 
41
69
  get appUrl() {
42
- return appHost() + '/jobs/' + this.id;
70
+ return [appHost(), this.name == 'agent' ? 'agents' : 'jobs', this.id].join(
71
+ '/'
72
+ );
43
73
  }
44
74
 
45
75
  #select(data) {
@@ -108,6 +138,8 @@ export const Job = class {
108
138
  }
109
139
 
110
140
  if (['completed', 'failed'].includes(this.state)) {
141
+ console.log('Got state:', this.state);
142
+
111
143
  if (this.progress?.children?.jobs) {
112
144
  this.progress.children.jobs = this.progress.children.jobs.filter(
113
145
  (it) => it.state != 'active'
@@ -116,13 +148,16 @@ export const Job = class {
116
148
 
117
149
  this.#socket.disconnect();
118
150
 
119
- this.get()
120
- .then(() => {
121
- this.trigger('progress', this);
122
- this.trigger(this.state, this);
123
- this.trigger('finished', this);
124
- })
125
- .catch((e) => console.error(e));
151
+ console.log('Set timeout before triggering completion');
152
+ setTimeout(() => {
153
+ this.get()
154
+ .then(() => {
155
+ this.trigger('progress', this);
156
+ this.trigger(this.state, this);
157
+ this.trigger('finished', this);
158
+ })
159
+ .catch((e) => console.error(e));
160
+ }, 500);
126
161
  }
127
162
  }
128
163
 
package/src/extract.js CHANGED
@@ -7,5 +7,5 @@ export async function extract(args) {
7
7
 
8
8
  extract.detach = async (args) => {
9
9
  const data = await call('POST', '/api/extract', { ...args, detach: true });
10
- return new Job(data.jobId, args);
10
+ return new Job(data.jobId, { ...args, name: 'extract' });
11
11
  };
package/src/scrape.js CHANGED
@@ -7,5 +7,5 @@ export async function scrape(args) {
7
7
 
8
8
  scrape.detach = async (args) => {
9
9
  const data = await call('POST', '/api/scrape', { ...args, detach: true });
10
- return new Job(data.jobId, args);
10
+ return new Job(data.jobId, { ...args, name: 'scrape' });
11
11
  };
package/src/visit.js CHANGED
@@ -7,5 +7,5 @@ export async function visit(args) {
7
7
 
8
8
  visit.detach = async (args) => {
9
9
  const data = await call('POST', '/api/visit', { ...args, detach: true });
10
- return new Job(data.jobId, args);
10
+ return new Job(data.jobId, { ...args, name: 'visit' });
11
11
  };