All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.syncope.common.lib.to.AbstractAnnotatedBean Maven / Gradle / Ivy

There is a newer version: 2.1.14
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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 org.apache.syncope.common.lib.to;

import org.apache.syncope.common.lib.AbstractBaseBean;
import com.fasterxml.jackson.annotation.JsonIgnore;
import java.util.Date;
import javax.xml.bind.annotation.XmlType;
import org.apache.commons.lang3.StringUtils;

/**
 * Abstract wrapper for common system information.
 */
@XmlType
public class AbstractAnnotatedBean extends AbstractBaseBean {

    private static final long serialVersionUID = -930797879027642457L;

    /**
     * Username of the user that has created this profile.
     * 

* Cannot be used a reference to an existing user for two main reasons: the creator can be the user admin; * the creator could have been removed. */ private String creator; /** * Creation date. */ private Date creationDate; /** * Username of the user that has performed the last modification to this profile. *

* This field cannot be null: at creation time it have to be initialized with the creator username. *

* The modifier can be the user itself whether the last performed change has been a self-modification. *

* Cannot be used a reference to an existing user for two main reasons: the modifier can be the user admin; * the modifier could have been removed. */ private String lastModifier; /** * Last change date. *

* This field cannot be null: at creation time it has to be initialized with creationDate field value. */ private Date lastChangeDate; public String getCreator() { return creator; } public void setCreator(final String creator) { this.creator = creator; } public Date getCreationDate() { return creationDate; } public void setCreationDate(final Date creationDate) { this.creationDate = creationDate; } public String getLastModifier() { return lastModifier; } public void setLastModifier(final String lastModifier) { this.lastModifier = lastModifier; } public Date getLastChangeDate() { return lastChangeDate; } public void setLastChangeDate(final Date lastChangeDate) { this.lastChangeDate = lastChangeDate; } @JsonIgnore public String getETagValue() { Date etagDate = getLastChangeDate() == null ? getCreationDate() : getLastChangeDate(); return etagDate == null ? StringUtils.EMPTY : String.valueOf(etagDate.getTime()); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy