class com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl extends com.novell.ldapchai.impl.edir.entry.TopImpl implements com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy
{
static final java.util.Collection LDAP_PASSWORD_ATTRIBUTES;
private final java.util.Map ruleMap;
private final java.util.Map allEntryValues;
void <init>(java.lang.String, com.novell.ldapchai.provider.ChaiProvider) throws com.novell.ldapchai.exception.ChaiUnavailableException, com.novell.ldapchai.exception.ChaiOperationException
{
com.novell.ldapchai.util.SearchHelper v;
java.util.HashMap v, v;
java.util.Map v, v, v, v;
java.lang.String v, v, v;
com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl v;
java.util.Collection v;
com.novell.ldapchai.provider.ChaiProvider v, v;
java.lang.Object v;
com.novell.ldapchai.provider.SearchScope v;
v := @this: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl;
v := @parameter: java.lang.String;
v := @parameter: com.novell.ldapchai.provider.ChaiProvider;
specialinvoke v.<com.novell.ldapchai.impl.edir.entry.TopImpl: void <init>(java.lang.String,com.novell.ldapchai.provider.ChaiProvider)>(v, v);
v = new com.novell.ldapchai.util.SearchHelper;
specialinvoke v.<com.novell.ldapchai.util.SearchHelper: void <init>()>();
virtualinvoke v.<com.novell.ldapchai.util.SearchHelper: void setFilter(java.lang.String)>("(objectClass=*)");
v = <com.novell.ldapchai.provider.SearchScope: com.novell.ldapchai.provider.SearchScope BASE>;
virtualinvoke v.<com.novell.ldapchai.util.SearchHelper: void setSearchScope(com.novell.ldapchai.provider.SearchScope)>(v);
v = <com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl: java.util.Collection LDAP_PASSWORD_ATTRIBUTES>;
virtualinvoke v.<com.novell.ldapchai.util.SearchHelper: void setAttributes(java.util.Collection)>(v);
v = virtualinvoke v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl: com.novell.ldapchai.provider.ChaiProvider getChaiProvider()>();
v = virtualinvoke v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl: java.lang.String getEntryDN()>();
v = interfaceinvoke v.<com.novell.ldapchai.provider.ChaiProvider: java.util.Map searchMultiValues(java.lang.String,com.novell.ldapchai.util.SearchHelper)>(v, v);
v = virtualinvoke v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl: java.lang.String getEntryDN()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>(java.util.Map)>(v);
v = staticinvoke <java.util.Collections: java.util.Map unmodifiableMap(java.util.Map)>(v);
v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl: java.util.Map allEntryValues> = v;
v = new java.util.HashMap;
v = staticinvoke <com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl: java.util.Map createRuleMapUsingAttributeValues(java.util.Map)>(v);
specialinvoke v.<java.util.HashMap: void <init>(java.util.Map)>(v);
v = staticinvoke <java.util.Collections: java.util.Map unmodifiableMap(java.util.Map)>(v);
v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl: java.util.Map ruleMap> = v;
return;
}
public java.lang.String getLdapObjectClassName()
{
com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl v;
v := @this: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl;
return "nspmPasswordPolicy";
}
public java.lang.String getChallengeSetDN()
{
com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute v;
java.util.Map v;
java.lang.Object v, v;
java.lang.String v;
com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl v;
boolean v;
v := @this: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl;
v = v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl: java.util.Map allEntryValues>;
v = <com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute CHALLENGE_SET_DN>;
v = virtualinvoke v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute: java.lang.String getLdapAttribute()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
goto label;
label:
v = "";
label:
return v;
}
public java.lang.String getSourceDN()
{
java.lang.String v;
com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl v;
v := @this: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl;
v = virtualinvoke v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl: java.lang.String getEntryDN()>();
return v;
}
public java.util.List testPasswordForErrors(java.lang.String)
{
java.lang.UnsupportedOperationException v;
java.lang.String v;
com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl v;
v := @this: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl;
v := @parameter: java.lang.String;
v = new java.lang.UnsupportedOperationException;
specialinvoke v.<java.lang.UnsupportedOperationException: void <init>(java.lang.String)>("not implemented");
throw v;
}
public com.novell.ldapchai.util.PasswordRuleHelper getRuleHelper()
{
com.novell.ldapchai.util.GenericRuleHelper v;
com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl v;
v := @this: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl;
v = new com.novell.ldapchai.util.GenericRuleHelper;
specialinvoke v.<com.novell.ldapchai.util.GenericRuleHelper: void <init>(com.novell.ldapchai.ChaiPasswordPolicy)>(v);
return v;
}
private static java.util.Map createRuleMapUsingComplexityRules(java.lang.String)
{
com.novell.ldapchai.impl.edir.value.NspmComplexityRules v;
java.util.HashMap v;
com.novell.ldapchai.ChaiPasswordRule v, v;
java.lang.String v, v, v, v;
boolean v;
v := @parameter: java.lang.String;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = new com.novell.ldapchai.impl.edir.value.NspmComplexityRules;
specialinvoke v.<com.novell.ldapchai.impl.edir.value.NspmComplexityRules: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<com.novell.ldapchai.impl.edir.value.NspmComplexityRules: boolean isMsComplexityPolicy()>();
if v == 0 goto label;
v = <com.novell.ldapchai.ChaiPasswordRule: com.novell.ldapchai.ChaiPasswordRule ADComplexity>;
v = virtualinvoke v.<com.novell.ldapchai.ChaiPasswordRule: java.lang.String getKey()>();
v = staticinvoke <java.lang.String: java.lang.String valueOf(boolean)>(1);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
return v;
label:
v = <com.novell.ldapchai.ChaiPasswordRule: com.novell.ldapchai.ChaiPasswordRule NovellComplexityRules>;
v = virtualinvoke v.<com.novell.ldapchai.ChaiPasswordRule: java.lang.String getKey()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
return v;
}
private static java.util.Map createRuleMapUsingAttributeValues(java.util.Map)
{
java.util.ListIterator v;
com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl$PolicyOptions v;
java.util.Map v, v;
boolean v, v, v, v, v;
com.novell.ldapchai.ChaiPasswordRule[] v;
com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute v, v, v, v, v;
com.novell.ldapchai.ChaiPasswordRule v, v, v;
java.util.HashMap v;
java.util.ArrayList v;
int v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.Object v, v, v, v, v, v, v, v;
v := @parameter: java.util.Map;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = <com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute AD_COMPLEXITY_RULES>;
v = virtualinvoke v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute: java.lang.String getLdapAttribute()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
v = staticinvoke <com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl: java.util.Map createRuleMapUsingComplexityRules(java.lang.String)>(v);
interfaceinvoke v.<java.util.Map: void putAll(java.util.Map)>(v);
label:
v = staticinvoke <com.novell.ldapchai.ChaiPasswordRule: com.novell.ldapchai.ChaiPasswordRule[] values()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = staticinvoke <com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute attributeForRule(com.novell.ldapchai.ChaiPasswordRule)>(v);
if v == null goto label;
v = virtualinvoke v.<com.novell.ldapchai.ChaiPasswordRule: java.lang.String getKey()>();
v = virtualinvoke v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute: java.lang.String getDefaultValue()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = virtualinvoke v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute: java.lang.String getLdapAttribute()>();
if v == null goto label;
v = virtualinvoke v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute: java.lang.String getLdapAttribute()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<com.novell.ldapchai.ChaiPasswordRule: java.lang.String getKey()>();
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
v = v + 1;
goto label;
label:
v = <com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute DISALLOWED_ATTRIBUTES>;
v = virtualinvoke v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute: java.lang.String getLdapAttribute()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = interfaceinvoke v.<java.util.List: java.util.ListIterator listIterator()>();
label:
v = interfaceinvoke v.<java.util.ListIterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.ListIterator: java.lang.Object next()>();
v = virtualinvoke v.<java.lang.String: java.lang.String replaceAll(java.lang.String,java.lang.String)>("[ :]", "");
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = staticinvoke <com.novell.ldapchai.util.internal.StringHelper: java.lang.String stringCollectionToString(java.util.Collection,java.lang.String)>(v, "\n");
v = <com.novell.ldapchai.ChaiPasswordRule: com.novell.ldapchai.ChaiPasswordRule DisallowedAttributes>;
v = virtualinvoke v.<com.novell.ldapchai.ChaiPasswordRule: java.lang.String getKey()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
v = <com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute PASSWORD_POLICY_OPTIONS>;
v = virtualinvoke v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute: java.lang.String getLdapAttribute()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
v = <com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute PASSWORD_POLICY_OPTIONS>;
v = virtualinvoke v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute: java.lang.String getDefaultValue()>();
v = staticinvoke <java.lang.Integer: int parseInt(java.lang.String)>(v);
v = staticinvoke <com.novell.ldapchai.util.internal.StringHelper: int convertStrToInt(java.lang.String,int)>(v, v);
v = new com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl$PolicyOptions;
v = staticinvoke <java.lang.String: java.lang.String valueOf(int)>(v);
specialinvoke v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl$PolicyOptions: void <init>(java.lang.String)>(v);
v = <com.novell.ldapchai.ChaiPasswordRule: com.novell.ldapchai.ChaiPasswordRule PolicyEnabled>;
v = virtualinvoke v.<com.novell.ldapchai.ChaiPasswordRule: java.lang.String getKey()>();
v = virtualinvoke v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl$PolicyOptions: boolean isPolicyEnabled()>();
v = staticinvoke <java.lang.Boolean: java.lang.String toString(boolean)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
return v;
}
public java.lang.String getValue(java.lang.String)
{
java.util.Map v;
java.lang.Object v;
java.lang.String v;
com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl v;
v := @this: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl;
v := @parameter: java.lang.String;
v = v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl: java.util.Map ruleMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
return v;
}
public java.lang.String getValue(com.novell.ldapchai.ChaiPasswordRule)
{
java.util.Map v;
java.lang.Object v;
com.novell.ldapchai.ChaiPasswordRule v;
java.lang.String v;
com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl v;
v := @this: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl;
v := @parameter: com.novell.ldapchai.ChaiPasswordRule;
v = v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl: java.util.Map ruleMap>;
v = virtualinvoke v.<com.novell.ldapchai.ChaiPasswordRule: java.lang.String getKey()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
return v;
}
public java.util.Set getKeys()
{
java.util.Map v;
java.util.Set v, v;
com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl v;
v := @this: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl;
v = v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl: java.util.Map ruleMap>;
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
v = staticinvoke <java.util.Collections: java.util.Set unmodifiableSet(java.util.Set)>(v);
return v;
}
public com.novell.ldapchai.ChaiEntry getPolicyEntry()
{
com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl v;
v := @this: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl;
return v;
}
static void <clinit>()
{
com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute[] v;
com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute v;
java.util.Collection v;
int v, v;
java.lang.String v;
java.util.ArrayList v;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = staticinvoke <com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute: com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute[] values()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicy$Attribute: java.lang.String getLdapAttribute()>();
virtualinvoke v.<java.util.ArrayList: boolean add(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v = staticinvoke <java.util.Collections: java.util.Collection unmodifiableCollection(java.util.Collection)>(v);
<com.novell.ldapchai.impl.edir.entry.NspmPasswordPolicyImpl: java.util.Collection LDAP_PASSWORD_ATTRIBUTES> = v;
return;
}
}