| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- import { TextMatch } from 'app/types/explore';
- import xss from 'xss';
- /**
- * Adapt findMatchesInText for react-highlight-words findChunks handler.
- * See https://github.com/bvaughn/react-highlight-words#props
- */
- export function findHighlightChunksInText({ searchWords, textToHighlight }) {
- return findMatchesInText(textToHighlight, searchWords.join(' '));
- }
- const cleanNeedle = (needle: string): string => {
- return needle.replace(/[[{(][\w,.-?:*+]+$/, '');
- };
- /**
- * Returns a list of substring regexp matches.
- */
- export function findMatchesInText(haystack: string, needle: string): TextMatch[] {
- // Empty search can send re.exec() into infinite loop, exit early
- if (!haystack || !needle) {
- return [];
- }
- const matches = [];
- const cleaned = cleanNeedle(needle);
- let regexp: RegExp;
- try {
- regexp = new RegExp(`(?:${cleaned})`, 'g');
- } catch (error) {
- return matches;
- }
- haystack.replace(regexp, (substring, ...rest) => {
- if (substring) {
- const offset = rest[rest.length - 2];
- matches.push({
- text: substring,
- start: offset,
- length: substring.length,
- end: offset + substring.length,
- });
- }
- return '';
- });
- return matches;
- }
- const XSSWL = Object.keys(xss.whiteList).reduce((acc, element) => {
- acc[element] = xss.whiteList[element].concat(['class', 'style']);
- return acc;
- }, {});
- const sanitizeXSS = new xss.FilterXSS({
- whiteList: XSSWL,
- });
- /**
- * Returns string safe from XSS attacks.
- *
- * Even though we allow the style-attribute, there's still default filtering applied to it
- * Info: https://github.com/leizongmin/js-xss#customize-css-filter
- * Whitelist: https://github.com/leizongmin/js-css-filter/blob/master/lib/default.js
- */
- export function sanitize(unsanitizedString: string): string {
- try {
- return sanitizeXSS.process(unsanitizedString);
- } catch (error) {
- console.log('String could not be sanitized', unsanitizedString);
- return unsanitizedString;
- }
- }
- export function hasAnsiCodes(input: string): boolean {
- return /\u001b\[\d{1,2}m/.test(input);
- }
|