alkira/push.py

120 lines
2.9 KiB
Python
Raw Normal View History

2022-06-14 21:56:02 +02:00
#!/usr/bin/env python3
import os
import sys
import re
import json
import time
import logging
import requests
import configparser
###############################################
CONFIG_FILE = "/Users/mischa/Alkira/xDev/alkira.cnf"
if not os.path.isfile(CONFIG_FILE):
logging.error(f"The config file {CONFIG_FILE} doesn't exist")
sys.exit(1)
config = configparser.RawConfigParser()
config.read(CONFIG_FILE)
ALKIRA_TENANT = config.get('alkira', 'ALKIRA_TENANT')
ALKIRA_USERNAME = config.get('alkira', 'ALKIRA_USERNAME')
ALKIRA_PASSWORD = config.get('alkira', 'ALKIRA_PASSWORD')
ALKIRA_BASE_URI = f'https://{ALKIRA_TENANT}/api'
###############################################
# Set default headers
headers = {'Content-Type': "application/json"}
# Set logging.INFO to logging.DEBUG for debug information
logging.basicConfig(level=logging.INFO)
logging = logging.getLogger('AlkiraAPI')
# Naming exceptions
service_exceptions = {
"saas": "internet",
"pan": "panfw",
"ftntfw": "ftnt-fw-",
"chkpfw": "chkp-fw-"
}
def alkira_login():
body = {'userName': ALKIRA_USERNAME,
'password': ALKIRA_PASSWORD}
session = requests.session()
response = alkira_post(session, '/login', body)
return session
def alkira_post(session, uri, body):
url = f'{ALKIRA_BASE_URI}{uri}'
try:
response = session.post(url, data=json.dumps(body), headers=headers)
response.raise_for_status()
except Exception as e:
logging.error(f'Error: {str(e)}')
sys.exit(1)
return response
def alkira_get(session, uri):
url = f'{ALKIRA_BASE_URI}{uri}'
try:
response = session.get(url, headers=headers)
response.raise_for_status()
except Exception as e:
logging.error(f'Error: {str(e)}')
sys.exit(1)
return response
def alkira_delete(session, uri):
url = f'{ALKIRA_BASE_URI}{uri}'
try:
response = session.delete(url, headers=headers)
response.raise_for_status()
except Exception as e:
logging.error(f'Error: {str(e)}')
sys.exit(1)
return response
# Authenticate
s = alkira_login()
logging.debug(s)
# Get TenantID
r = alkira_get(s, '/tenantnetworks')
data = r.json()
tenantNetworkId = data[0]['id']
tenantName = data[0]['name']
logging.info(f'Tenant Name: {tenantName}')
logging.info(f'Tenant ID: {tenantNetworkId}')
# Push connectors
logging.info('Push Connectors')
2022-06-15 10:43:29 +02:00
with open ('dump.txt', 'r') as f:
body = json.load(f)
print(json.dumps(body))
2022-06-14 21:56:02 +02:00
r = alkira_post(s, f'/tenantnetworks/{tenantNetworkId}/awsvpcconnectors', body)
data = r.json()
print(r.status_code)
#print('# Connectors')
#print(json.dumps(data, indent=4))
## Get services
#logging.info('Checking services')
#r = alkira_get(s, f'/tenantnetworks/{tenantNetworkId}/services')
#data = r.json()
#print('# Services')
#print(json.dumps(data, indent=4))
#
## Get Global CIDR
#logging.info('Checking Global CIDR')
#r = alkira_get(s, f'/tenantnetworks/{tenantNetworkId}/global-cidr-lists')
#data = r.json()
#print('# Global CIDR')
#print(json.dumps(data, indent=4))