Return-Path: Delivered-To: apmail-directory-commits-archive@www.apache.org Received: (qmail 97852 invoked from network); 8 Jun 2008 05:28:59 -0000 Received: from hermes.apache.org (HELO mail.apache.org) (140.211.11.2) by minotaur.apache.org with SMTP; 8 Jun 2008 05:28:59 -0000 Received: (qmail 52237 invoked by uid 500); 8 Jun 2008 05:29:02 -0000 Delivered-To: apmail-directory-commits-archive@directory.apache.org Received: (qmail 52202 invoked by uid 500); 8 Jun 2008 05:29:02 -0000 Mailing-List: contact commits-help@directory.apache.org; run by ezmlm Precedence: bulk List-Help: List-Unsubscribe: List-Post: List-Id: Reply-To: dev@directory.apache.org Delivered-To: mailing list commits@directory.apache.org Received: (qmail 52190 invoked by uid 99); 8 Jun 2008 05:29:01 -0000 Received: from athena.apache.org (HELO athena.apache.org) (140.211.11.136) by apache.org (qpsmtpd/0.29) with ESMTP; Sat, 07 Jun 2008 22:29:01 -0700 X-ASF-Spam-Status: No, hits=-2000.0 required=10.0 tests=ALL_TRUSTED X-Spam-Check-By: apache.org Received: from [140.211.11.4] (HELO eris.apache.org) (140.211.11.4) by apache.org (qpsmtpd/0.29) with ESMTP; Sun, 08 Jun 2008 05:28:20 +0000 Received: by eris.apache.org (Postfix, from userid 65534) id 7F5262388A41; Sat, 7 Jun 2008 22:28:38 -0700 (PDT) Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Subject: svn commit: r664447 - /directory/apacheds/branches/bigbang/protocol-newldap/src/main/java/org/apache/directory/server/newldap/handlers/NewDeleteHandler.java Date: Sun, 08 Jun 2008 05:28:38 -0000 To: commits@directory.apache.org From: akarasulu@apache.org X-Mailer: svnmailer-1.0.8 Message-Id: <20080608052838.7F5262388A41@eris.apache.org> X-Virus-Checked: Checked by ClamAV on apache.org Author: akarasulu Date: Sat Jun 7 22:28:38 2008 New Revision: 664447 URL: http://svn.apache.org/viewvc?rev=664447&view=rev Log: added new DeleteRequest handler implementation Added: directory/apacheds/branches/bigbang/protocol-newldap/src/main/java/org/apache/directory/server/newldap/handlers/NewDeleteHandler.java Added: directory/apacheds/branches/bigbang/protocol-newldap/src/main/java/org/apache/directory/server/newldap/handlers/NewDeleteHandler.java URL: http://svn.apache.org/viewvc/directory/apacheds/branches/bigbang/protocol-newldap/src/main/java/org/apache/directory/server/newldap/handlers/NewDeleteHandler.java?rev=664447&view=auto ============================================================================== --- directory/apacheds/branches/bigbang/protocol-newldap/src/main/java/org/apache/directory/server/newldap/handlers/NewDeleteHandler.java (added) +++ directory/apacheds/branches/bigbang/protocol-newldap/src/main/java/org/apache/directory/server/newldap/handlers/NewDeleteHandler.java Sat Jun 7 22:28:38 2008 @@ -0,0 +1,109 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + * + */ +package org.apache.directory.server.newldap.handlers; + + +import javax.naming.NamingException; +import javax.naming.ReferralException; + +import org.apache.directory.server.newldap.LdapSession; +import org.apache.directory.shared.ldap.exception.LdapException; +import org.apache.directory.shared.ldap.message.DeleteRequest; +import org.apache.directory.shared.ldap.message.LdapResult; +import org.apache.directory.shared.ldap.message.ReferralImpl; +import org.apache.directory.shared.ldap.message.ResultCodeEnum; +import org.apache.directory.shared.ldap.name.LdapDN; +import org.apache.directory.shared.ldap.util.ExceptionUtils; + +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + + +/** + * A single reply handler for {@link DeleteRequest}s. + * + * @author Apache Directory Project + * @version $Rev: 664302 $ + */ +public class NewDeleteHandler extends LdapRequestHandler +{ + private static final Logger LOG = LoggerFactory.getLogger( DeleteHandler.class ); + + /** Speedup for logs */ + private static final boolean IS_DEBUG = LOG.isDebugEnabled(); + + + public void handle( LdapSession session, DeleteRequest req ) throws Exception + { + LdapResult result = req.getResultResponse().getLdapResult(); + + try + { + session.getCoreSession().delete( req ); + result.setResultCode( ResultCodeEnum.SUCCESS ); + session.getIoSession().write( req.getResultResponse() ); + } + catch ( ReferralException e ) + { + ReferralImpl refs = new ReferralImpl(); + result.setReferral( refs ); + result.setResultCode( ResultCodeEnum.REFERRAL ); + result.setErrorMessage( "Encountered referral attempting to handle delete request." ); + /* coming up null causing a NPE */ + // result.setMatchedDn( e.getResolvedName().toString() ); + do + { + refs.addLdapUrl( ( String ) e.getReferralInfo() ); + } + while ( e.skipReferral() ); + session.getIoSession().write( req.getResultResponse() ); + } + catch ( NamingException e ) + { + String msg = "failed to delete entry " + req.getName() + ": " + e.getMessage(); + + if ( IS_DEBUG ) + { + msg += ":\n" + ExceptionUtils.getStackTrace( e ); + } + + ResultCodeEnum code; + if ( e instanceof LdapException ) + { + code = ( ( LdapException ) e ).getResultCode(); + } + else + { + code = ResultCodeEnum.getBestEstimate( e, req.getType() ); + } + + result.setResultCode( code ); + result.setErrorMessage( msg ); + if ( ( e.getResolvedName() != null ) + && ( ( code == ResultCodeEnum.NO_SUCH_OBJECT ) || ( code == ResultCodeEnum.ALIAS_PROBLEM ) + || ( code == ResultCodeEnum.INVALID_DN_SYNTAX ) || ( code == ResultCodeEnum.ALIAS_DEREFERENCING_PROBLEM ) ) ) + { + result.setMatchedDn( (LdapDN)e.getResolvedName() ); + } + + session.getIoSession().write( req.getResultResponse() ); + } + } +} \ No newline at end of file