Squashed commit of the following:
commit 0f96137c629d7df99d40e479f66dd78248185ca3
Merge: 0d640fe37 aac36a2d2
Author: Stanislav Chzhen <s.chzhen@adguard.com>
Date: Wed Aug 30 12:53:03 2023 +0300
Merge branch 'master' into 3701-fallback-dns-api
commit 0d640fe37a563d9fcea1ff4b6c86f37629af0ebd
Author: Stanislav Chzhen <s.chzhen@adguard.com>
Date: Wed Aug 30 12:49:05 2023 +0300
dnsforward: imp tests
commit 6b7f7aad76566b70852146bc6629ae7fb71eec09
Author: Ainar Garipov <A.Garipov@AdGuard.COM>
Date: Fri Aug 25 18:51:34 2023 +0300
client: add fallback dns field
commit c2ac7e3656431f7d44645786296e58ac7d012fed
Author: Stanislav Chzhen <s.chzhen@adguard.com>
Date: Thu Aug 24 13:22:07 2023 +0300
all: add fallback dns api
80 lines
2.9 KiB
JavaScript
80 lines
2.9 KiB
JavaScript
import { createAction } from 'redux-actions';
|
|
import i18next from 'i18next';
|
|
|
|
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 clearDnsCacheRequest = createAction('CLEAR_DNS_CACHE_REQUEST');
|
|
export const clearDnsCacheFailure = createAction('CLEAR_DNS_CACHE_FAILURE');
|
|
export const clearDnsCacheSuccess = createAction('CLEAR_DNS_CACHE_SUCCESS');
|
|
|
|
export const clearDnsCache = () => async (dispatch) => {
|
|
dispatch(clearDnsCacheRequest());
|
|
try {
|
|
const data = await apiClient.clearCache();
|
|
dispatch(clearDnsCacheSuccess(data));
|
|
dispatch(addSuccessToast(i18next.t('cache_cleared')));
|
|
} catch (error) {
|
|
dispatch(addErrorToast({ error }));
|
|
dispatch(clearDnsCacheFailure());
|
|
}
|
|
};
|
|
|
|
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, 'fallback_dns')) {
|
|
data.fallback_dns = splitByNewLine(config.fallback_dns);
|
|
hasDnsSettings = true;
|
|
}
|
|
if (Object.prototype.hasOwnProperty.call(data, 'local_ptr_upstreams')) {
|
|
data.local_ptr_upstreams = splitByNewLine(config.local_ptr_upstreams);
|
|
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());
|
|
}
|
|
};
|