alkira/push-debug.py

231 lines
7.0 KiB
Python
Raw Normal View History

2022-06-15 10:43:29 +02:00
#!/usr/bin/env python3
#
# Copyright 2022, Mischa Peters <mischa AT alkira DOT net>, Alkira.
# push-debug.py
# Version 0.1 - 20220617 - initial release
#
# Permission to use, copy, modify, and distribute this software for any
# purpose with or without fee is hereby granted, provided that the above
# copyright notice and this permission notice appear in all copies.
#
# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#
2022-06-15 10:43:29 +02:00
import os
import sys
import re
import json
import time
import logging
import requests
import configparser
2022-06-17 15:36:07 +02:00
import argparse
# Parse all arguments
2022-06-17 16:16:41 +02:00
parser = argparse.ArgumentParser(description="Push JSON config to AlkiraAPI (debug)")
2022-06-17 16:01:23 +02:00
parser.add_argument("-t", "--tenant", type=str, default='alkira.cnf', help="location of alikira.cnf (default: alkira.cnfi)")
2022-06-17 15:36:07 +02:00
parser.add_argument("-f", "--file", type=str, help="location of the JSON connector file")
parser.add_argument("-p", "--pretty", help="make the JSON pretty!", action="store_true")
2022-06-17 16:01:23 +02:00
parser.add_argument("-v", "--verbose", type=int, default=0, help="Verbose level 0 or 1 (default: 0)")
2022-06-17 15:36:07 +02:00
if len(sys.argv)==1:
parser.print_help(sys.stderr)
sys.exit(1)
try:
args = parser.parse_args()
ALKIRA_CONFIG = args.tenant
json_file = args.file
except argparse.ArgumentError as e:
print(str(e))
sys.exit()
2022-06-15 10:43:29 +02:00
2022-06-17 16:01:23 +02:00
try:
loglevel = {
0: logging.INFO,
1: logging.DEBUG
}[args.verbose]
except KeyError:
loglevel = logging.INFO
2022-06-15 10:43:29 +02:00
###############################################
2022-06-17 16:01:23 +02:00
# Set loglevel (logging.INFO, logging.DEBUG)
logging.basicConfig(level=loglevel)
logging = logging.getLogger('AlkiraAPI')
2022-06-17 15:36:07 +02:00
# Tenant config
2022-06-17 12:45:57 +02:00
if not os.path.isfile(ALKIRA_CONFIG):
logging.error(f"The config file {ALKIRA_CONFIG} doesn't exist")
2022-06-15 10:43:29 +02:00
sys.exit(1)
2022-06-17 12:45:57 +02:00
alkira = configparser.RawConfigParser()
2022-06-17 14:07:23 +02:00
alkira.read(ALKIRA_CONFIG)
2022-06-15 10:43:29 +02:00
2022-06-17 12:45:57 +02:00
ALKIRA_TENANT = alkira.get('alkira', 'ALKIRA_TENANT')
ALKIRA_USERNAME = alkira.get('alkira', 'ALKIRA_USERNAME')
ALKIRA_PASSWORD = alkira.get('alkira', 'ALKIRA_PASSWORD')
2022-06-15 10:43:29 +02:00
ALKIRA_BASE_URI = f'https://{ALKIRA_TENANT}/api'
2022-06-21 18:10:54 +02:00
SERVICE_USERNAME = alkira.get('services', 'SERVICE_USERNAME')
SERVICE_PASSWORD = alkira.get('services', 'SERVICE_PASSWORD')
CIDR_NAME = alkira.get('globalcidr', 'CIDR_NAME')
CIDR_DESCR = alkira.get('globalcidr', 'CIDR_DESCR')
CIDR_PREFIX = alkira.get('globalcidr', 'CIDR_PREFIX')
CIDR_CXP = alkira.get('globalcidr', 'CIDR_CXP')
2022-06-15 10:43:29 +02:00
###############################################
# Set default headers
headers = {'Content-Type': "application/json"}
2022-06-21 18:10:54 +02:00
# URL Exceptions
url_exceptions = {
"saas": "internet",
"pan": "panfw",
"ftntfwservices": "ftnt-fw-services",
2022-06-21 18:10:54 +02:00
"chkpfwservices": "chkp-fw-services",
"ocivcnconnectors": "oci-vcn-connectors",
"ftntfwservices": "ftnt-fw-services"
}
2022-06-21 18:10:54 +02:00
# URL Exceptions creating credentials
service_credentials = {
"panfwservices": "pan",
2022-06-21 18:10:54 +02:00
"ftntfwservices": "ftntfw",
"chkpfwservices": "chkp-fw"
}
2022-06-21 18:10:54 +02:00
# URL Exceptions creating instance credentials
service_instance_credentials = {
2022-06-21 18:10:54 +02:00
"ftntfwservices": "ftntfw-",
"chkpfwservices": "chkp-fw-"
}
2022-06-21 18:10:54 +02:00
# Global CIDR
service_global_cidr = [
"chkpfwservices"
]
2022-06-15 10:43:29 +02:00
# Authenticate
2022-06-21 18:10:54 +02:00
logging.info('=== Authenticating')
2022-06-15 10:43:29 +02:00
body = {'userName': ALKIRA_USERNAME,
'password': ALKIRA_PASSWORD}
url = f'{ALKIRA_BASE_URI}/login'
session = requests.session()
response = session.post(url, data=json.dumps(body), headers=headers)
# Get TenantID
2022-06-21 18:10:54 +02:00
logging.info('=== Fetching Tenant Info')
2022-06-15 10:43:29 +02:00
url = f'{ALKIRA_BASE_URI}/tenantnetworks'
response = session.get(url, headers=headers)
data = response.json()
tenantNetworkId = data[0]['id']
tenantName = data[0]['name']
logging.info(f'Tenant Name: {tenantName}')
logging.info(f'Tenant ID: {tenantNetworkId}')
2022-06-21 18:10:54 +02:00
# Push connector
logging.info('=== Push Connector')
connector_result = re.match(r'(\w+)(\d+)', json_file)
2022-06-17 15:36:07 +02:00
connector_name = connector_result.group(1)
connector_number = connector_result.group(2)
2022-06-17 18:22:29 +02:00
logging.debug(f'Connector Name: {connector_name} - Number: {connector_number}')
if connector_name in service_credentials.keys():
2022-06-21 18:10:54 +02:00
print('=== Create Credentials')
credentials_url = service_credentials[connector_name]
2022-06-21 18:10:54 +02:00
fwcredential = f'fwcredentials-{time.time()}'
body = {
"credentials": {
2022-06-21 18:10:54 +02:00
"userName": SERVICE_USERNAME,
"password": SERVICE_PASSWORD
},
2022-06-21 18:10:54 +02:00
"name": fwcredential
}
2022-06-17 15:36:07 +02:00
if args.pretty:
print(json.dumps(body, indent=4))
else:
print(json.dumps(body))
url = f'{ALKIRA_BASE_URI}/credentials/{credentials_url}'
2022-06-21 18:10:54 +02:00
print(url)
response = session.post(url, data=json.dumps(body), headers=headers)
print(response.status_code)
print(response.content)
json_body = response.json()
if response.status_code == 200:
2022-06-21 18:10:54 +02:00
service_credentialid = json_body['id']
print(f'credentialId: {service_credentialid}')
if connector_name in service_instance_credentials.keys():
credentials_url = service_instance_credentials[connector_name]
print('=== Create Instance Credentials')
url = f'{ALKIRA_BASE_URI}/credentials/{credentials_url}instance'
2022-06-21 18:10:54 +02:00
print(url)
response = session.post(url, data=json.dumps(body), headers=headers)
print(response.status_code)
print(response.content)
json_body = response.json()
if response.status_code == 200:
2022-06-21 18:10:54 +02:00
service_instance_credentialid = json_body['id']
print(f'instance credentialId: {service_instance_credentialid}')
if connector_name in service_global_cidr:
print('=== Create Global CIDR')
body = {
"name": CIDR_NAME,
"description": CIDR_DESCR,
"values": [
CIDR_PREFIX
],
"cxp": CIDR_CXP
}
if args.pretty:
print(json.dumps(body, indent=4))
else:
print(json.dumps(body))
url = f'{ALKIRA_BASE_URI}/tenantnetworks/{tenantNetworkId}/global-cidr-lists'
print(url)
response = session.post(url, data=json.dumps(body), headers=headers)
print(response.status_code)
print(response.content)
json_body = response.json()
if response.status_code == 201:
global_cidr_id = json_body['id']
print(f'global cidr id: {global_cidr_id}')
with open (json_file, 'r') as f:
body = json.load(f)
if connector_name in url_exceptions.keys():
connector_name = url_exceptions[connector_name]
if 'credentialId' in body:
2022-06-21 18:10:54 +02:00
body['credentialId'] = service_credentialid
print(f'JSON credentialId: {service_credentialid}')
if 'instances' in body:
2022-06-21 18:10:54 +02:00
body['instances'][0]['credentialId'] = service_instance_credentialid
print(f'JSON credentialId: {service_instance_credentialid}')
if 'managementServer' in body:
body['managementServer']['globalCidrListId'] = global_cidr_id
print(f'JSON globalCidrListId: {global_cidr_id}')
if args.pretty:
print(json.dumps(body, indent=4))
else:
print(json.dumps(body))
print('=== Create FW Instance')
2022-06-17 15:36:07 +02:00
url = f'{ALKIRA_BASE_URI}/tenantnetworks/{tenantNetworkId}/{connector_name}'
2022-06-15 10:43:29 +02:00
response = session.post(url, data=json.dumps(body), headers=headers)
print(response.status_code)
print(response.content)