diff --git a/src/ui/avatarbd/AvatarBDFirewall.java b/src/ui/avatarbd/AvatarBDFirewall.java index ca826f52b2208eb80590a75107722a6ea9db1c94..97c65c8f9ddc4b46cbba52162eaa08dc395ea6ff 100755 --- a/src/ui/avatarbd/AvatarBDFirewall.java +++ b/src/ui/avatarbd/AvatarBDFirewall.java @@ -173,28 +173,28 @@ public class AvatarBDFirewall extends TGCScalableWithoutInternalComponent { String tmpName; // DB: commented until JDialogAvatarFirewall is added to repository -// JDialogAvatarFirewall dialog = new JDialogAvatarFirewall(frame, "Setting firewall attributes", this); -// dialog.setSize(600, 600); -// GraphicLib.centerOnParent(dialog); -// dialog.show(); // blocked until dialog has been closed -// -// if (!dialog.isRegularClose()) { -// return false; -// } -// -// if (dialog.getNodeName().length() != 0) { -// tmpName = dialog.getNodeName(); -// tmpName = tmpName.trim(); -// if (!TAttribute.isAValidId(tmpName, false, false)) { -// error = true; -// errors += "Name of the node "; -// } else { -// name = tmpName; -// } -// } -// latency = Integer.valueOf(dialog.getLatency()); + JDialogAvatarFirewall dialog = new JDialogAvatarFirewall(frame, "Setting firewall attributes", this); + dialog.setSize(600, 600); + GraphicLib.centerOnParent(dialog); + dialog.show(); // blocked until dialog has been closed + + if (!dialog.isRegularClose()) { + return false; + } + + if (dialog.getNodeName().length() != 0) { + tmpName = dialog.getNodeName(); + tmpName = tmpName.trim(); + if (!TAttribute.isAValidId(tmpName, false, false)) { + error = true; + errors += "Name of the node "; + } else { + name = tmpName; + } + } + latency = Integer.valueOf(dialog.getLatency()); -// rules = dialog.getRules(); + rules = dialog.getRules(); if (error) { JOptionPane.showMessageDialog(frame, diff --git a/src/ui/window/JDialogAvatarFirewall.java b/src/ui/window/JDialogAvatarFirewall.java new file mode 100644 index 0000000000000000000000000000000000000000..ac455514fedcd5c708e279236d8dfdeb84925dd8 --- /dev/null +++ b/src/ui/window/JDialogAvatarFirewall.java @@ -0,0 +1,275 @@ +/**Copyright or (C) or Copr. GET / ENST, Telecom-Paris, Ludovic Apvrille + * + * ludovic.apvrille AT enst.fr + * + * This software is a computer program whose purpose is to allow the + * edition of TURTLE analysis, design and deployment diagrams, to + * allow the generation of RT-LOTOS or Java code from this diagram, + * and at last to allow the analysis of formal validation traces + * obtained from external tools, e.g. RTL from LAAS-CNRS and CADP + * from INRIA Rhone-Alpes. + * + * This software is governed by the CeCILL license under French law and + * abiding by the rules of distribution of free software. You can use, + * modify and/ or redistribute the software under the terms of the CeCILL + * license as circulated by CEA, CNRS and INRIA at the following URL + * "http://www.cecill.info". + * + * As a counterpart to the access to the source code and rights to copy, + * modify and redistribute granted by the license, users are provided only + * with a limited warranty and the software's author, the holder of the + * economic rights, and the successive licensors have only limited + * liability. + * + * In this respect, the user's attention is drawn to the risks associated + * with loading, using, modifying and/or developing or reproducing the + * software by the user in light of its specific status of free software, + * that may mean that it is complicated to manipulate, and that also + * therefore means that it is reserved for developers and experienced + * professionals having in-depth computer knowledge. Users are therefore + * encouraged to load and test the software's suitability as regards their + * requirements in conditions enabling the security of their systems and/or + * data to be ensured and, more generally, to use and operate it in the + * same conditions as regards security. + * + * The fact that you are presently reading this means that you have had + * knowledge of the CeCILL license and that you accept its terms. + * + * /** + * Class JDialogFirewallNode + * Dialog for managing attributes of Firewall nodes + * Creation: 17/10/2007 + * @version 1.0 17/10/2007 + * @author Letitia Li + * @see + */ + +package ui.window; + +import java.awt.*; +import java.awt.event.*; +import java.util.*; +import javax.swing.*; +import javax.swing.event.*; +//import javax.swing.event.*; +//import java.util.*; + +import ui.*; + +import ui.avatarbd.*; + + +public class JDialogAvatarFirewall extends javax.swing.JDialog implements ActionListener,ListSelectionListener { + + private boolean regularClose; + + private JPanel panel2; + private Frame frame; + private AvatarBDFirewall node; + + + // Panel1 + protected JTextField nodeName; + private Vector rules= new Vector(); + // Panel2 + protected JTextField latency; + private JList listRules; + private JButton addButton,removeButton; + + // Main Panel + private JButton closeButton; + private JButton cancelButton; + private JComboBox task1; + private JComboBox task2; + /** Creates new form */ + public JDialogAvatarFirewall(Frame _frame, String _title, AvatarBDFirewall _node) { + super(_frame, _title, true); + frame = _frame; + node = _node; + + initComponents(); + myInitComponents(); + pack(); + } + + private void myInitComponents() { + } + + private void initComponents() { + Container c = getContentPane(); + GridBagLayout gridbag0 = new GridBagLayout(); + GridBagLayout gridbag1 = new GridBagLayout(); + GridBagLayout gridbag2 = new GridBagLayout(); + GridBagConstraints c0 = new GridBagConstraints(); + GridBagConstraints c1 = new GridBagConstraints(); + GridBagConstraints c2 = new GridBagConstraints(); + + setFont(new Font("Helvetica", Font.PLAIN, 14)); + c.setLayout(gridbag0); + + setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE); + + + panel2 = new JPanel(); + panel2.setLayout(gridbag2); + panel2.setBorder(new javax.swing.border.TitledBorder("Firewall attributes")); + panel2.setPreferredSize(new Dimension(500, 500)); + + c2.gridwidth = 2; + c2.gridheight = 1; + c2.weighty = 1.0; + c2.weightx = 1.0; + c2.fill = GridBagConstraints.HORIZONTAL; + panel2.add(new JLabel("Firewall name:"), c2); + c2.gridwidth = GridBagConstraints.REMAINDER; //end row + nodeName = new JTextField(node.getNodeName(), 30); + nodeName.setEditable(true); + nodeName.setFont(new Font("times", Font.PLAIN, 12)); + panel2.add(nodeName, c2); + c2.gridwidth=2; + panel2.add(new JLabel("Latency (CC):"), c2); + c2.gridwidth = GridBagConstraints.REMAINDER; //end row + latency = new JTextField(""+node.getLatency(), 15); + panel2.add(latency, c2); + + c2.gridwidth = GridBagConstraints.REMAINDER; + c2.gridheight = 1; + c2.weighty = 1.0; + c2.weightx = 1.0; + c2.fill = GridBagConstraints.HORIZONTAL; + for (String s: node.getRules()){ + rules.add(s); + } + JLabel rulesLabel = new JLabel("Blocking Rules"); + panel2.add(rulesLabel, c2); + + listRules = new JList<String>(rules); + listRules.setSelectionMode(ListSelectionModel.SINGLE_SELECTION); + listRules.addListSelectionListener(this); + JScrollPane scrollPane = new JScrollPane(listRules); + scrollPane.setSize(500, 250); + c2.gridwidth = GridBagConstraints.REMAINDER; //end row + c2.fill = GridBagConstraints.BOTH; + c2.gridheight = 10; + c2.weighty = 10.0; + c2.weightx = 10.0; + panel2.add(scrollPane, c2); + c2.gridheight=1; + c2.gridwidth=1; + c2.weighty = 1.0; + c2.weightx = 1.0; + task1 = new JComboBox(); + for (String task: node.getTDiagramPanel().getMGUI().getAvatarBlocks()){ + task1.addItem(task); + } + task1.addItem("*"); + + task2= new JComboBox(); + for (String task: node.getTDiagramPanel().getMGUI().getAvatarBlocks()){ + task2.addItem(task); + } + task2.addItem("*"); + + panel2.add(task1, c2); + panel2.add(new JLabel("--->"),c2); + c2.gridwidth=GridBagConstraints.REMAINDER; + panel2.add(task2, c2); + + addButton = new JButton("Add Rule"); + addButton.addActionListener(this); + panel2.add(addButton,c2); + removeButton= new JButton("Remove Rule"); + removeButton.addActionListener(this); + panel2.add(removeButton,c2); + // main panel; + c0.gridheight = 10; + c0.weighty = 1.0; + c0.weightx = 1.0; + c0.gridwidth = GridBagConstraints.REMAINDER; //end row + c.add(panel2, c0); + + c0.gridwidth = 1; + c0.gridheight = 1; + c0.fill = GridBagConstraints.HORIZONTAL; + closeButton = new JButton("Save and Close", IconManager.imgic25); + //closeButton.setPreferredSize(new Dimension(600, 50)); + closeButton.addActionListener(this); + c.add(closeButton, c0); + c0.gridwidth = GridBagConstraints.REMAINDER; //end row + cancelButton = new JButton("Cancel", IconManager.imgic27); + cancelButton.addActionListener(this); + c.add(cancelButton, c0); + } + + public void actionPerformed(ActionEvent evt) { + /* if (evt.getSource() == typeBox) { + boolean b = ((Boolean)(initValues.elementAt(typeBox.getSelectedIndex()))).booleanValue(); + initialValue.setEnabled(b); + return; + }*/ + + + String command = evt.getActionCommand(); + + // Compare the action command to the known actions. + if (command.equals("Save and Close")) { + closeDialog(); + } else if (command.equals("Cancel")) { + cancelDialog(); + } else if (evt.getSource() == addButton) { + addRule(); + } else if (evt.getSource() == removeButton) { + removeRule(); + } + } + public void valueChanged(ListSelectionEvent e) { + int i = listRules.getSelectedIndex() ; + if (i == -1) { + removeButton.setEnabled(false); + } else { + removeButton.setEnabled(true); + } + } + + public void removeRule() { + int i = listRules.getSelectedIndex() ; + if (i!= -1) { + rules.removeElementAt(i); + listRules.setListData(rules); + } + } + public void addRule(){ + String s = task1.getSelectedItem().toString(); + s+= "->"; + s+= task2.getSelectedItem().toString(); + rules.add(s); + listRules.setListData(rules); + } + public void closeDialog() { + regularClose = true; + dispose(); + } + + public void cancelDialog() { + dispose(); + } + + public boolean isRegularClose() { + return regularClose; + } + + public String getNodeName() { + return nodeName.getText(); + } + + public String getLatency() { + return latency.getText(); + } + public ArrayList<String> getRules(){ + ArrayList<String> r = new ArrayList<String>(); + for (int i=0; i<rules.size(); i++){ + r.add((String) rules.get(i)); + } + return r; + } +}