log4j implemented for the producer subsystem
[mir.git] / source / mir / producer / reader / ScriptedProducerNode.java
1 /*
2  * Copyright (C) 2001, 2002  The Mir-coders group
3  *
4  * This file is part of Mir.
5  *
6  * Mir is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * Mir is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with Mir; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19  *
20  * In addition, as a special exception, The Mir-coders gives permission to link
21  * the code of this program with the com.oreilly.servlet library, any library
22  * licensed under the Apache Software License, The Sun (tm) Java Advanced
23  * Imaging library (JAI), The Sun JIMI library (or with modified versions of
24  * the above that use the same license as the above), and distribute linked
25  * combinations including the two.  You must obey the GNU General Public
26  * License in all respects for all of the code used other than the above
27  * mentioned libraries.  If you modify this file, you may extend this exception
28  * to your version of the file, but you are not obligated to do so.  If you do
29  * not wish to do so, delete this exception statement from your version.
30  */
31
32 package mir.producer.reader;
33
34 import java.util.*;
35 import java.io.*;
36
37 import mir.producer.*;
38 import mir.util.*;
39 import mir.log.*;
40
41 public class ScriptedProducerNode implements ProducerNode {
42   private ScriptedProducerNodeDefinition definition;
43   private Map integerParameterValues;
44   private Map stringParameterValues;
45   private Map nodeParameterValues;
46
47   public ScriptedProducerNode(ScriptedProducerNodeDefinition aDefinition, Map aStringParameterValues, Map anIntegerParameterValues, Map aNodeParameterValues) {
48     definition = aDefinition;
49     stringParameterValues = new HashMap();
50     stringParameterValues.putAll(aStringParameterValues);
51     integerParameterValues = new HashMap();
52     integerParameterValues.putAll(anIntegerParameterValues);
53     nodeParameterValues = new HashMap();
54     nodeParameterValues.putAll(aNodeParameterValues);
55   }
56
57   public void produce(Map aValues, String aVerb, LoggerWrapper aLogger) throws ProducerFailure, ProducerExc {
58     try {
59       Map oldValues = new HashMap();
60       ScriptedProducerNodeTool.saveMapValues(oldValues, aValues, definition.getStringParameters().keySet());
61       ScriptedProducerNodeTool.saveMapValues(oldValues, aValues, definition.getIntegerParameters().keySet());
62       try {
63         Iterator i = stringParameterValues.entrySet().iterator();
64
65         while (i.hasNext()) {
66           Map.Entry entry = (Map.Entry) i.next();
67
68           if (entry.getValue() instanceof String) {
69             aValues.put(entry.getKey(), ParameterExpander.expandExpression(aValues, (String) entry.getValue()));
70           }
71         }
72
73         i = integerParameterValues.entrySet().iterator();
74
75         while (i.hasNext()) {
76           Map.Entry entry = (Map.Entry) i.next();
77
78           if (entry.getValue() instanceof String) {
79             aValues.put(entry.getKey(), ParameterExpander.evaluateExpression(aValues, (String) entry.getValue()));
80           }
81         }
82
83         ScriptedProducerNodeTool.pushNodeParameterValues(aValues, definition.getName(), nodeParameterValues);
84         try {
85           definition.getBody().produce(aValues, aVerb, aLogger);
86         }
87         finally {
88           ScriptedProducerNodeTool.popNodeParameterValues(aValues, definition.getName());
89         }
90       }
91       finally {
92         ScriptedProducerNodeTool.restoreMapValues(aValues, definition.getIntegerParameters().keySet(), oldValues);
93         ScriptedProducerNodeTool.restoreMapValues(aValues, definition.getStringParameters().keySet(), oldValues);
94       }
95     }
96     catch (Exception e) {
97       aLogger.error("Scripted producer node " + definition.getName() + " caused an exception: " + e.getMessage());
98     }
99   }
100
101 }