| // Copyright 2015 The Weave Authors. All rights reserved. | 
 | // Use of this source code is governed by a BSD-style license that can be | 
 | // found in the LICENSE file. | 
 |  | 
 | #ifndef LIBWEAVE_SRC_COMMANDS_OBJECT_SCHEMA_H_ | 
 | #define LIBWEAVE_SRC_COMMANDS_OBJECT_SCHEMA_H_ | 
 |  | 
 | #include <map> | 
 | #include <memory> | 
 | #include <string> | 
 |  | 
 | #include <weave/error.h> | 
 |  | 
 | namespace base { | 
 | class Value; | 
 | class DictionaryValue; | 
 | }  // namespace base | 
 |  | 
 | namespace weave { | 
 |  | 
 | class PropType; | 
 |  | 
 | // ObjectSchema is a class representing an object definition in GCD command | 
 | // schema. This could represent a GCD command definition, but also it can be | 
 | // used when defining custom object types for command properties such as | 
 | // output media type (paper) for print command. The schema definition for | 
 | // these type of object description is the same. | 
 | class ObjectSchema final { | 
 |  public: | 
 |   // Do not inline the constructor/destructor to allow forward-declared type | 
 |   // PropType to be part of |properties_| member. | 
 |   ObjectSchema(); | 
 |   ~ObjectSchema(); | 
 |  | 
 |   // Properties is a string-to-PropType map representing a list of | 
 |   // properties defined for a command/object. The key is the parameter | 
 |   // name and the value is the parameter type definition object. | 
 |   using Properties = std::map<std::string, std::unique_ptr<PropType>>; | 
 |  | 
 |   // Makes a full copy of this object. | 
 |   virtual std::unique_ptr<ObjectSchema> Clone() const; | 
 |  | 
 |   // Add a new parameter definition. | 
 |   void AddProp(const std::string& name, std::unique_ptr<PropType> prop); | 
 |  | 
 |   // Finds parameter type definition by name. Returns nullptr if not found. | 
 |   const PropType* GetProp(const std::string& name) const; | 
 |  | 
 |   // Gets the list of all the properties defined. | 
 |   const Properties& GetProps() const { return properties_; } | 
 |  | 
 |   // Marks the property with given name as "required". If |name| specifies | 
 |   // an unknown property, false is returned and |error| is set with detailed | 
 |   // error message for the failure. | 
 |   bool MarkPropRequired(const std::string& name, ErrorPtr* error); | 
 |  | 
 |   // Specify whether extra properties are allowed on objects described by | 
 |   // this schema. When validating a value of an object type, we can | 
 |   // make sure that the value has only the properties explicitly defined by | 
 |   // the schema and no other (custom) properties are allowed. | 
 |   // This is to support JSON Schema's "additionalProperties" specification. | 
 |   bool GetExtraPropertiesAllowed() const { return extra_properties_allowed_; } | 
 |   void SetExtraPropertiesAllowed(bool allowed) { | 
 |     extra_properties_allowed_ = allowed; | 
 |   } | 
 |  | 
 |   // Saves the object schema to JSON. When |full_schema| is set to true, | 
 |   // then all properties and constraints are saved, otherwise, only | 
 |   // the overridden (not inherited) ones are saved. | 
 |   std::unique_ptr<base::DictionaryValue> ToJson(bool full_schema, | 
 |                                                 bool in_command_def) const; | 
 |  | 
 |   // Loads the object schema from JSON. If |object_schema| is not nullptr, it is | 
 |   // used as a base schema to inherit omitted properties and constraints from. | 
 |   bool FromJson(const base::DictionaryValue* value, | 
 |                 const ObjectSchema* object_schema, | 
 |                 ErrorPtr* error); | 
 |  | 
 |   // Helper factory method to create a new instance of ObjectSchema object. | 
 |   static std::unique_ptr<ObjectSchema> Create(); | 
 |  | 
 |   // Helper method to load property type definitions from JSON. | 
 |   static std::unique_ptr<PropType> PropFromJson(const base::Value& value, | 
 |                                                 const PropType* base_schema, | 
 |                                                 ErrorPtr* error); | 
 |  | 
 |  private: | 
 |   // Internal parameter type definition map. | 
 |   Properties properties_; | 
 |   bool extra_properties_allowed_{false}; | 
 | }; | 
 |  | 
 | }  // namespace weave | 
 |  | 
 | #endif  // LIBWEAVE_SRC_COMMANDS_OBJECT_SCHEMA_H_ |