deb-designate/designate/objects/rrdata_sshfp.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

68 lines
1.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 SSHFP(Record):
"""
SSHFP Resource Record Type
Defined in: RFC4255
"""
FIELDS = {
'algorithm': {
'schema': {
'type': 'integer',
'minimum': 0,
'maximum': 2
},
'required': True
},
'fp_type': {
'schema': {
'type': 'integer',
'minimum': 0,
'maximum': 1
},
'required': True
},
'fingerprint': {
'schema': {
'type': 'string',
'format': 'sshfp'
},
'required': True
}
}
def _to_string(self):
return "%(algorithm)s %(fp_type)s %(fingerprint)s" % self
def _from_string(self, value):
algorithm, fp_type, fingerprint = value.split(' ')
self.algorithm = int(algorithm)
self.fp_type = int(fp_type)
self.fingerprint = fingerprint
# The record type is defined in the RFC. This will be used when the record
# is sent by mini-dns.
RECORD_TYPE = 44
class SSHFPList(RecordList):
LIST_ITEM_TYPE = SSHFP