/****************************************************************************** * 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.RfcLdapResult.cs // // Author: // Sunil Kumar (Sunilk@novell.com) // // (C) 2003 Novell, Inc (http://www.novell.com) // using System; using Novell.Directory.Ldap.Asn1; namespace Novell.Directory.Ldap.Rfc2251 { /// Represents an LdapResult. /// ///
	/// LdapResult ::= SEQUENCE {
	/// resultCode      ENUMERATED {
	/// success                      (0),
	/// operationsError              (1),
	/// protocolError                (2),
	/// timeLimitExceeded            (3),
	/// sizeLimitExceeded            (4),
	/// compareFalse                 (5),
	/// compareTrue                  (6),
	/// authMethodNotSupported       (7),
	/// strongAuthRequired           (8),
	/// -- 9 reserved --
	/// referral                     (10),  -- new
	/// adminLimitExceeded           (11),  -- new
	/// unavailableCriticalExtension (12),  -- new
	/// confidentialityRequired      (13),  -- new
	/// saslBindInProgress           (14),  -- new
	/// noSuchAttribute              (16),
	/// undefinedAttributeType       (17),
	/// inappropriateMatching        (18),
	/// constraintViolation          (19),
	/// attributeOrValueExists       (20),
	/// invalidAttributeSyntax       (21),
	/// -- 22-31 unused --
	/// noSuchObject                 (32),
	/// aliasProblem                 (33),
	/// invalidDNSyntax              (34),
	/// -- 35 reserved for undefined isLeaf --
	/// aliasDereferencingProblem    (36),
	/// -- 37-47 unused --
	/// inappropriateAuthentication  (48),
	/// 
	/// invalidCredentials           (49),
	/// insufficientAccessRights     (50),
	/// busy                         (51),
	/// unavailable                  (52),
	/// unwillingToPerform           (53),
	/// loopDetect                   (54),
	/// -- 55-63 unused --
	/// namingViolation              (64),
	/// objectClassViolation         (65),
	/// notAllowedOnNonLeaf          (66),
	/// notAllowedOnRDN              (67),
	/// entryAlreadyExists           (68),
	/// objectClassModsProhibited    (69),
	/// -- 70 reserved for CLdap --
	/// affectsMultipleDSAs          (71), -- new
	/// -- 72-79 unused --
	/// other                        (80) },
	/// -- 81-90 reserved for APIs --
	/// matchedDN       LdapDN,
	/// errorMessage    LdapString,
	/// referral        [3] Referral OPTIONAL }
	/// 
/// ///
public class RfcLdapResult:Asn1Sequence, RfcResponse { /// Context-specific TAG for optional Referral. public const int REFERRAL = 3; //************************************************************************* // Constructors for RfcLdapResult //************************************************************************* /// Constructs an RfcLdapResult from parameters /// /// /// the result code of the operation /// /// /// the matched DN returned from the server /// /// /// the diagnostic message returned from the server /// public RfcLdapResult(Asn1Enumerated resultCode, RfcLdapDN matchedDN, RfcLdapString errorMessage):this(resultCode, matchedDN, errorMessage, null) { return ; } /// Constructs an RfcLdapResult from parameters /// /// /// the result code of the operation /// /// /// the matched DN returned from the server /// /// /// the diagnostic message returned from the server /// /// /// the referral(s) returned by the server /// public RfcLdapResult(Asn1Enumerated resultCode, RfcLdapDN matchedDN, RfcLdapString errorMessage, RfcReferral referral):base(4) { add(resultCode); add(matchedDN); add(errorMessage); if (referral != null) add(referral); return ; } /// Constructs an RfcLdapResult from the inputstream [CLSCompliantAttribute(false)] public RfcLdapResult(Asn1Decoder dec, System.IO.Stream in_Renamed, int len):base(dec, in_Renamed, len) { // Decode optional referral from Asn1OctetString to Referral. if (size() > 3) { Asn1Tagged obj = (Asn1Tagged) get_Renamed(3); Asn1Identifier id = obj.getIdentifier(); if (id.Tag == RfcLdapResult.REFERRAL) { sbyte[] content = ((Asn1OctetString) obj.taggedValue()).byteValue(); System.IO.MemoryStream bais = new System.IO.MemoryStream(SupportClass.ToByteArray(content)); set_Renamed(3, new RfcReferral(dec, bais, content.Length)); } } return ; } //************************************************************************* // Accessors //************************************************************************* /// Returns the result code from the server /// /// /// the result code /// public Asn1Enumerated getResultCode() { return (Asn1Enumerated) get_Renamed(0); } /// Returns the matched DN from the server /// /// /// the matched DN /// public RfcLdapDN getMatchedDN() { return new RfcLdapDN(((Asn1OctetString) get_Renamed(1)).byteValue()); } /// Returns the error message from the server /// /// /// the server error message /// public RfcLdapString getErrorMessage() { return new RfcLdapString(((Asn1OctetString) get_Renamed(2)).byteValue()); } /// Returns the referral(s) from the server /// /// /// the referral(s) /// public RfcReferral getReferral() { return (size() > 3)?(RfcReferral) get_Renamed(3):null; } } }