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   *     http://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.codec.controls.manageDsaIT;
21  
22  
23  import org.apache.directory.api.ldap.codec.api.CodecControl;
24  import org.apache.directory.api.ldap.codec.api.ControlFactory;
25  import org.apache.directory.api.ldap.codec.api.LdapApiService;
26  import org.apache.directory.api.ldap.model.message.controls.ManageDsaIT;
27  import org.apache.directory.api.ldap.model.message.controls.ManageDsaITImpl;
28  
29  
30  /**
31   * A codec {@link ControlFactory} implementation for {@link ManageDsaIT} control.
32   *
33   * @author <a href="mailto:dev@directory.apache.org">Apache Directory Project</a>
34   * @version $Rev$, $Date$
35   */
36  public class ManageDsaITFactory implements ControlFactory<ManageDsaIT>
37  {
38      /** The LDAP codec responsible for encoding and decoding Cascade Controls */
39      private LdapApiService codec;
40  
41  
42      /**
43       * Creates a new instance of CascadeFactory.
44       *
45       * @param codec The LDAP codec
46       */
47      public ManageDsaITFactory( LdapApiService codec )
48      {
49          this.codec = codec;
50      }
51  
52  
53      /**
54       * {@inheritDoc}
55       */
56      public String getOid()
57      {
58          return ManageDsaIT.OID;
59      }
60  
61  
62      /**
63       * {@inheritDoc}
64       */
65      public CodecControl<ManageDsaIT> newCodecControl()
66      {
67          return new ManageDsaITDecorator( codec, new ManageDsaITImpl() );
68      }
69  
70  
71      /**
72       * {@inheritDoc}
73       */
74      public CodecControl<ManageDsaIT> newCodecControl( ManageDsaIT control )
75      {
76          return new ManageDsaITDecorator( codec, control );
77      }
78  }