common-authorization/src/main/java/org/gcube/common/authorization/library/policies/User2ServicePolicy.java

92 lines
2.1 KiB
Java

package org.gcube.common.authorization.library.policies;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlRootElement;
@XmlRootElement
@XmlAccessorType(XmlAccessType.FIELD)
public class User2ServicePolicy extends Policy {
private UserEntity entity;
private String context;
private ServiceAccess serviceAccess;
protected User2ServicePolicy(){}
public User2ServicePolicy(String context, ServiceAccess serviceAccess, UserEntity entity) {
this.context = context;
this.serviceAccess = serviceAccess;
this.entity = entity;
}
public UserEntity getEntity() {
return entity;
}
public ServiceAccess getServiceAccess() {
return serviceAccess;
}
@Override
public PolicyType getPolicyType() {
return PolicyType.USER;
}
@Override
public String getPolicyAsString() {
return this.context+","+serviceAccess.getAsString()+","+entity.getAsString();
}
public String getContext() {
return context;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((entity == null) ? 0 : entity.hashCode());
result = prime * result
+ ((context == null) ? 0 : context.hashCode());
result = prime * result
+ ((serviceAccess == null) ? 0 : serviceAccess.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
User2ServicePolicy other = (User2ServicePolicy) obj;
if (entity == null) {
if (other.entity != null)
return false;
} else if (!entity.equals(other.entity))
return false;
if (context == null) {
if (other.context != null)
return false;
} else if (!context.equals(other.context))
return false;
if (serviceAccess == null) {
if (other.serviceAccess != null)
return false;
} else if (!serviceAccess.equals(other.serviceAccess))
return false;
return true;
}
@Override
public String toString() {
return "User2ServicePolicy [entity=" + entity + ", environment="
+ context + ", serviceAccess=" + serviceAccess + "]";
}
}