Skip to content
This repository was archived by the owner on Nov 22, 2024. It is now read-only.

Commit f3dd7ae

Browse files
authored
Merge pull request #133 from JaredPage/add-bot-management-handle-null-errors
Added Bot Management ability and fixed an edge case for the API return
2 parents 5f444bc + a2640a0 commit f3dd7ae

3 files changed

Lines changed: 70 additions & 1 deletion

File tree

CloudFlare/api_v4.py

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -86,6 +86,7 @@ def zones(self):
8686
self.add('AUTH', "zones", "activation_check")
8787
self.add('AUTH', "zones", "available_plans")
8888
self.add('AUTH', "zones", "available_rate_plans")
89+
self.add('AUTH', "zones", "bot_management")
8990
self.add('AUTH', "zones", "custom_certificates")
9091
self.add('AUTH', "zones", "custom_certificates/prioritize")
9192
self.add('AUTH', "zones", "custom_hostnames")

CloudFlare/cloudflare.py

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -490,7 +490,7 @@ def _call(self, method, headers, parts,
490490
response_data['success'] = True
491491

492492
if response_data['success'] is False:
493-
if 'errors' in response_data:
493+
if 'errors' in response_data and response_data['errors'] != None:
494494
errors = response_data['errors'][0]
495495
else:
496496
errors = {}

examples/example_page_rules.py

Lines changed: 68 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,68 @@
1+
#!/usr/bin/env python
2+
"""Cloudflare API code - example"""
3+
4+
import os
5+
import sys
6+
sys.path.insert(0, os.path.abspath('..'))
7+
8+
import CloudFlare
9+
10+
def main():
11+
"""Cloudflare API code - example"""
12+
13+
try:
14+
zone_name = sys.argv[1]
15+
except IndexError:
16+
exit('usage: example_page_rules.py zone')
17+
18+
cf = CloudFlare.CloudFlare()
19+
20+
# grab the zone identifier
21+
try:
22+
params = {'name': zone_name}
23+
zones = cf.zones.get(params=params)
24+
except CloudFlare.exceptions.CloudFlareAPIError as e:
25+
exit('/zones %d %s - api call failed' % (e, e))
26+
except Exception as e:
27+
exit('/zones.get - %s - api call failed' % (e))
28+
29+
if len(zones) == 0:
30+
exit('/zones.get - %s - zone not found' % (zone_name))
31+
32+
if len(zones) != 1:
33+
exit('/zones.get - %s - api call returned %d items' % (zone_name, len(zones)))
34+
35+
zone_id = zones[0]['id']
36+
37+
url_match=f"*.{zone_name}/url1*"
38+
url_forwarded=f"http://{zone_name}/url2"
39+
40+
targets=[{"target":"url","constraint":{"operator":"matches","value":url_match}}]
41+
actions=[{"id":"forwarding_url","value":{"status_code":302,"url":url_forwarded}}]
42+
pagerule_for_redirection = {"status": "active","priority": 1,"actions": actions,"targets": targets}
43+
44+
try:
45+
r = cf.zones.pagerules.get(zone_id, data=pagerule_for_redirection)
46+
except CloudFlare.exceptions.CloudFlareAPIError as e:
47+
exit('/zones.pagerules.get %d %s - api call failed' % (e, e))
48+
49+
create=True
50+
51+
for rule in r:
52+
if (rule['actions'] == pagerule_for_redirection["actions"] and rule["targets"] == pagerule_for_redirection["targets"]):
53+
print('\t', '... rule already present!')
54+
create=False
55+
break
56+
57+
if (create):
58+
try:
59+
r = cf.zones.pagerules.post(zone_id, data=pagerule_for_redirection)
60+
except CloudFlare.exceptions.CloudFlareAPIError as e:
61+
exit('/zones.pagerules.post %d %s - api call failed' % (e, e))
62+
if (r['actions'] == pagerule_for_redirection["actions"] and r["targets"] == pagerule_for_redirection["targets"]):
63+
print('\t', '... created!')
64+
exit(0)
65+
66+
if __name__ == '__main__':
67+
main()
68+

0 commit comments

Comments
 (0)