Adding the --netbox.ssl_verify option #152
3 changed files with 17 additions and 1 deletions
|
@ -89,6 +89,8 @@ INFO:root:Creating Disk Samsung SSD 850 S2RBNX0K101698D
|
||||||
netbox:
|
netbox:
|
||||||
url: 'http://netbox.internal.company.com'
|
url: 'http://netbox.internal.company.com'
|
||||||
token: supersecrettoken
|
token: supersecrettoken
|
||||||
|
# uncomment to disable ssl verification
|
||||||
|
# ssl_verify: false
|
||||||
|
|
||||||
# Network configuration
|
# Network configuration
|
||||||
network:
|
network:
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
netbox:
|
netbox:
|
||||||
url: 'http://netbox.internal.company.com'
|
url: 'http://netbox.internal.company.com'
|
||||||
token: supersecrettoken
|
token: supersecrettoken
|
||||||
|
# uncomment to disable ssl verification
|
||||||
|
# ssl_verify: false
|
||||||
|
|
||||||
network:
|
network:
|
||||||
ignore_interfaces: "(dummy.*|docker.*)"
|
ignore_interfaces: "(dummy.*|docker.*)"
|
||||||
|
|
|
@ -3,6 +3,8 @@ import sys
|
||||||
|
|
||||||
import jsonargparse
|
import jsonargparse
|
||||||
import pynetbox
|
import pynetbox
|
||||||
|
import requests
|
||||||
|
import urllib3
|
||||||
|
|
||||||
|
|
||||||
def get_config():
|
def get_config():
|
||||||
|
@ -30,6 +32,8 @@ def get_config():
|
||||||
p.add_argument('--log_level', default='debug')
|
p.add_argument('--log_level', default='debug')
|
||||||
p.add_argument('--netbox.url', help='Netbox URL')
|
p.add_argument('--netbox.url', help='Netbox URL')
|
||||||
p.add_argument('--netbox.token', help='Netbox API Token')
|
p.add_argument('--netbox.token', help='Netbox API Token')
|
||||||
|
p.add_argument('--netbox.ssl_verify', default=True, action='store_true',
|
||||||
|
help='Disable SSL verification')
|
||||||
p.add_argument('--virtual.enabled', action='store_true', help='Is a virtual machine or not')
|
p.add_argument('--virtual.enabled', action='store_true', help='Is a virtual machine or not')
|
||||||
p.add_argument('--virtual.cluster_name', help='Cluster name of VM')
|
p.add_argument('--virtual.cluster_name', help='Cluster name of VM')
|
||||||
p.add_argument('--hostname_cmd', default=None,
|
p.add_argument('--hostname_cmd', default=None,
|
||||||
|
@ -77,10 +81,18 @@ def get_netbox_instance():
|
||||||
if config.netbox.url is None or config.netbox.token is None:
|
if config.netbox.url is None or config.netbox.token is None:
|
||||||
logging.error('Netbox URL and token are mandatory')
|
logging.error('Netbox URL and token are mandatory')
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
return pynetbox.api(
|
|
||||||
|
nb = pynetbox.api(
|
||||||
url=get_config().netbox.url,
|
url=get_config().netbox.url,
|
||||||
token=get_config().netbox.token,
|
token=get_config().netbox.token,
|
||||||
)
|
)
|
||||||
|
if get_config().netbox.ssl_verify is False:
|
||||||
|
urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
|
||||||
|
session = requests.Session()
|
||||||
|
session.verify = False
|
||||||
|
nb.http_session = session
|
||||||
|
|
||||||
|
return nb
|
||||||
|
|
||||||
|
|
||||||
config = get_config()
|
config = get_config()
|
||||||
|
|
Loading…
Reference in a new issue