# -*- coding: utf-8 -*-
# smtpspec.py
# Copyright (C) 2013 LEAP
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.

# Schemas dict
# To add a schema for a version you should follow the form:
# { '1': schema_v1, '2': schema_v2, ... etc }
# so for instance, to add the '2' version, you should do:
# smtp_config_spec['2'] = schema_v2
smtp_config_spec = {}

smtp_config_spec['1'] = {
    'description': 'sample smtp service config',
    'type': 'object',
    'properties': {
        'serial': {
            'type': int,
            'default': 1,
            'required': ["True"]
        },
        'version': {
            'type': int,
            'default': 1,
            'required': ["True"]
        },
        'hosts': {
            'type': dict,
            'default': {
                "walrus": {
                    "hostname": "someprovider",
                    "ip_address": "1.1.1.1",
                    "port": 1111
                },
            },
        },
        'locations': {
            'type': dict,
            'default': {
                "locations": {

                }
            }
        }
    }
}


def get_schema(version):
    """
    Returns the schema corresponding to the version given.

    :param version: the version of the schema to get.
    :type version: str
    :rtype: dict or None if the version is not supported.
    """
    schema = smtp_config_spec.get(version, None)
    return schema