001 /*
002 * Licensed to the Apache Software Foundation (ASF) under one
003 * or more contributor license agreements. See the NOTICE file
004 * distributed with this work for additional information
005 * regarding copyright ownership. The ASF licenses this file
006 * to you under the Apache License, Version 2.0 (the
007 * "License"); you may not use this file except in compliance
008 * with the License. You may obtain a copy of the License at
009 *
010 * http://www.apache.org/licenses/LICENSE-2.0
011 *
012 * Unless required by applicable law or agreed to in writing,
013 * software distributed under the License is distributed on an
014 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
015 * KIND, either express or implied. See the License for the
016 * specific language governing permissions and limitations
017 * under the License.
018 *
019 */
020 package org.apache.directory.shared.ldap.codec.controls.replication.syncStateValue;
021
022
023 import java.nio.ByteBuffer;
024
025 import org.apache.directory.shared.asn1.Asn1Object;
026 import org.apache.directory.shared.asn1.ber.Asn1Decoder;
027 import org.apache.directory.shared.asn1.codec.DecoderException;
028 import org.apache.directory.shared.ldap.codec.ControlDecoder;
029 import org.apache.directory.shared.ldap.message.control.replication.SyncStateValueControl;
030
031
032 /**
033 * A decoder for SyncStateValueControl.
034 *
035 * @author <a href="mailto:dev@directory.apache.org">Apache Directory Project</a>
036 * @version $Rev: 741888 $, $Date: 2009-02-07 13:57:03 +0100 (Sat, 07 Feb 2009) $,
037 */
038 public class SyncStateValueControlDecoder extends Asn1Decoder implements ControlDecoder
039 {
040 /** An instance of this decoder */
041 private static final Asn1Decoder decoder = new Asn1Decoder();
042
043 /**
044 * Return the syncStateValue OID
045 *
046 * @see org.apache.directory.shared.ldap.codec.ControlDecoder#getControlType()
047 */
048 public String getControlType()
049 {
050 return SyncStateValueControl.CONTROL_OID;
051 }
052
053 /**
054 * Decode the syncStateValue control
055 *
056 * @param controlBytes The bytes array which contains the encoded syncStateValue
057 *
058 * @return A valid SyncStateValueControl object
059 *
060 * @throws DecoderException If the decoding found an error
061 * @throws NamingException It will never be throw by this method
062 */
063 public Asn1Object decode( byte[] controlBytes ) throws DecoderException
064 {
065 ByteBuffer bb = ByteBuffer.wrap( controlBytes );
066 SyncStateValueControlContainer container = new SyncStateValueControlContainer();
067 decoder.decode( bb, container );
068 return container.getSyncStateValueControl();
069 }
070 }