mirror of
https://github.com/DeNNiiInc/dbgate.git
synced 2026-04-19 07:16:01 +00:00
91 lines
2.9 KiB
TypeScript
91 lines
2.9 KiB
TypeScript
import _cloneDeepWith from 'lodash/cloneDeepWith';
|
|
import _escapeRegExp from 'lodash/escapeRegExp';
|
|
import { Condition, Expression } from './types';
|
|
import { evaluateExpression } from './evaluateExpression';
|
|
|
|
function isEmpty(value) {
|
|
if (value == null) return true;
|
|
return value.toString().trim() == '';
|
|
}
|
|
|
|
function isLike(value, test) {
|
|
if (!value) return false;
|
|
if (!test) return false;
|
|
const regex = new RegExp(`^${_escapeRegExp(test).replace(/%/g, '.*')}$`, 'i');
|
|
const res = !!value.toString().match(regex);
|
|
return res;
|
|
}
|
|
|
|
function extractRawValue(value) {
|
|
if (value?.$bigint) return value.$bigint;
|
|
if (value?.$oid) return value.$oid;
|
|
if (value?.$decimal) return value.$decimal;
|
|
return value;
|
|
}
|
|
|
|
export function evaluateCondition(condition: Condition, values) {
|
|
switch (condition.conditionType) {
|
|
case 'binary':
|
|
const left = extractRawValue(evaluateExpression(condition.left, values));
|
|
const right = extractRawValue(evaluateExpression(condition.right, values));
|
|
switch (condition.operator) {
|
|
case '=':
|
|
return left == right;
|
|
case '!=':
|
|
case '<>':
|
|
return left != right;
|
|
case '<=':
|
|
return left <= right;
|
|
case '>=':
|
|
return left >= right;
|
|
case '<':
|
|
return left < right;
|
|
case '>':
|
|
return left > right;
|
|
}
|
|
break;
|
|
case 'isNull':
|
|
return evaluateExpression(condition.expr, values) == null;
|
|
case 'isNotNull':
|
|
return evaluateExpression(condition.expr, values) != null;
|
|
case 'isEmpty':
|
|
return isEmpty(evaluateExpression(condition.expr, values));
|
|
case 'isNotEmpty':
|
|
return !isEmpty(evaluateExpression(condition.expr, values));
|
|
case 'and':
|
|
return condition.conditions.every(cond => evaluateCondition(cond, values));
|
|
case 'or':
|
|
return condition.conditions.some(cond => evaluateCondition(cond, values));
|
|
case 'like':
|
|
return isLike(
|
|
extractRawValue(evaluateExpression(condition.left, values)),
|
|
extractRawValue(evaluateExpression(condition.right, values))
|
|
);
|
|
case 'notLike':
|
|
return !isLike(
|
|
extractRawValue(evaluateExpression(condition.left, values)),
|
|
extractRawValue(evaluateExpression(condition.right, values))
|
|
);
|
|
case 'not':
|
|
return !evaluateCondition(condition.condition, values);
|
|
case 'anyColumnPass':
|
|
return Object.keys(values).some(columnName => {
|
|
const replaced = _cloneDeepWith(condition.placeholderCondition, (expr: Expression) => {
|
|
if (expr.exprType == 'placeholder')
|
|
return {
|
|
exprType: 'column',
|
|
columnName,
|
|
};
|
|
});
|
|
return evaluateCondition(replaced, values);
|
|
});
|
|
case 'in':
|
|
const value = extractRawValue(evaluateExpression(condition.expr, values));
|
|
const list = condition.values;
|
|
if (Array.isArray(list)) {
|
|
return list.some(item => item == value);
|
|
}
|
|
return false;
|
|
}
|
|
}
|