-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathTaintLogic.js
98 lines (97 loc) · 1.83 KB
/
TaintLogic.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
(function (sandbox) {
const Utils = sandbox.dtaUtils;
function TaintLogic(config)
{
this.config = config;
}
TaintLogic.prototype.noTaint = false;
TaintLogic.prototype.taintSource = () => true;
TaintLogic.prototype.arithmetic = function(left, right, op, pos)
{
return left || right;
};
TaintLogic.prototype.unaryArithmetic = function(left)
{
return left;
};
TaintLogic.prototype.toStringTaint = function(a,t,f)
{
var ret;
if (f !== 'undefined')
ret = Utils.fillArray(t, (String(a)).length);
else
ret = Utils.fillArray(t, f(a).length);
return ret;
};
TaintLogic.prototype.compressTaint = function (shadow)
{//todo, make it more generic
var ret;
if (typeof shadow == 'boolean')
{
ret = shadow;
}
else if (Array.isArray(shadow))
{
if (shadow.length === 0)
ret = false;
else
ret = shadow.reduce((a, b) => a || b);
}
return ret;
};
TaintLogic.prototype.ordTaint = function (t)
{
var ret;
ret = t[0];
return ret;
};
TaintLogic.prototype.chrTaint = function (t)
{
var ret;
ret = [t];
return ret;
};
TaintLogic.prototype.escapeTaint = function (t ,type)
{
var ret;
ret = t;
return ret;
};
TaintLogic.prototype.unescapeTaint = function (ts)
{
return ts.reduce((a,b) => a || b);
};
TaintLogic.prototype.getFieldTaint = function (elemT, idxT)
{//todo: maybe need to be changed for more option
var ret;
ret = elemT;
return ret;
};
TaintLogic.prototype.getStringCharTaint = function (baseT, offsetT)
{
var ret;
ret = [baseT];
return ret;
};
TaintLogic.prototype.strIdxOfTaint = function (baseTaintArr, argTaintArr, startIdx, end)
{
var ret;
if (argTaintArr.reduce((a, b) => a || b))
{
ret = true;
return ret;
}
for (var i = startIdx; i <= end; i++)
{
if (baseTaintArr[i])
{
ret = true;
return ret;
}
}
ret = false;
return ret;
};
sandbox.dtaTaintLogic = new TaintLogic();
})(J$);
//todo, make it an array of boolean