deb-designate/designate/objects/rrdata_soa.py
Graham Hayes 707bc639eb Enable Record Data Validation in v2 API
This enables the validation of data against schemas defined in the
individual record objects

* This is a permanent interface, implemented in a temp fashion *

* Current we convert all the Record() objects to objects of the
  right type, and then validate. If validation is successful we restore
  the generic objects and send them to central.

* We override the RecordSet validate() command, and add extra logic
  This allows for the v2 API to function, but recursive validation from
  a Domain object will not work, until another solution is found.

* The way schemas are build up has also changed
** Each schema is built on .validate()
** There is no embedded "obj://<object_name>" references anymore
** The entire schema is added as one blob

Closes-Bug: #1338256
Implements: blueprint validation-cleanup
APIImpact

Change-Id: I8d1d614a9a9c0c1d3faeb0f98778231278f37bc4
2015-03-30 21:29:44 +01:00

105 lines
2.9 KiB
Python

# Copyright (c) 2014 Rackspace Hosting
# All Rights Reserved.
#
# 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 designate.objects.record import Record
from designate.objects.record import RecordList
class SOA(Record):
"""
SOA Resource Record Type
Defined in: RFC1035
"""
FIELDS = {
'mname': {
'schema': {
'type': 'string',
'format': 'domainname',
'maxLength': 255,
},
'required': True
},
'rname': {
'schema': {
'type': 'string',
'format': 'domainname',
'maxLength': 255,
},
'required': True
},
'serial': {
'schema': {
'type': 'integer',
'minimum': 1,
'maximum': 4294967295,
},
'required': True
},
'refresh': {
'schema': {
'type': 'integer',
'minimum': 0,
'maximum': 2147483647
},
'required': True
},
'retry': {
'schema': {
'type': 'integer',
'minimum': 0,
'maximum': 2147483647
},
'required': True
},
'expire': {
'schema': {
'type': 'integer',
'minimum': 0,
'maximum': 2147483647
},
'required': True
},
'minimum': {
'schema': {
'type': 'integer',
'minimum': 0,
'maximum': 2147483647
},
'required': True
},
}
def _to_string(self):
return ("%(mname)s %(rname)s %(serial)s %(refresh)s %(retry)s "
"%(expire)s %(minimum)s" % self)
def _from_string(self, v):
mname, rname, serial, refresh, retry, expire, minimum = v.split(' ')
self.mname = mname
self.rname = rname
self.serial = int(serial)
self.refresh = int(refresh)
self.retry = int(retry)
self.expire = int(expire)
self.minimum = int(minimum)
# The record type is defined in the RFC. This will be used when the record
# is sent by mini-dns.
RECORD_TYPE = 6
class SOAList(RecordList):
LIST_ITEM_TYPE = SOA