/****************************************************************************** * The MIT License * Copyright (c) 2003 Novell Inc. www.novell.com * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the Software), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED AS IS, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. *******************************************************************************/ // // Novell.Directory.Ldap.Rfc2251.RfcAddRequest.cs // // Author: // Sunil Kumar (Sunilk@novell.com) // // (C) 2003 Novell, Inc (http://www.novell.com) // using System; using Novell.Directory.Ldap.Asn1; using Novell.Directory.Ldap; namespace Novell.Directory.Ldap.Rfc2251 { /// Represents the Ldap Add Request. /// ///
	/// AddRequest ::= [APPLICATION 8] SEQUENCE {
	/// entry           LdapDN,
	/// attributes      AttributeList }
	/// 
///
public class RfcAddRequest:Asn1Sequence, RfcRequest { /// Gets the attributes of the entry virtual public RfcAttributeList Attributes { get { return (RfcAttributeList) get_Renamed(1); } } //************************************************************************* // Constructors for AddRequest //************************************************************************* /// Constructs an RFCAddRequest /// /// /// the entry /// /// /// the Attributes making up the Entry /// public RfcAddRequest(RfcLdapDN entry, RfcAttributeList attributes):base(2) { add(entry); add(attributes); return ; } /// Constructs a new Add Request using data from an existing request. /// /// /// the original request data /// /// /// if not null, replaces the dn of the original request /// /* package */ internal RfcAddRequest(Asn1Object[] origRequest, System.String base_Renamed):base(origRequest, origRequest.Length) { // Replace the base if specified, otherwise keep original base if ((System.Object) base_Renamed != null) { set_Renamed(0, new RfcLdapDN(base_Renamed)); } return ; } //************************************************************************* // Accessors //************************************************************************* /// Override getIdentifier to return an application-wide id. ///
		/// ID = CLASS: APPLICATION, FORM: CONSTRUCTED, TAG: 8. (0x68)
		/// 
///
public override Asn1Identifier getIdentifier() { return new Asn1Identifier(Asn1Identifier.APPLICATION, true, LdapMessage.ADD_REQUEST); } public RfcRequest dupRequest(System.String base_Renamed, System.String filter, bool request) { return new RfcAddRequest(toArray(), base_Renamed); } public System.String getRequestDN() { return ((RfcLdapDN) get_Renamed(0)).stringValue(); } } }