Package org.opentides.bean.user

Source Code of org.opentides.bean.user.UserCredential

/*
   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.opentides.bean.user;

import java.util.ArrayList;
import java.util.List;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.JoinColumn;
import javax.persistence.OneToOne;
import javax.persistence.Table;

import org.hibernate.annotations.Cache;
import org.hibernate.annotations.CacheConcurrencyStrategy;
import org.opentides.bean.Auditable;
import org.opentides.bean.AuditableField;
import org.opentides.bean.BaseEntity;
import org.opentides.util.SecurityUtil;


@Entity
@Cache(usage = CacheConcurrencyStrategy.READ_WRITE)
@Table(name="USERS")
public class UserCredential extends BaseEntity implements Auditable {
  private static final long serialVersionUID = -8078097647300665926L;
 
  @Column(name = "USERNAME", unique=true)
  private String username;
 
  @Column(name = "PASSWORD", nullable=false)
  private String password;
 
  private transient String newPassword;

  private transient String confirmPassword;

  @Column(name="ENABLED")
  private Boolean enabled;
 
  @OneToOne
    @JoinColumn(name="USERID", nullable=false)
  private BaseUser user;
 
  /**
   * @return the user
   */
  public BaseUser getUser() {
    return user;
  }
  /**
   * @param user the user to set
   */
  public void setUser(BaseUser user) {
    this.user = user;
  }
  public UserCredential() {
    enabled=false;
  }

  /**
     * Getter method for username.
     *
     * @return the username
     */
    public String getUsername() {
        return username;
    }
    /**
     * Setter method for username.
     *
     * @param username the username to set
     */
    public void setUsername(String username) {
        this.username = username;
    }
    /**
     * Getter method for newPassword.
     *
     * @return the newPassword
     */
    public String getNewPassword() {
        return newPassword;
    }
    /**
     * Setter method for newPassword.
     *
     * @param newPassword the newPassword to set
     */
    public void setNewPassword(String newPassword) {
        this.newPassword = newPassword;
    }
    /**
     * Getter method for confirmPassword.
     *
     * @return the confirmPassword
     */
    public String getConfirmPassword() {
        return confirmPassword;
    }
    /**
     * Setter method for confirmPassword.
     *
     * @param confirmPassword the confirmPassword to set
     */
    public void setConfirmPassword(String confirmPassword) {
        this.confirmPassword = confirmPassword;
    }
    /**
     * Getter method for enabled.
     *
     * @return the enabled
     */
    public Boolean getEnabled() {
        return enabled;
    }
    /**
     * Setter method for enabled.
     *
     * @param enabled the enabled to set
     */
    public void setEnabled(Boolean enabled) {
        this.enabled = enabled;
    }

    /**
     * Matches if the given password matches with this password.
     * @param password
     * @return
     */
    public boolean matchPassword(String password) {
      String encryptedOldPassword = SecurityUtil.encryptPassword(password);
    if (encryptedOldPassword.equals(this.password))
      return true;
    else
      return false;
    }
   
    /**
     * Ensures that password is enrypted according to configured passwordEncoder.
     * @param password
     */
    public void setPassword(String password) {
        this.password = SecurityUtil.encryptPassword(password);
    }

    /* (non-Javadoc)
   * @see java.lang.Object#hashCode()
   */
  @Override
  public int hashCode() {
    final int prime = 31;
    int result = super.hashCode();
    result = prime * result + (enabled ? 1231 : 1237);
    result = prime * result
        + ((password == null) ? 0 : password.hashCode());
      result = prime * result
        + ((username == null) ? 0 : username.hashCode());
    return result;
  }
  /* (non-Javadoc)
   * @see org.opentides.bean.Auditable#getPrimaryField()
   */
  @Override
  public AuditableField getPrimaryField() {
    return new AuditableField("username", "Username");
 
 
  /* (non-Javadoc)
   * @see org.opentides.bean.BaseEntity#getAuditableFields()
   */
  @Override
  public List<AuditableField> getAuditableFields() {
    List<AuditableField> auditableFields = new ArrayList<AuditableField>();
    auditableFields.add(new AuditableField("username", "Username"));
    return auditableFields;
  }

  /* (non-Javadoc)
   * @see java.lang.Object#equals(java.lang.Object)
   */
  @Override
  public boolean equals(Object obj) {
    if (this == obj)
      return true;
    if (!super.equals(obj))
      return false;
    if (getClass() != obj.getClass())
      return false;
    final UserCredential other = (UserCredential) obj;
    if (!enabled.equals(other.enabled))
      return false;
    if (password == null) {
      if (other.password != null)
        return false;
    } else if (!password.equals(other.password))
      return false;
    if (username == null) {
      if (other.username != null)
        return false;
    } else if (!username.equals(other.username))
      return false;
    return true;
  }
}
TOP

Related Classes of org.opentides.bean.user.UserCredential

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.