#   Licensed 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.

import logging

from osc_lib import utils

from openstackclient.i18n import _

LOG = logging.getLogger(__name__)

# global variables used when building the shell
DEFAULT_API_VERSION = '2.0'
API_VERSION_OPTION = 'os_network_api_version'
API_NAME = 'network'
API_VERSIONS = ('2.0', '2')


def make_client(instance):
    """Returns a network proxy"""
    # NOTE(dtroyer): As of osc-lib 1.8.0 and OpenStackSDK 0.10.0 the
    #                old Profile interface and separate client creation
    #                for each API that uses the SDK is unnecessary.  This
    #                callback remains as a remnant of the original plugin
    #                interface and to avoid the code churn of changing all
    #                of the existing references.
    LOG.debug(
        'Network client initialized using OpenStack SDK: %s',
        instance.sdk_connection.network,
    )
    return instance.sdk_connection.network


def build_option_parser(parser):
    """Hook to add global options"""
    parser.add_argument(
        '--os-network-api-version',
        metavar='<network-api-version>',
        default=utils.env('OS_NETWORK_API_VERSION'),
        help=_("Network API version, default=%s (Env: OS_NETWORK_API_VERSION)")
        % DEFAULT_API_VERSION,
    )
    return parser