# Copyright 2014
# The Cloudscaling Group, Inc.
#
# 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.

from oslo_config import cfg

from gceapi.api import base_api
from gceapi.api import scopes
from gceapi import exception

CONF = cfg.CONF

# OS usual region names are in PascalCase - e.g. RegionOne,
# GCE region name should matche the regexp [a-z](?:[-a-z0-9]{0,61}[a-z0-9])?
_OS_GCE_MAP = {
    'RegionOne': 'region-one',
    'RegionTwo': 'region-two',
    'RegionThree': 'region-three',
    'RegionFour': 'region-four',
}


def _map_region_name(name):
    return _OS_GCE_MAP.get(name, name)


class API(base_api.API):
    """GCE Regions API

    Stubbed now for support only one predefined region from config
    #TODO(apavlov): need to implement discovering or regions from keystone
    """

    KIND = "region"
    _REGIONS = []

    def __init__(self, *args, **kwargs):
        super(API, self).__init__(*args, **kwargs)
        self._REGIONS = [_map_region_name(CONF.get("region").strip())]

    def _get_type(self):
        return self.KIND

    def get_item(self, context, name, scope=None):
        regions = self.get_items(context)
        for region in regions:
            if region["name"] == name:
                return region
        raise exception.NotFound

    def get_items(self, context, scope=None):
        return [dict(("name", region) for region in self._REGIONS)]

    def get_items_as_scopes(self, context):
        return [scopes.RegionScope(region) for region in self._REGIONS]