summaryrefslogtreecommitdiffstats
path: root/base/common/src/com/netscape/certsrv/ldap/LDAPExceptionConverter.java
blob: dd68795d1dcdb28e1f5b9a8e0006fc57edbdc656 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
// --- BEGIN COPYRIGHT BLOCK ---
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; version 2 of the License.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License along
// with this program; if not, write to the Free Software Foundation, Inc.,
// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
//
// (C) 2007 Red Hat, Inc.
// All rights reserved.
// --- END COPYRIGHT BLOCK ---
package com.netscape.certsrv.ldap;

import com.netscape.certsrv.base.BadRequestException;
import com.netscape.certsrv.base.ConflictingOperationException;
import com.netscape.certsrv.base.PKIException;
import com.netscape.certsrv.base.ResourceNotFoundException;

import netscape.ldap.LDAPException;

/**
 * @author Endi S. Dewata
 */
public class LDAPExceptionConverter {

    public static PKIException toPKIException(LDAPException e) {
        switch (e.getLDAPResultCode()) {
        case LDAPException.ATTRIBUTE_OR_VALUE_EXISTS:
            return new ConflictingOperationException("Attribute or value exists.", e);
        case LDAPException.NO_SUCH_OBJECT:
            return new ResourceNotFoundException("No such object.", e);
        case LDAPException.INVALID_DN_SYNTAX:
            return new BadRequestException("Invalid DN syntax.", e);
        case LDAPException.ENTRY_ALREADY_EXISTS:
            return new ConflictingOperationException("Entry already exists.", e);
        default:
            return new PKIException("LDAP error ("+e.getLDAPResultCode()+"): "+e.getMessage(), e);
        }
    }
}