-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathconfig.js
178 lines (172 loc) · 9.27 KB
/
config.js
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
/*
* Copyright 2015 Telefónica Investigación y Desarrollo, S.A.U
*
* This file is part of the Short Time Historic (STH) component
*
* STH is free software: you can redistribute it and/or
* modify it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the License,
* or (at your option) any later version.
*
* STH is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public
* License along with STH.
* If not, see http://www.gnu.org/licenses/.
*
* For those usages not covered by the GNU Affero General Public License
* please contact with: [[email protected]]
*/
const config = {};
// STH server configuration
//--------------------------
config.server = {
// The host where the STH server will be started.
// Default value: "localhost".
host: 'localhost',
// The port where the STH server will be listening.
// Default value: "8666".
port: '8666',
// The service to be used if not sent by the Orion Context Broker in the notifications.
// Default value: "testservice".
defaultService: 'testservice',
// The service path to be used if not sent by the Orion Context Broker in the notifications.
// Default value: "/testservicepath".
defaultServicePath: '/testservicepath',
// A flag indicating if the empty results should be removed from the response.
// Default value: "true".
filterOutEmpty: 'true',
// Array of resolutions the STH component should aggregate values for.
// Valid resolution values are: 'month', 'day', 'hour', 'minute' and 'second'
aggregationBy: ['day', 'hour', 'minute'],
// Directory where temporary files will be stored, such as the ones generated when CSV files are requested.
// Default value: "temp".
temporalDir: 'temp',
// Max page size returned by a query
maxPageSize: '100'
};
// Cors Configuration
config.cors = {
// The enabled is use to set CORS policy
enabled: 'false',
options: {
origin: ['*'],
headers: [
'Access-Control-Allow-Origin',
'Access-Control-Allow-Headers',
'Access-Control-Request-Headers',
'Origin, Referer, User-Agent'
],
additionalHeaders: ['fiware-servicepath', 'fiware-service'],
credentials: 'true'
}
};
// Database configuration
//------------------------
config.database = {
// The STH component supports 3 alternative models when storing the raw and aggregated data
// into the database: 1) one collection per attribute, 2) one collection per entity and
// 3) one collection per service path. The possible values are: "collection-per-attribute",
// "collection-per-entity" and "collection-per-service-path" respectively. Default value:
// "collection-per-entity".
dataModel: 'collection-per-entity',
// The username to use for the database connection. Default value: "".
user: '',
// The password to use for the database connection. Default value: "".
password: '',
// The auth source to use for the database connection. Default value: "".
authSource: '',
// The URI to use for the database connection. It supports replica set URIs. This does not
// include the "mongo://" protocol part. Default value: "localhost:27017"
URI: 'localhost:27017',
// The name of the replica set to connect to, if any. Default value: "".
replicaSet: '',
// The prefix to be added to the service for the creation of the databases. Default value: "sth".
prefix: 'sth_',
// The prefix to be added to the collections in the databases. More information below.
// Default value: "sth_".
collectionPrefix: 'sth_',
// The default MongoDB pool size of database connections. Optional. Default value: "5".
poolSize: '5',
// The write concern (see http://docs.mongodb.org/manual/core/write-concern/) to apply when
// writing data to the MongoDB database. Default value: "1".
writeConcern: '1',
// Flag indicating if the raw and/or aggregated data should be persisted. Valid values are:
// "only-raw", "only-aggregated" and "both". Default value: "both".
shouldStore: 'both',
truncation: {
// Data from the raw and aggregated data collections will be removed if older than the value specified in seconds.
// Set the value to 0 or remove the property entry not to apply this time-based truncation policy.
// Default value: "0".
expireAfterSeconds: '0',
// The oldest raw data (according to insertion time) will be removed if the size of the raw data collection
// gets bigger than the value specified in bytes. In case of raw data the reference time is the one stored in the
// 'recvTime' property whereas in the case of the aggregated data the reference of time is the one stored in the
// '_id.origin' property. Set the value to 0 or remove the property entry not to apply this truncation policy.
// Default value: "0".
// The "size" configuration parameter is mandatory in case size collection truncation is desired as required by
// MongoDB.
// Notice that this configuration parameter does not affect the aggregated data collections since MongoDB does not
// currently support updating documents in capped collections which increase the size of the documents.
// Notice also that in case of the raw data, the size-based truncation policy takes precedence over the TTL one.
// More concretely, if "size" is set, the value of "exporeAfterSeconds" is ignored for the raw data collections
// since currently MongoDB does not support TTL in capped collections.
size: '0',
// The oldest raw data (according to insertion time) will be removed if the number of documents in the raw data
// collections goes beyond the specified value. Set the value to 0 or remove the property entry not to apply this
// truncation policy. Default value: "0".
// Notice that this configuration parameter does not affect the aggregated data collections since MongoDB does not
// currently support updating documents in capped collections which increase the size of the documents.
max: '0'
},
// Attribute values to one or more blank spaces should be ignored and not processed either as raw data or for
// the aggregated computations. Default value: "true".
ignoreBlankSpaces: 'true',
// Database and collection names have to respect the limitations imposed by MongoDB (see
// https://docs.mongodb.com/manual/reference/limits/). To it, the STH provides 2 main mechanisms: mappings and
// encoding which can be configured using the next 2 configuration parameters.
// The mappings mechanism will substitute the original services, service paths, entity and attribute names and types
// by the ones defined in the configuration file. If enabled, the mappings mechanism will be the one applied.
nameMapping: {
// Default value: "true" (although we will set it to false until the Cygnus counterpart is ready and landed)
enabled: 'false',
// The path from the root of the STH component Node application to the mappings configuration file
configFile: './name-mapping.json'
},
// The encoding criteria is the following one:
// 1. Encode the forbidden characters using an escaping character (x) and a numerical Unicode code for each character.
// For instance, the / character will be encoded as x002f.
// 2. Database and collection names already using the above encoding must be escaped prepending another x,
// for instance, the text x002a will be encoded as xx002a.
// 3. The uppercase characters included in database names will be encoded using the mechanism stated in 1.
// 4. Collection names starting with 'system.' will be encoded as 'xsystem.'. For instance, system.myData will be
// encoded as xsystem.myData.
// Default value: "true" (although we will set it to false until the Cygnus counterpart is ready and landed)
nameEncoding: 'false',
// Server attempt to reconnect #times
reconnectTries: 30,
// Server will wait # milliseconds between retries.
reconnectInterval: 1000
};
// Logging configuration
//------------------------
config.logging = {
// The logging level of the messages. Messages with a level equal or superior to this will be logged.
// Accepted values are: "debug", "info", "warn" and "error". Default value: "info".
level: 'info',
// The logging format:
// - "json": writes logs as JSON.
// - "dev": for development. Used as the 'de-facto' value when the NODE_ENV variable is set to 'development'.
// - "pipe": writes logs separating the fields with pipes.
format: 'pipe',
// The time in seconds between proof of life logging messages informing that the server is up and running normally.
// Default value: "60"
proofOfLifeInterval: '60',
// The time in seconds between processed requests statistics appear in the logs
// Default value: "60"
processedRequestLogStatisticsInterval: '60'
};
module.exports = config;