badguardhome/client/src/helpers/helpers.js

179 lines
5.0 KiB
JavaScript
Raw Normal View History

2018-08-30 14:25:33 +00:00
import dateParse from 'date-fns/parse';
import dateFormat from 'date-fns/format';
import subHours from 'date-fns/sub_hours';
2018-08-30 14:25:33 +00:00
import addHours from 'date-fns/add_hours';
import round from 'lodash/round';
2019-02-19 16:19:40 +00:00
import {
STATS_NAMES,
STANDARD_DNS_PORT,
STANDARD_WEB_PORT,
CHECK_TIMEOUT,
STOP_TIMEOUT,
} from './constants';
export const formatTime = (time) => {
2018-08-30 14:25:33 +00:00
const parsedTime = dateParse(time);
return dateFormat(parsedTime, 'HH:mm:ss');
};
export const normalizeLogs = logs => logs.map((log) => {
const {
time,
question,
answer: response,
reason,
client,
2018-10-30 14:27:47 +00:00
filterId,
rule,
2018-08-30 14:25:33 +00:00
} = log;
const { host: domain, type } = question;
const responsesArray = response ? response.map((response) => {
const { value, type, ttl } = response;
return `${type}: ${value} (ttl=${ttl})`;
}) : [];
return {
time,
2018-08-30 14:25:33 +00:00
domain,
type,
response: responsesArray,
reason,
client,
2018-10-30 14:27:47 +00:00
filterId,
rule,
2018-08-30 14:25:33 +00:00
};
});
export const normalizeHistory = history => Object.keys(history).map((key) => {
2018-10-10 14:54:21 +00:00
let id = STATS_NAMES[key];
if (!id) {
id = key.replace(/_/g, ' ').replace(/^\w/, c => c.toUpperCase());
}
2018-08-30 14:25:33 +00:00
const dayAgo = subHours(Date.now(), 24);
2018-08-30 14:25:33 +00:00
const data = history[key].map((item, index) => {
const formatHour = dateFormat(addHours(dayAgo, index), 'ddd HH:00');
2018-08-30 14:25:33 +00:00
const roundValue = round(item, 2);
return {
x: formatHour,
y: roundValue,
};
});
return {
id,
data,
};
});
export const normalizeFilteringStatus = (filteringStatus) => {
const { enabled, filters, user_rules: userRules } = filteringStatus;
const newFilters = filters ? filters.map((filter) => {
const {
2018-10-30 14:27:47 +00:00
id, url, enabled, lastUpdated: lastUpdated = Date.now(), name = 'Default name', rulesCount: rulesCount = 0,
2018-08-30 14:25:33 +00:00
} = filter;
return {
2018-10-30 14:27:47 +00:00
id, url, enabled, lastUpdated: formatTime(lastUpdated), name, rulesCount,
2018-08-30 14:25:33 +00:00
};
}) : [];
const newUserRules = Array.isArray(userRules) ? userRules.join('\n') : '';
return { enabled, userRules: newUserRules, filters: newFilters };
};
2018-10-12 13:02:01 +00:00
export const getPercent = (amount, number) => {
if (amount > 0 && number > 0) {
return round(100 / (amount / number), 2);
}
return 0;
};
2018-10-14 20:42:25 +00:00
export const captitalizeWords = text => text.split(/[ -_]/g).map(str => str.charAt(0).toUpperCase() + str.substr(1)).join(' ');
2019-02-04 14:13:59 +00:00
export const getInterfaceIp = (option) => {
const onlyIPv6 = option.ip_addresses.every(ip => ip.includes(':'));
let interfaceIP = option.ip_addresses[0];
if (!onlyIPv6) {
option.ip_addresses.forEach((ip) => {
if (!ip.includes(':')) {
interfaceIP = ip;
}
});
}
return interfaceIP;
};
export const getIpList = (interfaces) => {
let list = [];
Object.keys(interfaces).forEach((item) => {
list = [...list, ...interfaces[item].ip_addresses];
});
return list.sort();
};
2019-02-06 14:32:32 +00:00
export const getDnsAddress = (ip, port = '') => {
const isStandardDnsPort = port === STANDARD_DNS_PORT;
let address = ip;
2019-02-04 14:13:59 +00:00
2019-02-06 14:32:32 +00:00
if (port) {
if (ip.includes(':') && !isStandardDnsPort) {
address = `[${ip}]:${port}`;
} else if (!isStandardDnsPort) {
address = `${ip}:${port}`;
2019-02-04 14:13:59 +00:00
}
2019-02-06 14:32:32 +00:00
}
return address;
};
export const getWebAddress = (ip, port = '') => {
const isStandardWebPort = port === STANDARD_WEB_PORT;
let address = `http://${ip}`;
2019-02-04 14:13:59 +00:00
2019-02-06 14:32:32 +00:00
if (port) {
if (ip.includes(':') && !isStandardWebPort) {
address = `http://[${ip}]:${port}`;
} else if (!isStandardWebPort) {
address = `http://${ip}:${port}`;
}
2019-02-04 14:13:59 +00:00
}
2019-02-06 14:32:32 +00:00
return address;
2019-02-04 14:13:59 +00:00
};
2019-02-19 12:43:36 +00:00
export const redirectToCurrentProtocol = (values) => {
2019-02-19 15:04:23 +00:00
const {
protocol, hostname, hash, port,
} = window.location;
2019-02-19 12:43:36 +00:00
const { enabled, port_https } = values;
2019-02-19 15:04:23 +00:00
const httpsPort = port_https !== 443 ? `:${port_https}` : '';
2019-02-19 12:43:36 +00:00
if (protocol !== 'https:' && enabled && port_https) {
2019-02-19 15:04:23 +00:00
window.location.replace(`https://${hostname}${httpsPort}/${hash}`);
} else if (protocol === 'https:' && enabled && port_https && port_https !== port) {
2019-02-19 16:19:40 +00:00
// TODO
const redirectCheck = setInterval(() => {
fetch(`https://${hostname}${httpsPort}/${hash}`, { mode: 'no-cors' })
2019-02-19 16:42:59 +00:00
.then((response) => {
if (response) {
clearInterval(redirectCheck);
window.location.replace(`https://${hostname}${httpsPort}/${hash}`);
}
2019-02-19 16:19:40 +00:00
})
.catch(() => false);
}, CHECK_TIMEOUT);
setTimeout(() => {
clearInterval(redirectCheck);
console.error('Redirect check stopped');
}, STOP_TIMEOUT);
2019-02-19 12:43:36 +00:00
} else if (protocol === 'https:' && (!enabled || !port_https)) {
window.location.replace(`http://${hostname}/${hash}`);
}
};