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
|
# General bidding logic script. Depending on query parameters, it can
# simulate a variety of network errors, and its generateBid() and
# reportWin() functions can have arbitrary Javascript code injected
# in them. generateBid() will by default return a bid of 9 for the
# first ad.
def main(request, response):
error = request.GET.first(b"error", None)
if error == b"close-connection":
# Close connection without writing anything, to simulate a network
# error. The write call is needed to avoid writing the default headers.
response.writer.write("")
response.close_connection = True
return
if error == b"http-error":
response.status = (404, b"OK")
else:
response.status = (200, b"OK")
if error == b"wrong-content-type":
response.headers.set(b"Content-Type", b"application/json")
elif error != b"no-content-type":
response.headers.set(b"Content-Type", b"application/javascript")
if error == b"bad-allow-fledge":
response.headers.set(b"X-Allow-FLEDGE", b"sometimes")
elif error == b"fledge-not-allowed":
response.headers.set(b"X-Allow-FLEDGE", b"false")
elif error != b"no-allow-fledge":
response.headers.set(b"X-Allow-FLEDGE", b"true")
body = b''
if error == b"no-body":
return body
if error != b"no-generateBid":
body += b"""
function generateBid(interestGroup, auctionSignals, perBuyerSignals,
trustedBiddingSignals, browserSignals,
directFromSellerSignals) {
{{GET[generateBid]}};
return {
'bid': 9,
'render': interestGroup.ads[0].renderUrl
};
}"""
bid = request.GET.first(b"bid", None)
if bid != None:
body = body.replace(b"9", bid)
if error != b"no-reportWin":
body += b"""
function reportWin(auctionSignals, perBuyerSignals, sellerSignals,
browserSignals, directFromSellerSignals) {
{{GET[reportWin]}};
}"""
return body
|