001/*
002 * CDDL HEADER START
003 *
004 * The contents of this file are subject to the terms of the
005 * Common Development and Distribution License, Version 1.0 only
006 * (the "License").  You may not use this file except in compliance
007 * with the License.
008 *
009 * You can obtain a copy of the license at legal-notices/CDDLv1_0.txt
010 * or http://forgerock.org/license/CDDLv1.0.html.
011 * See the License for the specific language governing permissions
012 * and limitations under the License.
013 *
014 * When distributing Covered Code, include this CDDL HEADER in each
015 * file and include the License file at legal-notices/CDDLv1_0.txt.
016 * If applicable, add the following below this CDDL HEADER, with the
017 * fields enclosed by brackets "[]" replaced with your own identifying
018 * information:
019 *      Portions Copyright [yyyy] [name of copyright owner]
020 *
021 * CDDL HEADER END
022 *
023 *
024 *      Copyright 2008 Sun Microsystems, Inc.
025 */
026package org.forgerock.opendj.server.config.meta;
027
028
029
030import org.forgerock.opendj.config.AdministratorAction;
031import org.forgerock.opendj.config.BooleanPropertyDefinition;
032import org.forgerock.opendj.config.ClassPropertyDefinition;
033import org.forgerock.opendj.config.client.ConcurrentModificationException;
034import org.forgerock.opendj.config.client.ManagedObject;
035import org.forgerock.opendj.config.client.MissingMandatoryPropertiesException;
036import org.forgerock.opendj.config.client.OperationRejectedException;
037import org.forgerock.opendj.config.DefaultBehaviorProvider;
038import org.forgerock.opendj.config.DefinedDefaultBehaviorProvider;
039import org.forgerock.opendj.config.IntegerPropertyDefinition;
040import org.forgerock.opendj.config.ManagedObjectAlreadyExistsException;
041import org.forgerock.opendj.config.ManagedObjectDefinition;
042import org.forgerock.opendj.config.PropertyOption;
043import org.forgerock.opendj.config.PropertyProvider;
044import org.forgerock.opendj.config.server.ConfigurationChangeListener;
045import org.forgerock.opendj.config.server.ServerManagedObject;
046import org.forgerock.opendj.config.Tag;
047import org.forgerock.opendj.config.UndefinedDefaultBehaviorProvider;
048import org.forgerock.opendj.ldap.DN;
049import org.forgerock.opendj.ldap.LdapException;
050import org.forgerock.opendj.server.config.client.SimilarityBasedPasswordValidatorCfgClient;
051import org.forgerock.opendj.server.config.server.PasswordValidatorCfg;
052import org.forgerock.opendj.server.config.server.SimilarityBasedPasswordValidatorCfg;
053
054
055
056/**
057 * An interface for querying the Similarity Based Password Validator
058 * managed object definition meta information.
059 * <p>
060 * The Similarity Based Password Validator determines whether a
061 * proposed password is acceptable by measuring how similar it is to
062 * the user's current password.
063 */
064public final class SimilarityBasedPasswordValidatorCfgDefn extends ManagedObjectDefinition<SimilarityBasedPasswordValidatorCfgClient, SimilarityBasedPasswordValidatorCfg> {
065
066  /** The singleton configuration definition instance. */
067  private static final SimilarityBasedPasswordValidatorCfgDefn INSTANCE = new SimilarityBasedPasswordValidatorCfgDefn();
068
069
070
071  /** The "java-class" property definition. */
072  private static final ClassPropertyDefinition PD_JAVA_CLASS;
073
074
075
076  /** The "min-password-difference" property definition. */
077  private static final IntegerPropertyDefinition PD_MIN_PASSWORD_DIFFERENCE;
078
079
080
081  /** Build the "java-class" property definition. */
082  static {
083      ClassPropertyDefinition.Builder builder = ClassPropertyDefinition.createBuilder(INSTANCE, "java-class");
084      builder.setOption(PropertyOption.MANDATORY);
085      builder.setOption(PropertyOption.ADVANCED);
086      builder.setAdministratorAction(new AdministratorAction(AdministratorAction.Type.COMPONENT_RESTART, INSTANCE, "java-class"));
087      DefaultBehaviorProvider<String> provider = new DefinedDefaultBehaviorProvider<String>("org.opends.server.extensions.SimilarityBasedPasswordValidator");
088      builder.setDefaultBehaviorProvider(provider);
089      builder.addInstanceOf("org.opends.server.api.PasswordValidator");
090      PD_JAVA_CLASS = builder.getInstance();
091      INSTANCE.registerPropertyDefinition(PD_JAVA_CLASS);
092  }
093
094
095
096  /** Build the "min-password-difference" property definition. */
097  static {
098      IntegerPropertyDefinition.Builder builder = IntegerPropertyDefinition.createBuilder(INSTANCE, "min-password-difference");
099      builder.setOption(PropertyOption.MANDATORY);
100      builder.setAdministratorAction(new AdministratorAction(AdministratorAction.Type.NONE, INSTANCE, "min-password-difference"));
101      builder.setDefaultBehaviorProvider(new UndefinedDefaultBehaviorProvider<Integer>());
102      builder.setUpperLimit(2147483647);
103      builder.setLowerLimit(0);
104      PD_MIN_PASSWORD_DIFFERENCE = builder.getInstance();
105      INSTANCE.registerPropertyDefinition(PD_MIN_PASSWORD_DIFFERENCE);
106  }
107
108
109
110  // Register the tags associated with this managed object definition.
111  static {
112    INSTANCE.registerTag(Tag.valueOf("user-management"));
113  }
114
115
116
117  /**
118   * Get the Similarity Based Password Validator configuration
119   * definition singleton.
120   *
121   * @return Returns the Similarity Based Password Validator
122   *         configuration definition singleton.
123   */
124  public static SimilarityBasedPasswordValidatorCfgDefn getInstance() {
125    return INSTANCE;
126  }
127
128
129
130  /**
131   * Private constructor.
132   */
133  private SimilarityBasedPasswordValidatorCfgDefn() {
134    super("similarity-based-password-validator", PasswordValidatorCfgDefn.getInstance());
135  }
136
137
138
139  /** {@inheritDoc} */
140  public SimilarityBasedPasswordValidatorCfgClient createClientConfiguration(
141      ManagedObject<? extends SimilarityBasedPasswordValidatorCfgClient> impl) {
142    return new SimilarityBasedPasswordValidatorCfgClientImpl(impl);
143  }
144
145
146
147  /** {@inheritDoc} */
148  public SimilarityBasedPasswordValidatorCfg createServerConfiguration(
149      ServerManagedObject<? extends SimilarityBasedPasswordValidatorCfg> impl) {
150    return new SimilarityBasedPasswordValidatorCfgServerImpl(impl);
151  }
152
153
154
155  /** {@inheritDoc} */
156  public Class<SimilarityBasedPasswordValidatorCfg> getServerConfigurationClass() {
157    return SimilarityBasedPasswordValidatorCfg.class;
158  }
159
160
161
162  /**
163   * Get the "enabled" property definition.
164   * <p>
165   * Indicates whether the password validator is enabled for use.
166   *
167   * @return Returns the "enabled" property definition.
168   */
169  public BooleanPropertyDefinition getEnabledPropertyDefinition() {
170    return PasswordValidatorCfgDefn.getInstance().getEnabledPropertyDefinition();
171  }
172
173
174
175  /**
176   * Get the "java-class" property definition.
177   * <p>
178   * Specifies the fully-qualified name of the Java class that
179   * provides the password validator implementation.
180   *
181   * @return Returns the "java-class" property definition.
182   */
183  public ClassPropertyDefinition getJavaClassPropertyDefinition() {
184    return PD_JAVA_CLASS;
185  }
186
187
188
189  /**
190   * Get the "min-password-difference" property definition.
191   * <p>
192   * Specifies the minimum difference of new and old password.
193   * <p>
194   * A value of zero indicates that no difference between passwords is
195   * acceptable.
196   *
197   * @return Returns the "min-password-difference" property definition.
198   */
199  public IntegerPropertyDefinition getMinPasswordDifferencePropertyDefinition() {
200    return PD_MIN_PASSWORD_DIFFERENCE;
201  }
202
203
204
205  /**
206   * Managed object client implementation.
207   */
208  private static class SimilarityBasedPasswordValidatorCfgClientImpl implements
209    SimilarityBasedPasswordValidatorCfgClient {
210
211    /** Private implementation. */
212    private ManagedObject<? extends SimilarityBasedPasswordValidatorCfgClient> impl;
213
214
215
216    /** Private constructor. */
217    private SimilarityBasedPasswordValidatorCfgClientImpl(
218        ManagedObject<? extends SimilarityBasedPasswordValidatorCfgClient> impl) {
219      this.impl = impl;
220    }
221
222
223
224    /** {@inheritDoc} */
225    public Boolean isEnabled() {
226      return impl.getPropertyValue(INSTANCE.getEnabledPropertyDefinition());
227    }
228
229
230
231    /** {@inheritDoc} */
232    public void setEnabled(boolean value) {
233      impl.setPropertyValue(INSTANCE.getEnabledPropertyDefinition(), value);
234    }
235
236
237
238    /** {@inheritDoc} */
239    public String getJavaClass() {
240      return impl.getPropertyValue(INSTANCE.getJavaClassPropertyDefinition());
241    }
242
243
244
245    /** {@inheritDoc} */
246    public void setJavaClass(String value) {
247      impl.setPropertyValue(INSTANCE.getJavaClassPropertyDefinition(), value);
248    }
249
250
251
252    /** {@inheritDoc} */
253    public Integer getMinPasswordDifference() {
254      return impl.getPropertyValue(INSTANCE.getMinPasswordDifferencePropertyDefinition());
255    }
256
257
258
259    /** {@inheritDoc} */
260    public void setMinPasswordDifference(int value) {
261      impl.setPropertyValue(INSTANCE.getMinPasswordDifferencePropertyDefinition(), value);
262    }
263
264
265
266    /** {@inheritDoc} */
267    public ManagedObjectDefinition<? extends SimilarityBasedPasswordValidatorCfgClient, ? extends SimilarityBasedPasswordValidatorCfg> definition() {
268      return INSTANCE;
269    }
270
271
272
273    /** {@inheritDoc} */
274    public PropertyProvider properties() {
275      return impl;
276    }
277
278
279
280    /** {@inheritDoc} */
281    public void commit() throws ManagedObjectAlreadyExistsException,
282        MissingMandatoryPropertiesException, ConcurrentModificationException,
283        OperationRejectedException, LdapException {
284      impl.commit();
285    }
286
287
288
289    /** {@inheritDoc} */
290    public String toString() {
291      return impl.toString();
292    }
293  }
294
295
296
297  /**
298   * Managed object server implementation.
299   */
300  private static class SimilarityBasedPasswordValidatorCfgServerImpl implements
301    SimilarityBasedPasswordValidatorCfg {
302
303    /** Private implementation. */
304    private ServerManagedObject<? extends SimilarityBasedPasswordValidatorCfg> impl;
305
306    /** The value of the "enabled" property. */
307    private final boolean pEnabled;
308
309    /** The value of the "java-class" property. */
310    private final String pJavaClass;
311
312    /** The value of the "min-password-difference" property. */
313    private final int pMinPasswordDifference;
314
315
316
317    /** Private constructor. */
318    private SimilarityBasedPasswordValidatorCfgServerImpl(ServerManagedObject<? extends SimilarityBasedPasswordValidatorCfg> impl) {
319      this.impl = impl;
320      this.pEnabled = impl.getPropertyValue(INSTANCE.getEnabledPropertyDefinition());
321      this.pJavaClass = impl.getPropertyValue(INSTANCE.getJavaClassPropertyDefinition());
322      this.pMinPasswordDifference = impl.getPropertyValue(INSTANCE.getMinPasswordDifferencePropertyDefinition());
323    }
324
325
326
327    /** {@inheritDoc} */
328    public void addSimilarityBasedChangeListener(
329        ConfigurationChangeListener<SimilarityBasedPasswordValidatorCfg> listener) {
330      impl.registerChangeListener(listener);
331    }
332
333
334
335    /** {@inheritDoc} */
336    public void removeSimilarityBasedChangeListener(
337        ConfigurationChangeListener<SimilarityBasedPasswordValidatorCfg> listener) {
338      impl.deregisterChangeListener(listener);
339    }
340    /** {@inheritDoc} */
341    public void addChangeListener(
342        ConfigurationChangeListener<PasswordValidatorCfg> listener) {
343      impl.registerChangeListener(listener);
344    }
345
346
347
348    /** {@inheritDoc} */
349    public void removeChangeListener(
350        ConfigurationChangeListener<PasswordValidatorCfg> listener) {
351      impl.deregisterChangeListener(listener);
352    }
353
354
355
356    /** {@inheritDoc} */
357    public boolean isEnabled() {
358      return pEnabled;
359    }
360
361
362
363    /** {@inheritDoc} */
364    public String getJavaClass() {
365      return pJavaClass;
366    }
367
368
369
370    /** {@inheritDoc} */
371    public int getMinPasswordDifference() {
372      return pMinPasswordDifference;
373    }
374
375
376
377    /** {@inheritDoc} */
378    public Class<? extends SimilarityBasedPasswordValidatorCfg> configurationClass() {
379      return SimilarityBasedPasswordValidatorCfg.class;
380    }
381
382
383
384    /** {@inheritDoc} */
385    public DN dn() {
386      return impl.getDN();
387    }
388
389
390
391    /** {@inheritDoc} */
392    public String toString() {
393      return impl.toString();
394    }
395  }
396}