/************************************************************************* * Copyright 2009-2015 Eucalyptus Systems, Inc. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; version 3 of the License. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see http://www.gnu.org/licenses/. * * Please contact Eucalyptus Systems, Inc., 6755 Hollister Ave., Goleta * CA 93117, USA or visit http://www.eucalyptus.com/licenses/ if you need * additional information or have any questions. ************************************************************************/ package com.eucalyptus.auth.euare.principal; import java.security.cert.X509Certificate; import java.util.Date; import java.util.List; import java.util.Map; import com.eucalyptus.auth.AuthException; import com.eucalyptus.auth.PolicyParseException; import com.eucalyptus.auth.principal.AccessKey; import com.eucalyptus.auth.principal.Certificate; import com.eucalyptus.auth.principal.Policy; import com.eucalyptus.auth.principal.User; /** * */ public interface EuareUser extends User, EuareAccountScopedPrincipal { String USER_GROUP_PREFIX = "_"; String EMAIL = "email"; // LDAP user full DN String DN = "dn"; // LDAP user SASL ID String SASLID = "saslid"; int MAX_PASSWORD_LENGTH = 128; EuareAccount getAccount( ) throws AuthException; void setName( String name ) throws AuthException; String getPath( ); void setPath( String path ) throws AuthException; Date getCreateDate( ); void setEnabled( boolean enabled ) throws AuthException; String getToken( ); void setToken( String token ) throws AuthException; String resetToken( ) throws AuthException; String getPassword( ); void setPassword( String password ) throws AuthException; Long getPasswordExpires( ); void setPasswordExpires( Long time ) throws AuthException; String getInfo( String key ) throws AuthException; Map<String, String> getInfo( ) throws AuthException; void setInfo( String key, String value ) throws AuthException; void setInfo( Map<String, String> newInfo ) throws AuthException; void removeInfo( String key ) throws AuthException; List<AccessKey> getKeys( ) throws AuthException; EuareAccessKey getKey( String keyId ) throws AuthException; void removeKey( String keyId ) throws AuthException; EuareAccessKey createKey( ) throws AuthException; List<Certificate> getCertificates( ) throws AuthException; EuareCertificate getCertificate( String certificateId ) throws AuthException; EuareCertificate addCertificate( String certificateId, X509Certificate certificate ) throws AuthException; void removeCertificate( String certificateId ) throws AuthException; List<EuareGroup> getGroups( ) throws AuthException; List<Policy> getPolicies( ) throws AuthException; /** * Add a policy, fail if exists. */ Policy addPolicy( String name, String policy ) throws AuthException, PolicyParseException; /** * Add or update the named policy. */ Policy putPolicy( String name, String policy ) throws AuthException, PolicyParseException; void removePolicy( String name ) throws AuthException; List<EuareManagedPolicy> getAttachedPolicies() throws AuthException; void attachPolicy( EuareManagedPolicy policy ) throws AuthException; void detachPolicy( EuareManagedPolicy policy ) throws AuthException; boolean isSystemAdmin( ); boolean isSystemUser( ); boolean isAccountAdmin( ); }