-
Notifications
You must be signed in to change notification settings - Fork 104
/
253-XForwardedFor-2.py
45 lines (34 loc) · 1.18 KB
/
253-XForwardedFor-2.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
from base import *
DIR = "x_forwarded_for_cgi_2"
REMOTE_IP = "5.6.7.8"
CONF = """
vserver!1!rule!2530!match = directory
vserver!1!rule!2530!match!directory = /%s
vserver!1!rule!2530!handler = cgi
vserver!1!rule!2530!handler!x_real_ip_enabled = 1
vserver!1!rule!2530!handler!x_real_ip_access_all = 0
vserver!1!rule!2530!handler!x_real_ip_access = ::1,127.0.0.1
""" % (DIR)
CGI_CODE = """#!/bin/sh
echo "Content-Type: text/plain"
echo
echo "REMOTE_ADDR ->${REMOTE_ADDR}<-"
echo
"""
class Test (TestBase):
def __init__ (self):
TestBase.__init__ (self, __file__)
self.name = "X-Forwared-For to REMOTE_ADDR: multiple"
self.request = "GET /%s/test HTTP/1.0\r\n" % (DIR) + \
"X-Forwarded-For: %s, 9.9.9.9\r\n" % (REMOTE_IP)
self.expected_error = 200
self.conf = CONF
self.proxy_suitable = False
def CustomTest (self):
body = self.reply.split ("\r\n\r\n")[1]
if "REMOTE_ADDR ->%s<-" %(REMOTE_IP) in body:
return 0
return -1
def Prepare (self, www):
d = self.Mkdir (www, DIR, 0777)
self.WriteFile (d, "test", 0555, CGI_CODE)