/*
* Copyright Ericsson AB 2011-2014. All Rights Reserved.
*
* The contents of this file are subject to the Lesser GNU Public License,
* (the "License"), either version 2.1 of the License, or
* (at your option) any later version.; you may not use this file except in
* compliance with the License. You should have received a copy of the
* License along with this software. If not, it can be
* retrieved online at https://www.gnu.org/licenses/lgpl.html. Moreover
* it could also be requested from Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
* BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO
* WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW.
* EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR
* OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY KIND,
* EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
* LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE,
* YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
*
* IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
* WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
* REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU FOR
* DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL
* DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE LIBRARY
* (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED
* INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE
* OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF SUCH
* HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
*
*/
package com.ericsson.deviceaccess.spi.schema;
import java.util.ArrayList;
import java.util.List;
import java.util.function.Consumer;
/**
* Implementation of a service schema.
*/
public class ServiceSchema {
private String name;
private List<ActionSchema> actionSchemas = new ArrayList<>();
private List<ParameterSchema> propertySchemas = new ArrayList<>();
/**
* Creates schema with specified name.
*
* @param name
*/
private ServiceSchema(String name) {
this.name = name;
}
/**
* Returns the name of the service.
*
* @return the name of the service
*/
public String getName() {
return name;
}
/**
* Gets the action schemas defined for this schema.
*
* @return the actions defined for this schema
*/
public List<ActionSchema> getActionSchemas() {
return actionSchemas;
}
/**
* Gets the parameters for this service
*
* @return
*/
public List<ParameterSchema> getPropertiesSchemas() {
return propertySchemas;
}
/**
* Builder for creating ServiceSchema instances.
*/
public static class Builder {
private String name;
private final List<ActionSchema> actionSchemas = new ArrayList<>();
private final List<ParameterSchema> propertieSchemas = new ArrayList<>();
/**
* Create builder for a service with the specified name.
*
*/
public Builder() {
}
public Builder(String name) {
this.name = name;
}
public Builder setName(String name) {
this.name = name;
return this;
}
/**
* Adds an action schema.
*
* @param consumer
* @return the builder
*/
public Builder addAction(Consumer<ActionSchema.Builder> consumer) {
ActionSchema.Builder builder = new ActionSchema.Builder();
consumer.accept(builder);
actionSchemas.add(builder.build());
return this;
}
public Builder addAction(ActionSchema action) {
actionSchemas.add(action);
return this;
}
public Builder addAction(String name) {
actionSchemas.add(new ActionSchema.Builder(name).build());
return this;
}
/**
* Adds a parameter schema.
*
* @param consumer
* @return the builder
*/
public Builder addProperty(Consumer<ParameterSchema.Builder> consumer) {
ParameterSchema.Builder builder = new ParameterSchema.Builder();
consumer.accept(builder);
propertieSchemas.add(builder.build());
return this;
}
public Builder addProperty(ParameterSchema parameter) {
propertieSchemas.add(parameter);
return this;
}
public Builder addProperty(String name, Class<?> type) {
propertieSchemas.add(new ParameterSchema.Builder(name, type).build());
return this;
}
/**
* Builds the schema.
*
* @return the built schema
*/
public ServiceSchema build() {
if (name == null) {
throw new ServiceSchemaError("Name must be specified");
}
ServiceSchema serviceSchema = new ServiceSchema(name);
actionSchemas.forEach(serviceSchema.actionSchemas::add);
propertieSchemas.forEach(serviceSchema.propertySchemas::add);
return serviceSchema;
}
}
}