1 | 'use strict';
|
---|
2 |
|
---|
3 | import {VERSION} from '../env/data.js';
|
---|
4 | import AxiosError from '../core/AxiosError.js';
|
---|
5 |
|
---|
6 | const validators = {};
|
---|
7 |
|
---|
8 | // eslint-disable-next-line func-names
|
---|
9 | ['object', 'boolean', 'number', 'function', 'string', 'symbol'].forEach((type, i) => {
|
---|
10 | validators[type] = function validator(thing) {
|
---|
11 | return typeof thing === type || 'a' + (i < 1 ? 'n ' : ' ') + type;
|
---|
12 | };
|
---|
13 | });
|
---|
14 |
|
---|
15 | const deprecatedWarnings = {};
|
---|
16 |
|
---|
17 | /**
|
---|
18 | * Transitional option validator
|
---|
19 | *
|
---|
20 | * @param {function|boolean?} validator - set to false if the transitional option has been removed
|
---|
21 | * @param {string?} version - deprecated version / removed since version
|
---|
22 | * @param {string?} message - some message with additional info
|
---|
23 | *
|
---|
24 | * @returns {function}
|
---|
25 | */
|
---|
26 | validators.transitional = function transitional(validator, version, message) {
|
---|
27 | function formatMessage(opt, desc) {
|
---|
28 | return '[Axios v' + VERSION + '] Transitional option \'' + opt + '\'' + desc + (message ? '. ' + message : '');
|
---|
29 | }
|
---|
30 |
|
---|
31 | // eslint-disable-next-line func-names
|
---|
32 | return (value, opt, opts) => {
|
---|
33 | if (validator === false) {
|
---|
34 | throw new AxiosError(
|
---|
35 | formatMessage(opt, ' has been removed' + (version ? ' in ' + version : '')),
|
---|
36 | AxiosError.ERR_DEPRECATED
|
---|
37 | );
|
---|
38 | }
|
---|
39 |
|
---|
40 | if (version && !deprecatedWarnings[opt]) {
|
---|
41 | deprecatedWarnings[opt] = true;
|
---|
42 | // eslint-disable-next-line no-console
|
---|
43 | console.warn(
|
---|
44 | formatMessage(
|
---|
45 | opt,
|
---|
46 | ' has been deprecated since v' + version + ' and will be removed in the near future'
|
---|
47 | )
|
---|
48 | );
|
---|
49 | }
|
---|
50 |
|
---|
51 | return validator ? validator(value, opt, opts) : true;
|
---|
52 | };
|
---|
53 | };
|
---|
54 |
|
---|
55 | validators.spelling = function spelling(correctSpelling) {
|
---|
56 | return (value, opt) => {
|
---|
57 | // eslint-disable-next-line no-console
|
---|
58 | console.warn(`${opt} is likely a misspelling of ${correctSpelling}`);
|
---|
59 | return true;
|
---|
60 | }
|
---|
61 | };
|
---|
62 |
|
---|
63 | /**
|
---|
64 | * Assert object's properties type
|
---|
65 | *
|
---|
66 | * @param {object} options
|
---|
67 | * @param {object} schema
|
---|
68 | * @param {boolean?} allowUnknown
|
---|
69 | *
|
---|
70 | * @returns {object}
|
---|
71 | */
|
---|
72 |
|
---|
73 | function assertOptions(options, schema, allowUnknown) {
|
---|
74 | if (typeof options !== 'object') {
|
---|
75 | throw new AxiosError('options must be an object', AxiosError.ERR_BAD_OPTION_VALUE);
|
---|
76 | }
|
---|
77 | const keys = Object.keys(options);
|
---|
78 | let i = keys.length;
|
---|
79 | while (i-- > 0) {
|
---|
80 | const opt = keys[i];
|
---|
81 | const validator = schema[opt];
|
---|
82 | if (validator) {
|
---|
83 | const value = options[opt];
|
---|
84 | const result = value === undefined || validator(value, opt, options);
|
---|
85 | if (result !== true) {
|
---|
86 | throw new AxiosError('option ' + opt + ' must be ' + result, AxiosError.ERR_BAD_OPTION_VALUE);
|
---|
87 | }
|
---|
88 | continue;
|
---|
89 | }
|
---|
90 | if (allowUnknown !== true) {
|
---|
91 | throw new AxiosError('Unknown option ' + opt, AxiosError.ERR_BAD_OPTION);
|
---|
92 | }
|
---|
93 | }
|
---|
94 | }
|
---|
95 |
|
---|
96 | export default {
|
---|
97 | assertOptions,
|
---|
98 | validators
|
---|
99 | };
|
---|