~mortenoh/+junk/dhis2-detailed-import-export

« back to all changes in this revision

Viewing changes to dhis-2/dhis-support/dhis-support-system/src/main/java/org/hisp/dhis/system/deletion/DefaultDeletionManager.java

  • Committer: larshelge at gmail
  • Date: 2009-03-03 16:46:36 UTC
  • Revision ID: larshelge@gmail.com-20090303164636-2sjlrquo7ib1gf7r
Initial check-in

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
package org.hisp.dhis.system.deletion;
 
2
 
 
3
/*
 
4
 * Copyright (c) 2004-2007, University of Oslo
 
5
 * All rights reserved.
 
6
 *
 
7
 * Redistribution and use in source and binary forms, with or without
 
8
 * modification, are permitted provided that the following conditions are met:
 
9
 * * Redistributions of source code must retain the above copyright notice, this
 
10
 *   list of conditions and the following disclaimer.
 
11
 * * Redistributions in binary form must reproduce the above copyright notice,
 
12
 *   this list of conditions and the following disclaimer in the documentation
 
13
 *   and/or other materials provided with the distribution.
 
14
 * * Neither the name of the HISP project nor the names of its contributors may
 
15
 *   be used to endorse or promote products derived from this software without
 
16
 *   specific prior written permission.
 
17
 *
 
18
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
 
19
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 
20
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 
21
 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
 
22
 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 
23
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 
24
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
 
25
 * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 
26
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 
27
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 
28
 */
 
29
 
 
30
import java.lang.reflect.InvocationTargetException;
 
31
import java.lang.reflect.Method;
 
32
import java.util.ArrayList;
 
33
import java.util.Collection;
 
34
import java.util.List;
 
35
 
 
36
import org.apache.commons.logging.Log;
 
37
import org.apache.commons.logging.LogFactory;
 
38
import org.hisp.dhis.common.DeleteNotAllowedException;
 
39
 
 
40
/**
 
41
 * @author Lars Helge Overland
 
42
 * @version $Id$
 
43
 */
 
44
public class DefaultDeletionManager
 
45
    implements DeletionManager
 
46
{
 
47
    private static final Log log = LogFactory.getLog( DefaultDeletionManager.class );
 
48
    
 
49
    private static final String DELETE_METHOD_PREFIX = "delete";
 
50
    private static final String ALLOW_METHOD_PREFIX = "allowDelete";
 
51
    
 
52
    private List<DeletionHandler> handlers = new ArrayList<DeletionHandler>();
 
53
 
 
54
    // -------------------------------------------------------------------------
 
55
    // DeletionManager implementation
 
56
    // -------------------------------------------------------------------------
 
57
 
 
58
    public void addDeletionHandler( DeletionHandler handler )
 
59
    {
 
60
        this.handlers.add( handler );
 
61
    }
 
62
    
 
63
    public void addDeletionHandlers( Collection<DeletionHandler> deletionHandlers )
 
64
    {
 
65
        this.handlers.addAll( deletionHandlers );
 
66
    }
 
67
    
 
68
    @SuppressWarnings( "unchecked" )
 
69
    public void execute( Object object )
 
70
    {
 
71
        Class clazz = object.getClass();
 
72
        
 
73
        if ( !clazz.getSuperclass().equals( Object.class ) )
 
74
        {
 
75
            clazz = clazz.getSuperclass();
 
76
        }
 
77
        
 
78
        String className = clazz.getSimpleName();
 
79
 
 
80
        // ---------------------------------------------------------------------
 
81
        // Verify that object is allowed to be deleted
 
82
        // ---------------------------------------------------------------------
 
83
        
 
84
        String allowMethodName = ALLOW_METHOD_PREFIX + className;
 
85
 
 
86
        String currentHandler = null;
 
87
        
 
88
        try
 
89
        {
 
90
            Method allowMethod = DeletionHandler.class.getMethod( allowMethodName, new Class[] { clazz }  );
 
91
            
 
92
            for ( DeletionHandler handler : handlers )
 
93
            {   
 
94
                currentHandler = handler.getClass().getSimpleName();
 
95
                
 
96
                boolean allow = (Boolean) allowMethod.invoke( handler, object );
 
97
                
 
98
                if ( !allow )
 
99
                {
 
100
                    throw new DeleteNotAllowedException( DeleteNotAllowedException.ERROR_ASSOCIATED_BY_OTHER_OBJECTS, handler.getClassName() );
 
101
                }
 
102
            }
 
103
        }
 
104
        catch ( NoSuchMethodException ex )
 
105
        {
 
106
            log.error( "Method '" + allowMethodName + "' does not exist on class '" + clazz + "'", ex );
 
107
        }
 
108
        catch ( IllegalAccessException ex )
 
109
        {
 
110
            log.error( "Method '" + allowMethodName + "' could not be invoked on DeletionHandler '" + currentHandler + "'", ex );
 
111
        }
 
112
        catch ( InvocationTargetException ex )
 
113
        {
 
114
            log.error( "Method '" + allowMethodName + "' threw exception on DeletionHandler '" + currentHandler + "'", ex );
 
115
        }
 
116
 
 
117
        // ---------------------------------------------------------------------
 
118
        // Delete associated objects
 
119
        // ---------------------------------------------------------------------
 
120
        
 
121
        String deleteMethodName = DELETE_METHOD_PREFIX + className;
 
122
 
 
123
        try
 
124
        {
 
125
            Method deleteMethod = DeletionHandler.class.getMethod( deleteMethodName, new Class[] { clazz } );
 
126
        
 
127
            for ( DeletionHandler handler : handlers )
 
128
            {
 
129
                currentHandler = handler.getClass().getSimpleName();
 
130
                
 
131
                deleteMethod.invoke( handler, object );
 
132
            }
 
133
        }
 
134
        catch ( Exception ex )
 
135
        {
 
136
            log.error( "Failed to invoke method " + deleteMethodName + " on DeletionHandler '" + currentHandler + "'", ex );
 
137
        }
 
138
        
 
139
        log.info( "Deleted objects associatied with object of type " + className );
 
140
    }
 
141
}