-
Notifications
You must be signed in to change notification settings - Fork 1
/
swagger.ts
76 lines (73 loc) · 1.89 KB
/
swagger.ts
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
const swaggerAutogen = require('swagger-autogen')();
const doc = {
info: {
version: '1.0.0',
title: 'Anonymizer Backend API',
description:
'Documentation automatically generated by the <b>swagger-autogen</b> module.',
},
host: 'localhost:5001',
basePath: '/',
schemes: ['http', 'https'],
consumes: ['application/json'],
produces: ['application/json'],
tags: [
{
name: 'Data Anonymizer APIs',
description:
'These endpoints are used to anonymize personal data across databases and tables based on provided config json file.',
},
],
components: {
schemas: {
Config: {
"type": "object",
"properties": {
"tables": {
"type": "array",
"items": {
"type": "object",
"properties": {
"table_name": {
"type": "string"
},
"primary_key": {
"type": "string"
},
"foreign_key": {
"type": "string"
},
"columns": {
"type": "array",
"items": {
"type": "object",
"properties": {
"name": {
"type": "string"
},
"type": {
"type": "string"
}
},
"required": []
}
}
},
"required": [
"table_name",
"foreign_key",
"columns"
]
}
}
},
"required": [
"tables"
]
}
}
}
};
const outputFile = 'build/swagger.json';
const endpointsFiles = ['src/app.ts'];
swaggerAutogen(outputFile, endpointsFiles, doc);