-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathopenapi.yaml
More file actions
480 lines (462 loc) · 11.3 KB
/
Copy pathopenapi.yaml
File metadata and controls
480 lines (462 loc) · 11.3 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
openapi: "3.0.3"
info:
title: FollowEngine API
description: >
FollowEngine is a competitor growth intelligence platform. This API provides
programmatic access to competitor monitoring, signal detection, AI-generated
briefs, and webhook management.
Base URL: `https://api.followengine.com/v1`
Get your API key at [followengine.com](https://followengine.com).
version: "1.0.0"
contact:
name: FollowEngine API Support
url: https://followengine.com
email: api@followengine.com
license:
name: Proprietary
url: https://followengine.com/terms
servers:
- url: https://api.followengine.com/v1
description: Production
tags:
- name: Competitors
description: Manage monitored competitors
- name: Signals
description: Competitor signal detection
- name: Briefs
description: AI-generated strategy briefs
- name: Webhooks
description: Real-time event subscriptions
paths:
/competitors:
get:
tags: [Competitors]
summary: List competitors
description: Returns all competitors being monitored by your account.
parameters:
- name: status
in: query
schema:
type: string
enum: [active, paused, error]
- name: limit
in: query
schema:
type: integer
default: 20
maximum: 100
- name: cursor
in: query
schema:
type: string
responses:
"200":
description: OK
content:
application/json:
schema:
type: object
properties:
competitors:
type: array
items:
$ref: "#/components/schemas/Competitor"
total:
type: integer
has_more:
type: boolean
next_cursor:
type: string
post:
tags: [Competitors]
summary: Add competitor
description: Start monitoring a new competitor.
requestBody:
required: true
content:
application/json:
schema:
type: object
required: [domain]
properties:
domain:
type: string
example: "competitor.com"
name:
type: string
example: "Competitor Inc"
channels:
type: array
items:
type: string
enum: [google_ads, meta_ads, tiktok_ads, youtube, tiktok, search, web]
example: ["google_ads", "search"]
tags:
type: array
items:
type: string
responses:
"201":
description: Created
content:
application/json:
schema:
$ref: "#/components/schemas/Competitor"
/competitors/{id}:
get:
tags: [Competitors]
summary: Get competitor
parameters:
- name: id
in: path
required: true
schema:
type: string
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/Competitor"
patch:
tags: [Competitors]
summary: Update competitor
parameters:
- name: id
in: path
required: true
schema:
type: string
requestBody:
content:
application/json:
schema:
type: object
properties:
name:
type: string
channels:
type: array
items:
type: string
status:
type: string
enum: [active, paused]
tags:
type: array
items:
type: string
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/Competitor"
delete:
tags: [Competitors]
summary: Remove competitor
parameters:
- name: id
in: path
required: true
schema:
type: string
responses:
"204":
description: Deleted
/competitors/{id}/signals:
get:
tags: [Signals]
summary: Competitor signals
parameters:
- name: id
in: path
required: true
schema:
type: string
- name: channel
in: query
schema:
type: string
- name: severity
in: query
schema:
type: string
enum: [low, medium, high, critical]
- name: since
in: query
schema:
type: string
format: date-time
- name: limit
in: query
schema:
type: integer
default: 20
responses:
"200":
description: OK
content:
application/json:
schema:
type: object
properties:
signals:
type: array
items:
$ref: "#/components/schemas/Signal"
/signals:
get:
tags: [Signals]
summary: All signals
parameters:
- name: severity
in: query
schema:
type: string
enum: [low, medium, high, critical]
- name: since
in: query
schema:
type: string
format: date-time
- name: limit
in: query
schema:
type: integer
default: 20
responses:
"200":
description: OK
/signals/{id}:
get:
tags: [Signals]
summary: Signal details
parameters:
- name: id
in: path
required: true
schema:
type: string
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/Signal"
/briefs:
get:
tags: [Briefs]
summary: List briefs
parameters:
- name: competitor_id
in: query
schema:
type: string
- name: limit
in: query
schema:
type: integer
default: 10
responses:
"200":
description: OK
content:
application/json:
schema:
type: object
properties:
briefs:
type: array
items:
$ref: "#/components/schemas/Brief"
post:
tags: [Briefs]
summary: Generate brief
requestBody:
required: true
content:
application/json:
schema:
type: object
required: [competitor_id]
properties:
competitor_id:
type: string
period:
type: string
enum: [last_7_days, last_30_days, last_quarter]
default: last_7_days
channels:
type: array
items:
type: string
responses:
"202":
description: Generation started
/briefs/{id}:
get:
tags: [Briefs]
summary: Get brief
parameters:
- name: id
in: path
required: true
schema:
type: string
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/Brief"
/webhooks:
get:
tags: [Webhooks]
summary: List webhooks
responses:
"200":
description: OK
post:
tags: [Webhooks]
summary: Create webhook
requestBody:
required: true
content:
application/json:
schema:
type: object
required: [url, events]
properties:
url:
type: string
format: uri
events:
type: array
items:
type: string
enum: [signal.new, signal.escalated, competitor.added, competitor.status_changed, brief.generated]
secret:
type: string
responses:
"201":
description: Created
/webhooks/{id}:
delete:
tags: [Webhooks]
summary: Remove webhook
parameters:
- name: id
in: path
required: true
schema:
type: string
responses:
"204":
description: Deleted
components:
securitySchemes:
BearerAuth:
type: http
scheme: bearer
description: API key from https://followengine.com/dashboard/settings
schemas:
Competitor:
type: object
properties:
id:
type: string
example: "comp_01h2x3y4z5"
name:
type: string
example: "Acme Corp"
domain:
type: string
example: "acmecorp.com"
channels:
type: array
items:
type: string
example: ["google_ads", "meta_ads", "search"]
status:
type: string
enum: [active, paused, error]
tags:
type: array
items:
type: string
created_at:
type: string
format: date-time
last_signal_at:
type: string
format: date-time
Signal:
type: object
properties:
id:
type: string
example: "sig_01h2x4z5a6"
competitor_id:
type: string
competitor_name:
type: string
channel:
type: string
example: "google_ads"
type:
type: string
example: "new_creative"
title:
type: string
example: "Acme Corp launched a free trial angle"
description:
type: string
severity:
type: string
enum: [low, medium, high, critical]
change_pct:
type: number
example: 24
detected_at:
type: string
format: date-time
url:
type: string
format: uri
Brief:
type: object
properties:
id:
type: string
competitor_id:
type: string
period:
type: string
title:
type: string
summary:
type: string
what_changed:
type: array
items:
type: string
what_repeated:
type: array
items:
type: string
what_to_copy:
type: array
items:
type: string
signal_count:
type: integer
generated_at:
type: string
format: date-time
security:
- BearerAuth: []