View Javadoc
1   /*
2    *   Licensed to the Apache Software Foundation (ASF) under one
3    *   or more contributor license agreements.  See the NOTICE file
4    *   distributed with this work for additional information
5    *   regarding copyright ownership.  The ASF licenses this file
6    *   to you under the Apache License, Version 2.0 (the
7    *   "License"); you may not use this file except in compliance
8    *   with the License.  You may obtain a copy of the License at
9    *
10   *     https://www.apache.org/licenses/LICENSE-2.0
11   *
12   *   Unless required by applicable law or agreed to in writing,
13   *   software distributed under the License is distributed on an
14   *   "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15   *   KIND, either express or implied.  See the License for the
16   *   specific language governing permissions and limitations
17   *   under the License.
18   *
19   */
20  
21  package org.apache.directory.ldap.client.template;
22  
23  
24  import org.apache.directory.api.ldap.extras.controls.ppolicy.PasswordPolicyErrorEnum;
25  import org.apache.directory.api.ldap.extras.controls.ppolicy.PasswordPolicyResponse;
26  
27  
28  /**
29   * The default implementation of {@link PasswordWarning}.
30   *
31   * @author <a href="mailto:dev@directory.apache.org">Apache Directory Project</a>
32   */
33  final class PasswordWarningImpl implements PasswordWarning
34  {
35      private static final long serialVersionUID = -8952246313604352357L;
36  
37      private int timeBeforeExpiration = -1;
38      private int graceAuthNsRemaining = -1;
39      private boolean changeAfterReset = false;
40  
41  
42      private PasswordWarningImpl()
43      {
44      }
45  
46  
47      static PasswordWarning newWarning( PasswordPolicyResponse response )
48      {
49          if ( response != null )
50          {
51              PasswordWarningImpl policyWarning = new PasswordWarningImpl();
52              policyWarning.timeBeforeExpiration = response.getTimeBeforeExpiration();
53              policyWarning.graceAuthNsRemaining = response.getGraceAuthNRemaining();
54              policyWarning.changeAfterReset = response.getPasswordPolicyError() == PasswordPolicyErrorEnum.CHANGE_AFTER_RESET;
55  
56              if ( policyWarning.timeBeforeExpiration >= 0 || policyWarning.graceAuthNsRemaining >= 0
57                  || policyWarning.changeAfterReset )
58              {
59                  // it actually is a warning!
60                  return policyWarning;
61              }
62          }
63          return null;
64      }
65  
66  
67      /**
68       * {@inheritDoc}
69       */
70      @Override
71      public int getTimeBeforeExpiration()
72      {
73          return timeBeforeExpiration;
74      }
75  
76  
77      /**
78       * {@inheritDoc}
79       */
80      @Override
81      public int getGraceAuthNsRemaining()
82      {
83          return graceAuthNsRemaining;
84      }
85  
86  
87      /**
88       * {@inheritDoc}
89       */
90      @Override
91      public boolean isChangeAfterReset()
92      {
93          return changeAfterReset;
94      }
95  }