Skip to content

Commit

Permalink
Merge pull request #132 from ns1/add-redirect-docs
Browse files Browse the repository at this point in the history
Add redirect docs and examples
  • Loading branch information
fformica authored Nov 18, 2024
2 parents 0e0ac36 + e38de97 commit a5d9569
Show file tree
Hide file tree
Showing 4 changed files with 144 additions and 0 deletions.
1 change: 1 addition & 0 deletions doc/api/modules.rst
Original file line number Diff line number Diff line change
Expand Up @@ -9,3 +9,4 @@ ns1 package
zones
records
rest
redirect
33 changes: 33 additions & 0 deletions doc/api/redirect.rst
Original file line number Diff line number Diff line change
@@ -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:


5 changes: 5 additions & 0 deletions doc/api/rest.rst
Original file line number Diff line number Diff line change
Expand Up @@ -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:
105 changes: 105 additions & 0 deletions examples/redirect.py
Original file line number Diff line number Diff line change
@@ -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='<<CLEARTEXT API KEY>>')

# 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")

0 comments on commit a5d9569

Please sign in to comment.