From b8c6cd0bcbef69b2c4129fecb09c611d6f5ca5b5 Mon Sep 17 00:00:00 2001 From: Ferdinando Formica Date: Fri, 15 Nov 2024 14:25:57 +0000 Subject: [PATCH] Add redirect docs and examples --- doc/api/modules.rst | 1 + doc/api/redirect.rst | 33 ++++++++++++++ doc/api/rest.rst | 5 +++ examples/redirect.py | 105 +++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 144 insertions(+) create mode 100644 doc/api/redirect.rst create mode 100644 examples/redirect.py diff --git a/doc/api/modules.rst b/doc/api/modules.rst index e5d4a98..3384789 100644 --- a/doc/api/modules.rst +++ b/doc/api/modules.rst @@ -9,3 +9,4 @@ ns1 package zones records rest + redirect diff --git a/doc/api/redirect.rst b/doc/api/redirect.rst new file mode 100644 index 0000000..e65ec30 --- /dev/null +++ b/doc/api/redirect.rst @@ -0,0 +1,33 @@ +ns1.redirect +========= + +Redirect is an object representing a single redirect; RedirectCertificate represents a redirect certificate +and the Redirect.retrieveCertificate() method can be used to retrieve it. + +.. note:: + + The mandatory fields are domain, path and target, which describe a redirect in the form ``domain/path -> target``. + + By default, unless *https_enabled* is set to False, HTTPS will be enabled on the source domain: once there is a + certificate for the source domain, all redirects using it are automatically HTTPS enabled, regardless of the value + of *https_enabled*. + + The possible values for *forwarding_mode* are (see https://www.ibm.com/docs/en/ns1-connect?topic=redirects-path-query-forwarding): + + * ``all``: the entire URL path included in incoming requests to the source URL is appended to the target URL. + * ``none``: no part of the requested URL path should be appended to the target URL. + * ``capture``: only the segment of the requested URL path matching the wildcard segment defined in the source URL should be appended to the target URL. + + The possible values for *forwarding_type* are (see https://www.ibm.com/docs/en/ns1-connect?topic=redirects-configuring-url-redirect): + + * ``permanent``: answer clients with HTTP 301 Moved Permanently. + * ``temporary``: answer clients with HTTP 302 Found. + * ``masking``: answer clients with HTTP 200 OK and include the target in a frame. + + +.. automodule:: ns1.redirect + :members: + :undoc-members: + :show-inheritance: + + diff --git a/doc/api/rest.rst b/doc/api/rest.rst index ed0debb..c12ea5e 100644 --- a/doc/api/rest.rst +++ b/doc/api/rest.rst @@ -47,3 +47,8 @@ A thin layer over the NS1 REST API :members: :undoc-members: :show-inheritance: + +.. automodule:: ns1.rest.redirect + :members: + :undoc-members: + :show-inheritance: diff --git a/examples/redirect.py b/examples/redirect.py new file mode 100644 index 0000000..7cd7708 --- /dev/null +++ b/examples/redirect.py @@ -0,0 +1,105 @@ +# +# Copyright (c) 2024 NSONE, Inc. +# +# License under The MIT License (MIT). See LICENSE in project root. +# + +from ns1 import NS1 + +# NS1 will use config in ~/.nsone by default +api = NS1() + +# to specify an apikey here instead, use: +# api = NS1(apiKey='<>') + +# to load an alternate configuration file: +# api = NS1(configFile='/etc/ns1/api.json') + +# turn on "follow pagination". This will handle paginated responses for +# redirect and certificate list. It's off by default. +config = api.config +config["follow_pagination"] = True + +redirects = api.redirects() +certificates = api.redirect_certificates() + +########## +# CREATE # +########## + +# a redirect can only be created on an existing zone +zone = api.createZone("example.com", nx_ttl=3600) + +# the simplest redirect, https://domain/path -> target, will have https_enabled=True +# so it will also create a certificate for the domain +redirect_https = redirects.create( + domain="source.domain.example.com", + path="/path", + target="https://www.ibm.com/products/ns1-connect" +) + +# an http redirect, http://domain/path -> target, will not hold any certificate for the domain +redirect_http = redirects.create( + domain="source.domain.example.com", + path="/all/*", + target="http://httpforever.com/", + https_enabled=False, +) + +# requesting the certificate manually so that we can use a wildcard; +# note that this wildcard does not include *.domain.example.com, the previous domain +certificate_wildcard = certificates.create("*.example.com") +redirect_allsettings = redirects.create( + certificate_id=certificate_wildcard["id"], + domain="files.example.com", + path="*.rpm", + target="https://rpmfind.net/", + https_enabled=True, + https_forced=True, + query_forwarding=False, + forwarding_mode="all", + forwarding_type="permanent", + tags=["test","me"], +) + +########## +# SEARCH # +########## + +# search; we can also use list() to get all redirects +reds = redirects.searchSource('example.com') +print (reds['total'], len(reds['results'])) + +certs = certificates.search('example.com') +print (certs['total'], len(certs['results'])) + +################# +# READ / UPDATE # +################# + +# read +redirect_tmp = redirects.retrieve(redirect_allsettings["id"]) +print(redirect_tmp) + +# update +redirect_tmp = redirects.update( + redirect_tmp, + forwarding_type="temporary", +) +print(redirect_tmp) + +########## +# DELETE # +########## + +# delete redirects +redirects.delete(redirect_https['id']) +redirects.delete(redirect_http['id']) +redirects.delete(redirect_allsettings['id']) + +# also revoke certificate; +# note that the domain in redirect_http is the same so the certificate is also the same +certificates.delete(redirect_https["certificate_id"]) +certificates.delete(redirect_allsettings["certificate_id"]) + +api.zones().delete('example.com')