![JAR search and dependency download from the Maven repository](/logo.png)
br.com.caelum.vraptor.serialization.Serializer Maven / Gradle / Ivy
/***
* Copyright (c) 2009 Caelum - www.caelum.com.br/opensource 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.
*/
package br.com.caelum.vraptor.serialization;
/**
* Serializes given object, including and excluding fields.
*
* @author Lucas Cavalcanti
* @author Guilherme Silveira
* @since 3.0.2
*/
public interface Serializer {
/**
* Exclude these properties in serialization.
* You can add a question mark (?) at the beginning of {@code names} to avoid IllegalArgumentException,
* making it an optional field
* @param names
* @return
* @throws IllegalArgumentException if {@code names} doesn't exists in object
*/
Serializer exclude(String... names);
/**
* Include all properties in serialization.
* @return
*/
Serializer excludeAll();
/**
* Include these properties in serialization.
* You can add a question mark (?) at the beginning of {@code names} to avoid IllegalArgumentException
* making it an optional field
* @param names
* @return
* @throws IllegalArgumentException if {@code names} doesn't exists in object
*/
Serializer include(String... names);
/**
* Include all fields, recursively.
*/
Serializer recursive();
/**
* End method for this fluent interface
*/
void serialize();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy