blob: df3234608e09e3795ed8a9267b8f833a578da91f [file] [log] [blame]
#
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
#
from rich import print
from pick import pick
import typer
from airavata_mft_sdk import mft_client
from airavata_mft_sdk.swift import SwiftCredential_pb2
from airavata_mft_sdk.swift import SwiftStorage_pb2
from airavata_mft_sdk.common import StorageCommon_pb2
import sys
sys.path.append('../airavata_mft_cli')
from airavata_mft_cli import config as configcli
def handle_add_storage():
options = ["v3", "v2" ]
option, index = pick(options, "Select Keystone Auth Version", indicator="=>")
secret_create_req= SwiftCredential_pb2.SwiftSecretCreateRequest()
if (option == "v3"):
user_name = typer.prompt("User Name")
password = typer.prompt("Password")
tenant_name = typer.prompt("Tenant Name")
project_domain = typer.prompt("Project Domain Name", "Default")
user_domain = typer.prompt("User Domain Name", "Default")
v3_sec = SwiftCredential_pb2.SwiftV3AuthSecret(userDomainName=user_domain, userName=user_name,
password=password, tenantName=tenant_name, projectDomainName=project_domain)
secret_create_req.v3AuthSecret.CopyFrom(v3_sec)
else :
tenant_name = typer.prompt("Tenant Name")
user_name = typer.prompt("User Name")
password = typer.prompt("Password")
v2_sec = SwiftCredential_pb2.SwiftV2AuthSecret(tenant=tenant_name, userName=user_name, password=password)
secret_create_req.v2AuthSecret.CopyFrom(v2_sec)
auth_url = typer.prompt("Auth URL")
secret_create_req.endpoint = auth_url
region_name = typer.prompt("Region Name")
container = typer.prompt("Container")
storage_name = typer.prompt("Name of the storage ", container)
client = mft_client.MFTClient(transfer_api_port = configcli.transfer_api_port,
transfer_api_secured = configcli.transfer_api_secured,
resource_service_host = configcli.resource_service_host,
resource_service_port = configcli.resource_service_port,
resource_service_secured = configcli.resource_service_secured,
secret_service_host = configcli.secret_service_host,
secret_service_port = configcli.secret_service_port)
swift_storage_create_req = SwiftStorage_pb2.SwiftStorageCreateRequest(region=region_name,
container=container,
name=storage_name)
created_storage = client.swift_storage_api.createSwiftStorage(swift_storage_create_req)
created_secret = client.swift_secret_api.createSwiftSecret(secret_create_req)
secret_for_storage_req = StorageCommon_pb2.SecretForStorage(storageId = created_storage.storageId,
secretId = created_secret.secretId,
storageType = StorageCommon_pb2.StorageType.SWIFT)
client.common_api.registerSecretForStorage(secret_for_storage_req)
print("Successfully added the Swift Container...")