01: /*
02: * <copyright>
03: *
04: * Copyright 1997-2004 BBNT Solutions, LLC
05: * under sponsorship of the Defense Advanced Research Projects
06: * Agency (DARPA).
07: *
08: * You can redistribute this software and/or modify it under the
09: * terms of the Cougaar Open Source License as published on the
10: * Cougaar Open Source Website (www.cougaar.org).
11: *
12: * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
13: * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
14: * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
15: * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
16: * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
17: * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
18: * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
19: * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
20: * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
21: * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
22: * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
23: *
24: * </copyright>
25: */
26:
27: package org.cougaar.mlm.plugin.ldm;
28:
29: import java.util.Calendar;
30: import java.util.Date;
31:
32: import org.cougaar.planning.ldm.PlanningFactory;
33: import org.cougaar.planning.ldm.asset.Asset;
34: import org.cougaar.planning.ldm.plan.NewRoleSchedule;
35: import org.cougaar.planning.ldm.plan.NewSchedule;
36:
37: /** AssetCreator is a subclass of AggregateAssetCreator which creates sql queries
38: * (through its superclass) and processes the query results by creating assets with bumpernumbers.
39: */
40:
41: public class SQLNonNSNAssetCreator extends SQLAssetCreator {
42:
43: public SQLNonNSNAssetCreator() {
44: }
45:
46: public void processRow(Object[] data) {
47: //System.out.println("I see "+data[1]+" of "+data[2]);
48:
49: String nsn = (String) data[0];
50: Number count = (Number) data[1];
51: String nomenclature = (String) data[2];
52:
53: //System.out.println(myMessageAddress.getAddress() + ": " +
54: // "Creating " + count + " instances of NSN/" + nsn + " " + nomenclature);
55:
56: for (int i = 1; i <= count.intValue(); i++) {
57: String bumper = createUniqueID(myMessageAddress
58: .getAddress(), nsn, i);
59: Asset newasset = createAsset(nsn, bumper, nomenclature);
60: setupAvailableSchedule(newasset);
61:
62: publishAdd(newasset);
63: }
64:
65: }
66:
67: private String createUniqueID(String cluster, String nsn, int id) {
68: return cluster + "-" + nsn + "-" + id;
69: }
70:
71: private void setupAvailableSchedule(Asset asset) {
72: PlanningFactory ldmfactory = getLDM().getFactory();
73: Calendar mycalendar = Calendar.getInstance();
74: // set the start date of the available schedule to 01/01/1990
75: mycalendar.set(1990, 0, 1, 0, 0, 0);
76: Date start = mycalendar.getTime();
77: // set the end date of the available schedule to 01/01/2010
78: mycalendar.set(2010, 0, 1, 0, 0, 0);
79: Date end = mycalendar.getTime();
80: NewSchedule availsched = ldmfactory.newSimpleSchedule(start,
81: end);
82: // set the available schedule
83: ((NewRoleSchedule) asset.getRoleSchedule())
84: .setAvailableSchedule(availsched);
85: }
86:
87: }
|