public class com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy extends com.novell.ldapchai.impl.openldap.entry.OpenLDAPEntry implements com.novell.ldapchai.ChaiPasswordPolicy
{
static final java.util.Set LDAP_PASSWORD_ATTRIBUTES;
private final java.util.Map ruleMap;
private final java.util.Map allEntryValues;
private final com.novell.ldapchai.provider.ChaiProvider provider;
public void <init>(java.lang.String, com.novell.ldapchai.provider.ChaiProvider) throws com.novell.ldapchai.exception.ChaiUnavailableException, com.novell.ldapchai.exception.ChaiOperationException
{
java.util.HashMap v, v;
java.util.function.Supplier v, v, v, v;
java.util.Map v, v, v, v, v, v, v, v;
java.lang.String v;
com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy v;
boolean v, v;
java.util.Set v;
com.novell.ldapchai.provider.ChaiProvider v;
java.lang.Object v;
com.novell.ldapchai.util.internal.ChaiLogger v, v, v, v;
v := @this: com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy;
v := @parameter: java.lang.String;
v := @parameter: com.novell.ldapchai.provider.ChaiProvider;
specialinvoke v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPEntry: void <init>(java.lang.String,com.novell.ldapchai.provider.ChaiProvider)>(v, v);
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: java.util.Map ruleMap> = v;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: java.util.Map allEntryValues> = v;
v = v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: java.util.Map allEntryValues>;
v = <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: java.util.Set LDAP_PASSWORD_ATTRIBUTES>;
v = virtualinvoke v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: java.util.Map readStringAttributes(java.util.Set)>(v);
interfaceinvoke v.<java.util.Map: void putAll(java.util.Map)>(v);
v = <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: com.novell.ldapchai.util.internal.ChaiLogger LOGGER>;
v = staticinvoke <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy$lambda_new_0__91: java.util.function.Supplier bootstrap$(com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy)>(v);
virtualinvoke v.<com.novell.ldapchai.util.internal.ChaiLogger: void trace(java.util.function.Supplier)>(v);
v = v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: java.util.Map allEntryValues>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("pwdCheckQuality");
v = <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: com.novell.ldapchai.util.internal.ChaiLogger LOGGER>;
v = staticinvoke <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy$lambda_new_1__92: java.util.function.Supplier bootstrap$(java.lang.String)>(v);
virtualinvoke v.<com.novell.ldapchai.util.internal.ChaiLogger: void debug(java.util.function.Supplier)>(v);
v = staticinvoke <java.util.Objects: boolean equals(java.lang.Object,java.lang.Object)>("1", v);
if v != 0 goto label;
v = staticinvoke <java.util.Objects: boolean equals(java.lang.Object,java.lang.Object)>("2", v);
if v == 0 goto label;
label:
v = v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: java.util.Map allEntryValues>;
v = specialinvoke v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: java.util.Map readCheckPasswordAttributes()>();
interfaceinvoke v.<java.util.Map: void putAll(java.util.Map)>(v);
label:
v = <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: com.novell.ldapchai.util.internal.ChaiLogger LOGGER>;
v = staticinvoke <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy$lambda_new_2__93: java.util.function.Supplier bootstrap$(com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy)>(v);
virtualinvoke v.<com.novell.ldapchai.util.internal.ChaiLogger: void trace(java.util.function.Supplier)>(v);
v = v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: java.util.Map ruleMap>;
v = v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: java.util.Map allEntryValues>;
v = staticinvoke <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: java.util.Map createRuleMapUsingAttributeValues(java.util.Map)>(v);
interfaceinvoke v.<java.util.Map: void putAll(java.util.Map)>(v);
v = <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: com.novell.ldapchai.util.internal.ChaiLogger LOGGER>;
v = staticinvoke <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy$lambda_new_3__94: java.util.function.Supplier bootstrap$(com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy)>(v);
virtualinvoke v.<com.novell.ldapchai.util.internal.ChaiLogger: void trace(java.util.function.Supplier)>(v);
v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: com.novell.ldapchai.provider.ChaiProvider provider> = v;
return;
}
private java.util.Map readCheckPasswordAttributes()
{
java.lang.Throwable v;
java.net.URL v;
java.util.HashMap v;
java.util.function.Supplier v;
java.util.Map v, v;
int v;
java.lang.String v, v;
com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy v;
boolean v;
java.util.Properties v;
java.util.Iterator v;
com.novell.ldapchai.provider.ChaiConfiguration v;
java.util.Set v;
java.io.IOException v;
com.novell.ldapchai.provider.ChaiSetting v;
com.novell.ldapchai.provider.ChaiProvider v;
java.lang.Object v;
com.novell.ldapchai.util.internal.ChaiLogger v;
java.io.InputStream v;
v := @this: com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy;
v = v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: com.novell.ldapchai.provider.ChaiProvider chaiProvider>;
v = interfaceinvoke v.<com.novell.ldapchai.provider.ChaiProvider: com.novell.ldapchai.provider.ChaiConfiguration getChaiConfiguration()>();
v = <com.novell.ldapchai.provider.ChaiSetting: com.novell.ldapchai.provider.ChaiSetting OPENLDAP_LOCAL_PASSWORD_POLICY_URL>;
v = virtualinvoke v.<com.novell.ldapchai.provider.ChaiConfiguration: java.lang.String getSetting(com.novell.ldapchai.provider.ChaiSetting)>(v);
if v == null goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
if v >= 1 goto label;
label:
v = staticinvoke <java.util.Collections: java.util.Map emptyMap()>();
return v;
label:
v = new java.net.URL;
specialinvoke v.<java.net.URL: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<java.net.URL: java.io.InputStream openStream()>();
v = new java.util.Properties;
specialinvoke v.<java.util.Properties: void <init>()>();
virtualinvoke v.<java.util.Properties: void load(java.io.InputStream)>(v);
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = virtualinvoke v.<java.util.Properties: java.util.Set keySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<java.util.Properties: java.lang.String getProperty(java.lang.String)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
return v;
label:
v := @caughtexception;
v = <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: com.novell.ldapchai.util.internal.ChaiLogger LOGGER>;
v = staticinvoke <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy$lambda_readCheckPasswordAttributes_4__95: java.util.function.Supplier bootstrap$(java.lang.String,java.io.IOException)>(v, v);
virtualinvoke v.<com.novell.ldapchai.util.internal.ChaiLogger: void debug(java.util.function.Supplier)>(v);
label:
goto label;
label:
v := @caughtexception;
throw v;
label:
v = staticinvoke <java.util.Collections: java.util.Map emptyMap()>();
return v;
catch java.io.IOException from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private static java.util.Map createRuleMapUsingAttributeValues(java.util.Map)
{
java.util.Map v;
boolean v, v, v;
com.novell.ldapchai.ChaiPasswordRule[] v;
java.lang.Exception v;
com.novell.ldapchai.ChaiPasswordRule v, v, v, v, v;
com.novell.ldapchai.util.internal.ChaiLogger v, v;
java.util.HashMap v;
java.util.function.Supplier v, v;
int v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v, v;
com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy$Attribute v;
java.lang.Object v, v;
v := @parameter: java.util.Map;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = <com.novell.ldapchai.ChaiPasswordRule: com.novell.ldapchai.ChaiPasswordRule AllowNumeric>;
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);
v = <com.novell.ldapchai.ChaiPasswordRule: com.novell.ldapchai.ChaiPasswordRule AllowSpecial>;
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);
v = <com.novell.ldapchai.ChaiPasswordRule: com.novell.ldapchai.ChaiPasswordRule CaseSensitive>;
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);
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.openldap.entry.OpenLDAPPasswordPolicy$Attribute: com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy$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.openldap.entry.OpenLDAPPasswordPolicy$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.openldap.entry.OpenLDAPPasswordPolicy$Attribute: java.lang.String getLdapAttribute()>();
v = <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: com.novell.ldapchai.util.internal.ChaiLogger LOGGER>;
v = staticinvoke <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy$lambda_createRuleMapUsingAttributeValues_5__96: java.util.function.Supplier bootstrap$(java.lang.String)>(v);
virtualinvoke v.<com.novell.ldapchai.util.internal.ChaiLogger: void trace(java.util.function.Supplier)>(v);
if v == null goto label;
if v == null goto label;
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v == 0 goto label;
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);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
v = virtualinvoke v.<com.novell.ldapchai.ChaiPasswordRule: java.lang.String getKey()>();
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v != 0 goto label;
v = virtualinvoke v.<com.novell.ldapchai.ChaiPasswordRule: java.lang.String getKey()>();
v = virtualinvoke v.<com.novell.ldapchai.ChaiPasswordRule: java.lang.String getDefaultValue()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
v = v + 1;
goto label;
label:
if v == null goto label;
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>("pwdInHistory");
if v == 0 goto label;
label:
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("pwdInHistory");
v = staticinvoke <java.lang.Integer: int parseInt(java.lang.String)>(v);
if v <= 0 goto label;
v = <com.novell.ldapchai.ChaiPasswordRule: com.novell.ldapchai.ChaiPasswordRule UniqueRequired>;
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, "true");
label:
goto label;
label:
v := @caughtexception;
v = <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: com.novell.ldapchai.util.internal.ChaiLogger LOGGER>;
v = staticinvoke <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy$lambda_createRuleMapUsingAttributeValues_6__97: java.util.function.Supplier bootstrap$(java.lang.Exception)>(v);
virtualinvoke v.<com.novell.ldapchai.util.internal.ChaiLogger: void error(java.util.function.Supplier)>(v);
label:
return v;
catch java.lang.Exception from label to label with label;
}
public java.lang.String getValue(java.lang.String)
{
java.util.Map v;
java.lang.Object v;
java.lang.String v;
com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy v;
v := @this: com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy;
v := @parameter: java.lang.String;
v = v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: 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.openldap.entry.OpenLDAPPasswordPolicy v;
v := @this: com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy;
v := @parameter: com.novell.ldapchai.ChaiPasswordRule;
v = v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: 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.openldap.entry.OpenLDAPPasswordPolicy v;
v := @this: com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy;
v = v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: 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.openldap.entry.OpenLDAPPasswordPolicy v;
v := @this: com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy;
return v;
}
public com.novell.ldapchai.util.PasswordRuleHelper getRuleHelper()
{
com.novell.ldapchai.util.GenericRuleHelper v;
com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy v;
v := @this: com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy;
v = new com.novell.ldapchai.util.GenericRuleHelper;
specialinvoke v.<com.novell.ldapchai.util.GenericRuleHelper: void <init>(com.novell.ldapchai.ChaiPasswordPolicy)>(v);
return v;
}
public java.lang.String getLdapObjectClassName()
{
com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy v;
v := @this: com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy;
return "pwdPolicy";
}
public java.lang.String getSourceDN()
{
java.lang.String v;
com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy v;
v := @this: com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy;
v = virtualinvoke v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: java.lang.String getEntryDN()>();
return v;
}
static void <clinit>()
{
java.util.HashSet v;
com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy$Attribute[] v;
int v, v;
java.util.Set v;
java.lang.String v;
com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy$Attribute v;
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>()>();
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>("pwdCheckQuality");
v = staticinvoke <com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy$Attribute: com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy$Attribute[] values()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy$Attribute: java.lang.String getLdapAttribute()>();
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v = staticinvoke <java.util.Collections: java.util.Set unmodifiableSet(java.util.Set)>(v);
<com.novell.ldapchai.impl.openldap.entry.OpenLDAPPasswordPolicy: java.util.Set LDAP_PASSWORD_ATTRIBUTES> = v;
return;
}
}