-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcspreport2me.py
62 lines (44 loc) · 1.99 KB
/
cspreport2me.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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
from burp import IBurpExtender
from burp import IProxyListener
from java.io import PrintWriter
import re
REPORT_API = 'YOUR_CSP_REPORT_API'
class BurpExtender(IBurpExtender, IProxyListener):
#
# implement IBurpExtender
#
def registerExtenderCallbacks(self, callbacks):
# obtain an extension helpers object
self._helpers = callbacks.getHelpers()
# set our extension name
callbacks.setExtensionName("CSPreport2me")
self.stdout = PrintWriter(callbacks.getStdout(), True)
# register ourselves as an HTTP listener
callbacks.registerProxyListener(self)
#
# implement IHttpListener
#
def processProxyMessage(self, messageIsRequest, message):
# only process response
if messageIsRequest:
return
# get the HTTP service for the request
HttpRequestResponse = message.getMessageInfo()
OriResp = self._helpers.bytesToString(HttpRequestResponse.getResponse())
#headers,body = NewReq.split("\r\n\r\n")
postindex = OriResp.index("\r\n\r\n")
headers = OriResp[0:postindex]
body = OriResp[postindex:]
#print(body) Content-Security-Policy
if 'content-security-policy' not in headers.lower():
return
newheaders = re.sub(r'report-uri .*','report-uri '+ REPORT_API, headers, 0, re.I)
NewResp = "".join((newheaders,body))
url = self._helpers.analyzeRequest(HttpRequestResponse).getUrl()
self.stdout.println("[content-security-policy report-uri] changed: %s" % url)
#self.stdout.println("[new headers]" + newheaders)
HttpRequestResponse.setResponse(self._helpers.stringToBytes(NewResp))
# # if the host is HOST_FROM, change it to HOST_TO
# if (HOST_FROM == httpService.getHost()):
# messageInfo.setHttpService(self._helpers.buildHttpService(HOST_TO,
# httpService.getPort(), httpService.getProtocol()))