Source code for seeq.addons.azureml.__main__

import os
import sys
import argparse
import subprocess
from getpass import getpass
from urllib.parse import urlparse
from seeq import spy
# noinspection PyProtectedMember
from seeq.spy._errors import *
# noinspection PyProtectedMember
from seeq.spy import _url
from ._copy import copy_notebook

NB_EXTENSIONS = ['widgetsnbextension', 'ipyvuetify', 'ipyvue', 'ipydatetime']
DEPLOYMENT_FOLDER = 'deployment'
DEPLOYMENT_NOTEBOOK = "azureml_integration_master.ipynb"


def permissions_defaults(permissions_group: list, permissions_users: list):
    if permissions_group is None:
        permissions_group = ['Everyone']

    if permissions_users is None:
        permissions_users = []
    return permissions_group, permissions_users


[docs]def install_app(sdl_url_, *, sort_key='a', permissions_group: list = None, permissions_users: list = None): """ Installs Azure ML Integration as an Add-on Tool in Seeq Workbench Parameters ---------- sdl_url_: str URL of the SDL container. E.g. `https://my.seeq.com/data-lab/6AB49411-917E-44CC-BA19-5EE0F903100C/` sort_key: str, default 'a' A string, typically one character letter. The sort_key determines the order in which the Add-on Tools are displayed in the tool panel. permissions_group: list Names of the Seeq groups that will have access to each tool. If None, the "Everyone" group will be used by default. permissions_users: list Names of Seeq users that will have access to each tool. If None, no individual users will be given access to the tool. Returns -------- -: None """ permissions_group, permissions_users = permissions_defaults(permissions_group, permissions_users) add_on_details = { "Name": 'Azure ML Integration', "Description": "Computes Azure ML models with Seeq data", "Icon": "fa fa-line-chart", "Target URL": f'{sdl_url_}/apps/{DEPLOYMENT_FOLDER}/{DEPLOYMENT_NOTEBOOK}', "Link Type": "window", "Window Details": "toolbar=0,location=0,left=800,top=400,height=1200,width=800", "Sort Key": sort_key, "Reuse Window": True, "Groups": permissions_group, "Users": permissions_users } copy_notebook(des_folder=DEPLOYMENT_FOLDER, src_folder='deployment_notebook', overwrite_folder=False, overwrite_contents=True) spy.addons.install(add_on_details, include_workbook_parameters=True, update_tool=True, update_permissions=True)
[docs]def install_nbextensions(): """ Installs the Jupyter nbextensions required to render the Add-on Returns ------- -: None """ for extension in NB_EXTENSIONS: subprocess.run(f'jupyter nbextension install --user --py {extension}', cwd=os.path.expanduser('~'), shell=True, check=True) subprocess.run(f'jupyter nbextension enable --user --py {extension}', cwd=os.path.expanduser('~'), shell=True, check=True)
[docs]def logging_attempts(_user): """ Allows user to re-enter credentials multiple times in the event of authentication failure Parameters ---------- _user: str Seeq username that needs to be authenticated Returns ------- -: None """ count = 0 allowed_attempts = 20 while count <= allowed_attempts: try: if _user is None or count >= 1: _user = input("\nAccess Key or Username: ") passwd = getpass("Access Key Password: ") spy.login(username=_user, password=passwd, ignore_ssl_errors=True) break except (SPyRuntimeError, SPyValueError): count += 1 try_again = None while try_again != 'yes' and try_again != 'no': try_again = input("\nTry again (yes/no)? [yes] ") if try_again == '' or try_again.lower() == 'y': try_again = 'yes' if try_again.lower() == 'n': try_again = 'no' print("-" * 60) if try_again.lower() == 'no': raise if count > allowed_attempts: raise RuntimeError("Number of login attempts exceeded")
[docs]def cli_interface(): """ Installs Azure ML Integration as a Seeq Add-on Returns ------- -: None """ parser = argparse.ArgumentParser(description='Install Azure ML Integration as a Seeq Add-on Tool') parser.add_argument('--nbextensions_only', action='store_true', help='Only installs the nbextensions without installing or updating the Add-on Tools' 'links') parser.add_argument('--username', type=str, help='Username or Access Key of Seeq admin user installing the tool(s) ') parser.add_argument('--seeq_url', type=str, nargs='?', help="Seeq hostname URL with the format https://my.seeq.com/ or https://my.seeq.com:34216") parser.add_argument('--users', type=str, nargs='*', default=[], help="List of the Seeq users to will have access to the Azure ML Integration Add-on Tool," " default: %(default)s") parser.add_argument('--groups', type=str, nargs='*', default=['Everyone'], help="List of the Seeq groups to will have access to the Azure ML Integration Add-on Tool, " "default: %(default)s") return parser.parse_args()
if __name__ == '__main__': args = cli_interface() if args.nbextensions_only: print("\n\nInstalling and enabling nbextensions") install_nbextensions() sys.exit(0) user = args.username logging_attempts(user) seeq_url = args.seeq_url if seeq_url is None: seeq_url = input(f"\n Seeq base URL [{spy.client.host.split('/api')[0]}]: ") if seeq_url == '': seeq_url = spy.client.host.split('/api')[0] url_parsed = urlparse(seeq_url) seeq_url_base = f"{url_parsed.scheme}://{url_parsed.netloc}" project_id = spy.utils.get_data_lab_project_id() sdl_url = f'{seeq_url_base}/data-lab/{project_id}' if project_id is None: print("\nThe project ID could not be found. Please provide the SDL project URL with the format " "https://my.seeq.com/data-lab/6AB49411-917E-44CC-BA19-5EE0F903100C/\n") sdl_url = input("Seeq Data Lab project URL: ") project_id = spy.utils.get_data_lab_project_id_from_url(sdl_url) if not project_id: raise RuntimeError(f'Could not install {args.apps} because the SDL project ID could not be found') sdl_url_sanitized = _url.SeeqURL.parse(sdl_url).url print(f"\nThe Azure ML Integration will be installed on the SDL notebook: {sdl_url_sanitized}\n" f"If this is not your intent, you can quit the installation now ") print('\n[enter] to continue or type "quit" to exit installation') choice = None while choice != '' and choice != 'quit': choice = input() if choice == '': print("\n\nInstalling and enabling nbextensions") install_nbextensions() install_app(sdl_url_sanitized, permissions_group=args.groups, permissions_users=args.users) elif choice == 'quit': print("\nExited installation") else: print(f'\nCommand "{choice}" is not valid') print('\n[enter] to continue the installation or type "quit" to exit installation')