Skip to content

Commit

Permalink
Merge pull request cloudflare#133 from JaredPage/add-bot-management-h…
Browse files Browse the repository at this point in the history
…andle-null-errors

Added Bot Management ability and fixed an edge case for the API return
  • Loading branch information
mahtin committed Mar 30, 2022
2 parents 5f444bc + a2640a0 commit f3dd7ae
Show file tree
Hide file tree
Showing 3 changed files with 70 additions and 1 deletion.
1 change: 1 addition & 0 deletions CloudFlare/api_v4.py
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,7 @@ def zones(self):
self.add('AUTH', "zones", "activation_check")
self.add('AUTH', "zones", "available_plans")
self.add('AUTH', "zones", "available_rate_plans")
self.add('AUTH', "zones", "bot_management")
self.add('AUTH', "zones", "custom_certificates")
self.add('AUTH', "zones", "custom_certificates/prioritize")
self.add('AUTH', "zones", "custom_hostnames")
Expand Down
2 changes: 1 addition & 1 deletion CloudFlare/cloudflare.py
Original file line number Diff line number Diff line change
Expand Up @@ -490,7 +490,7 @@ def _call(self, method, headers, parts,
response_data['success'] = True

if response_data['success'] is False:
if 'errors' in response_data:
if 'errors' in response_data and response_data['errors'] != None:
errors = response_data['errors'][0]
else:
errors = {}
Expand Down
68 changes: 68 additions & 0 deletions examples/example_page_rules.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
#!/usr/bin/env python
"""Cloudflare API code - example"""

import os
import sys
sys.path.insert(0, os.path.abspath('..'))

import CloudFlare

def main():
"""Cloudflare API code - example"""

try:
zone_name = sys.argv[1]
except IndexError:
exit('usage: example_page_rules.py zone')

cf = CloudFlare.CloudFlare()

# grab the zone identifier
try:
params = {'name': zone_name}
zones = cf.zones.get(params=params)
except CloudFlare.exceptions.CloudFlareAPIError as e:
exit('/zones %d %s - api call failed' % (e, e))
except Exception as e:
exit('/zones.get - %s - api call failed' % (e))

if len(zones) == 0:
exit('/zones.get - %s - zone not found' % (zone_name))

if len(zones) != 1:
exit('/zones.get - %s - api call returned %d items' % (zone_name, len(zones)))

zone_id = zones[0]['id']

url_match=f"*.{zone_name}/url1*"
url_forwarded=f"http://{zone_name}/url2"

targets=[{"target":"url","constraint":{"operator":"matches","value":url_match}}]
actions=[{"id":"forwarding_url","value":{"status_code":302,"url":url_forwarded}}]
pagerule_for_redirection = {"status": "active","priority": 1,"actions": actions,"targets": targets}

try:
r = cf.zones.pagerules.get(zone_id, data=pagerule_for_redirection)
except CloudFlare.exceptions.CloudFlareAPIError as e:
exit('/zones.pagerules.get %d %s - api call failed' % (e, e))

create=True

for rule in r:
if (rule['actions'] == pagerule_for_redirection["actions"] and rule["targets"] == pagerule_for_redirection["targets"]):
print('\t', '... rule already present!')
create=False
break

if (create):
try:
r = cf.zones.pagerules.post(zone_id, data=pagerule_for_redirection)
except CloudFlare.exceptions.CloudFlareAPIError as e:
exit('/zones.pagerules.post %d %s - api call failed' % (e, e))
if (r['actions'] == pagerule_for_redirection["actions"] and r["targets"] == pagerule_for_redirection["targets"]):
print('\t', '... created!')
exit(0)

if __name__ == '__main__':
main()

0 comments on commit f3dd7ae

Please sign in to comment.