Close #1820 Squashed commit of the following: commit 5aadec2e6e126588313ff006d6f95223ba19a526 Merge: a4db6b4295f41285Author: ArtemBaskal <a.baskal@adguard.com> Date: Wed Jul 15 11:15:31 2020 +0300 Merge branch 'master' into fix/1820 commit a4db6b42ab9cbf43d96c783a72a99e0a2c594108 Author: ArtemBaskal <a.baskal@adguard.com> Date: Tue Jul 14 19:08:09 2020 +0300 Remove textarea comma splitting commit bb34797aac6602b405941dbd90fe6a81b663bb92 Author: ArtemBaskal <a.baskal@adguard.com> Date: Tue Jul 14 18:21:18 2020 +0300 Fix client Access settings normalization commit ac4fb536514f54c5722077d78dbbd981c4e906a8 Merge: 0c758ddcb9fca8d0Author: ArtemBaskal <a.baskal@adguard.com> Date: Tue Jul 14 18:14:38 2020 +0300 Merge branch 'master' into fix/1820 commit 0c758ddcd738136b92e6f947a8068ecc59f7ec25 Merge: 15650db3f5a1f311Author: ArtemBaskal <a.baskal@adguard.com> Date: Fri Jul 3 11:22:00 2020 +0300 Merge branch 'master' into fix/1820 commit 15650db35323009001fd427a74a312705b54ac86 Author: ArtemBaskal <a.baskal@adguard.com> Date: Mon Jun 29 12:01:51 2020 +0300 '- client: Don't normalise disallowed domains'
55 lines
1.9 KiB
JavaScript
55 lines
1.9 KiB
JavaScript
import { createAction } from 'redux-actions';
|
|
|
|
import apiClient from '../api/Api';
|
|
import { splitByNewLine } from '../helpers/helpers';
|
|
import { addErrorToast, addSuccessToast } from './toasts';
|
|
|
|
export const getDnsConfigRequest = createAction('GET_DNS_CONFIG_REQUEST');
|
|
export const getDnsConfigFailure = createAction('GET_DNS_CONFIG_FAILURE');
|
|
export const getDnsConfigSuccess = createAction('GET_DNS_CONFIG_SUCCESS');
|
|
|
|
export const getDnsConfig = () => async (dispatch) => {
|
|
dispatch(getDnsConfigRequest());
|
|
try {
|
|
const data = await apiClient.getDnsConfig();
|
|
dispatch(getDnsConfigSuccess(data));
|
|
} catch (error) {
|
|
dispatch(addErrorToast({ error }));
|
|
dispatch(getDnsConfigFailure());
|
|
}
|
|
};
|
|
|
|
export const setDnsConfigRequest = createAction('SET_DNS_CONFIG_REQUEST');
|
|
export const setDnsConfigFailure = createAction('SET_DNS_CONFIG_FAILURE');
|
|
export const setDnsConfigSuccess = createAction('SET_DNS_CONFIG_SUCCESS');
|
|
|
|
export const setDnsConfig = (config) => async (dispatch) => {
|
|
dispatch(setDnsConfigRequest());
|
|
try {
|
|
const data = { ...config };
|
|
|
|
let hasDnsSettings = false;
|
|
if (Object.prototype.hasOwnProperty.call(data, 'bootstrap_dns')) {
|
|
data.bootstrap_dns = splitByNewLine(config.bootstrap_dns);
|
|
hasDnsSettings = true;
|
|
}
|
|
if (Object.prototype.hasOwnProperty.call(data, 'upstream_dns')) {
|
|
data.upstream_dns = splitByNewLine(config.upstream_dns);
|
|
hasDnsSettings = true;
|
|
}
|
|
|
|
await apiClient.setDnsConfig(data);
|
|
|
|
if (hasDnsSettings) {
|
|
dispatch(addSuccessToast('updated_upstream_dns_toast'));
|
|
} else {
|
|
dispatch(addSuccessToast('config_successfully_saved'));
|
|
}
|
|
|
|
dispatch(setDnsConfigSuccess(config));
|
|
} catch (error) {
|
|
dispatch(addErrorToast({ error }));
|
|
dispatch(setDnsConfigFailure());
|
|
}
|
|
};
|