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  package org.apache.directory.api.ldap.extras.controls.syncrepl_impl;
21  
22  
23  import org.apache.directory.api.asn1.ber.AbstractContainer;
24  import org.apache.directory.api.ldap.codec.api.ControlContainer;
25  import org.apache.directory.api.ldap.extras.controls.syncrepl.syncRequest.SyncRequestValue;
26  import org.apache.directory.api.ldap.model.message.Control;
27  
28  
29  /**
30   * A container for the SyncRequestValue control
31   *  
32   * @author <a href="mailto:dev@directory.apache.org">Apache Directory Project</a>
33   */
34  public class SyncRequestValueContainer extends AbstractContainer implements ControlContainer
35  {
36      /** SyncRequestValueControl */
37      private Control control;
38  
39      /**
40       * Creates a new SyncRequestValueControlContainer object. 
41       * 
42       * @param control The control to store
43       */
44      public SyncRequestValueContainer( Control control )
45      {
46          super();
47          this.control = control;
48          setGrammar( SyncRequestValueGrammar.getInstance() );
49          setTransition( SyncRequestValueStatesEnum.START_STATE );
50      }
51  
52  
53      /**
54       * @return Returns the syncRequestValue control.
55       */
56      public SyncRequestValue getSyncRequestValue()
57      {
58          return ( SyncRequestValue ) control;
59      }
60  
61  
62      /**
63       * Set a SyncRequestValueControl Object into the container. It will be completed by
64       * the ldapDecoder.
65       * 
66       * @param control the SyncRequestValueControl to set.
67       */
68      public void setControl( Control control )
69      {
70          this.control = control;
71      }
72  
73  
74      /**
75       * Clean the container
76       */
77      @Override
78      public void clean()
79      {
80          super.clean();
81          control = null;
82      }
83  }