diff options
| author | kali <kali@leap.se> | 2012-09-24 22:21:50 +0900 | 
|---|---|---|
| committer | kali <kali@leap.se> | 2012-09-24 22:21:50 +0900 | 
| commit | 30570bd89c04a56b35b91a0bc1d5fc00bb6ad266 (patch) | |
| tree | 10364a8c906b34474f0e453fd5a3b29c4d6fba92 /src/leap/eip | |
| parent | 5c32cc7b5e00853b3cc28b5003b92ab009418dff (diff) | |
add schema to JSONLeapConfig classes
and a jsonvalidate function too,
that calls to jsonchemea.validate(self, data) with self.schema
We're using the specs to both purposes now:
* providing a type casting system for our config options (work in
  progress for the type casting)
* json schema validation
Diffstat (limited to 'src/leap/eip')
| -rw-r--r-- | src/leap/eip/specs.py | 148 | 
1 files changed, 78 insertions, 70 deletions
| diff --git a/src/leap/eip/specs.py b/src/leap/eip/specs.py index 05aef590..a10a9623 100644 --- a/src/leap/eip/specs.py +++ b/src/leap/eip/specs.py @@ -8,7 +8,7 @@ PROVIDER_CA_CERT = __branding.get(      'provider_ca_file',      'testprovider-ca-cert.pem') -provider_ca_path = lambda: unicode(os.path.join( +provider_ca_path = lambda: str(os.path.join(      baseconfig.get_default_provider_path(),      'keys', 'ca',      PROVIDER_CA_CERT @@ -24,78 +24,86 @@ client_cert_path = lambda: unicode(os.path.join(  ))  eipconfig_spec = { -    'provider': { -        'type': unicode, -        'default': u"%s" % PROVIDER_DOMAIN, -        'required': True, -    }, -    'transport': { -        'type': unicode, -        'default': u"openvpn", -    }, -    'openvpn_protocol': { -        'type': unicode, -        'default': u"tcp" -    }, -    'openvpn_port': { -        'type': int, -        'default': 80 -    }, -    'openvpn_ca_certificate': { -        'type': unicode,  # path -        'default': provider_ca_path -    }, -    'openvpn_client_certificate': { -        'type': unicode,  # path -        'default': client_cert_path -    }, -    'connect_on_login': { -        'type': bool, -        'default': True -    }, -    'block_cleartext_traffic': { -        'type': bool, -        'default': True -    }, -    'primary_gateway': { -        'type': unicode, -        'default': u"usa_west", -        'required': True -    }, -    'secondary_gateway': { -        'type': unicode, -        'default': u"france" -    }, -    'management_password': { -        'type': unicode +    'description': 'sample eipconfig', +    'type': 'object', +    'properties': { +        'provider': { +            'type': unicode, +            'default': u"%s" % PROVIDER_DOMAIN, +            'required': True, +        }, +        'transport': { +            'type': unicode, +            'default': u"openvpn", +        }, +        'openvpn_protocol': { +            'type': unicode, +            'default': u"tcp" +        }, +        'openvpn_port': { +            'type': int, +            'default': 80 +        }, +        'openvpn_ca_certificate': { +            'type': unicode,  # path +            'default': provider_ca_path +        }, +        'openvpn_client_certificate': { +            'type': unicode,  # path +            'default': client_cert_path +        }, +        'connect_on_login': { +            'type': bool, +            'default': True +        }, +        'block_cleartext_traffic': { +            'type': bool, +            'default': True +        }, +        'primary_gateway': { +            'type': unicode, +            'default': u"usa_west", +            #'required': True +        }, +        'secondary_gateway': { +            'type': unicode, +            'default': u"france" +        }, +        'management_password': { +            'type': unicode +        }      }  }  eipservice_config_spec = { -    'serial': { -        'type': int, -        'required': True, -        'default': 1 -    }, -    'version': { -        'type': unicode, -        'required': True, -        'default': "0.1.0" -    }, -    'capabilities': { -        'type': dict, -        'default': { -            "transport": ["openvpn"], -            "ports": ["80", "53"], -            "protocols": ["udp", "tcp"], -            "static_ips": True, -            "adblock": True} -    }, -    'gateways': { -        'type': list, -        'default': [{"country_code": "us", -                    "label": {"en":"west"}, -                    "capabilities": {}, -                    "hosts": ["1.2.3.4", "1.2.3.5"]}] +    'description': 'sample eip service config', +    'type': 'object', +    'properties': { +        'serial': { +            'type': int, +            'required': True, +            'default': 1 +        }, +        'version': { +            'type': unicode, +            'required': True, +            'default': "0.1.0" +        }, +        'capabilities': { +            'type': dict, +            'default': { +                "transport": ["openvpn"], +                "ports": ["80", "53"], +                "protocols": ["udp", "tcp"], +                "static_ips": True, +                "adblock": True} +        }, +        'gateways': { +            'type': list, +            'default': [{"country_code": "us", +                        "label": {"en":"west"}, +                        "capabilities": {}, +                        "hosts": ["1.2.3.4", "1.2.3.5"]}] +        }      }  } | 
