-
Notifications
You must be signed in to change notification settings - Fork 86
Expand file tree
/
Copy pathindex.ts
More file actions
89 lines (83 loc) · 2.81 KB
/
index.ts
File metadata and controls
89 lines (83 loc) · 2.81 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
/**
* Copyright 2016, 2018-2020, 2022, Optimizely
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { ObjectWithUnknownProperties } from '../../shared_types';
import {
DATAFILE_VERSIONS,
} from '../enums';
import {
INVALID_CONFIG,
INVALID_DATAFILE_MALFORMED,
INVALID_DATAFILE_VERSION,
INVALID_ERROR_HANDLER,
INVALID_EVENT_DISPATCHER,
INVALID_LOGGER,
NO_DATAFILE_SPECIFIED,
} from 'error_message';
import { OptimizelyError } from '../../error/optimizly_error';
const SUPPORTED_VERSIONS = [DATAFILE_VERSIONS.V2, DATAFILE_VERSIONS.V3, DATAFILE_VERSIONS.V4];
/**
* Validates the given config options
* @param {unknown} config
* @param {object} config.errorHandler
* @param {object} config.eventDispatcher
* @param {object} config.logger
* @return {boolean} true if the config options are valid
* @throws If any of the config options are not valid
*/
export const validate = function(config: unknown): boolean {
if (typeof config === 'object' && config !== null) {
const configObj = config as ObjectWithUnknownProperties;
// TODO: add validation
return true;
}
throw new OptimizelyError(INVALID_CONFIG);
}
/**
* Validates the datafile
* @param {Object|string} datafile
* @return {Object} The datafile object if the datafile is valid
* @throws If the datafile is not valid for any of the following reasons:
- The datafile string is undefined
- The datafile string cannot be parsed as a JSON object
- The datafile version is not supported
*/
// eslint-disable-next-line
export const validateDatafile = function(datafile: unknown): any {
if (!datafile) {
throw new OptimizelyError(NO_DATAFILE_SPECIFIED);
}
if (typeof datafile === 'string') {
// Attempt to parse the datafile string
try {
datafile = JSON.parse(datafile);
} catch (ex) {
throw new OptimizelyError(INVALID_DATAFILE_MALFORMED);
}
}
if (typeof datafile === 'object' && !Array.isArray(datafile) && datafile !== null) {
if (SUPPORTED_VERSIONS.indexOf(datafile['version' as keyof unknown]) === -1) {
throw new OptimizelyError(INVALID_DATAFILE_VERSION, datafile['version' as keyof unknown]);
}
}
return datafile;
};
/**
* Provides utility methods for validating that the configuration options are valid
*/
export default {
validate: validate,
validateDatafile: validateDatafile,
}