You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
204 lines
4.9 KiB
Java
204 lines
4.9 KiB
Java
/*
|
|
* Copyright (C) 2009-2017 Alistair Neil <info@dazzleships.net>
|
|
*
|
|
* 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; either version 2
|
|
* of the License, or (at your option) any later version.
|
|
*
|
|
* 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
*/
|
|
package client;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.Collections;
|
|
import java.util.List;
|
|
import javax.swing.table.DefaultTableModel;
|
|
|
|
/**
|
|
*
|
|
* @author Alistair Neil <info@dazzleships.net>
|
|
*/
|
|
public class GuardNodeTableModel extends DefaultTableModel {
|
|
|
|
private final List<String> salFinger = Collections.synchronizedList(new ArrayList<String>());
|
|
private final String[] columnNames = {"GuardNode", "Country", "BW (MB\\s)", "Trusted"};
|
|
private NodeItem ni;
|
|
private int enabledcount;
|
|
|
|
public GuardNodeTableModel() {
|
|
}
|
|
|
|
public int getEnabledCount() {
|
|
return enabledcount;
|
|
}
|
|
|
|
/**
|
|
* Clear the table model of all data
|
|
*/
|
|
public void clear() {
|
|
getDataVector().clear();
|
|
salFinger.clear();
|
|
enabledcount = 0;
|
|
}
|
|
|
|
/**
|
|
* Get the number of columns
|
|
*
|
|
* @return columns as integer
|
|
*/
|
|
@Override
|
|
public int getColumnCount() {
|
|
return columnNames.length;
|
|
}
|
|
|
|
/**
|
|
* Test if the cell is editable
|
|
*
|
|
* @param row Cell row
|
|
* @param col Cell column
|
|
* @return True if editable
|
|
*/
|
|
@Override
|
|
public boolean isCellEditable(int row, int col) {
|
|
return col == 3;
|
|
}
|
|
|
|
/**
|
|
* Set value with given fingerprint at given column
|
|
*
|
|
* @param value Value
|
|
* @param finger Fingerprint
|
|
* @param col Column
|
|
*/
|
|
public void setValueAt(Object value, String finger, int col) {
|
|
setValueAt(value, salFinger.indexOf(finger), col);
|
|
}
|
|
|
|
/**
|
|
* Set cell value at row,col
|
|
*
|
|
* @param value
|
|
* @param row
|
|
* @param col
|
|
*/
|
|
@Override
|
|
public void setValueAt(Object value, int row, int col) {
|
|
try {
|
|
ni = (NodeItem) super.getValueAt(row, 0);
|
|
if (col == 3) {
|
|
ni.setGuardEnabled((Boolean) value);
|
|
if (ni.isGuardEnabled()) {
|
|
enabledcount++;
|
|
} else {
|
|
if (enabledcount > 0) {
|
|
enabledcount--;
|
|
}
|
|
}
|
|
fireTableCellUpdated(row, col);
|
|
}
|
|
} catch (Exception ex) {
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get cell value as object at row,col
|
|
*
|
|
* @param row
|
|
* @param col
|
|
* @return value as object
|
|
*/
|
|
@Override
|
|
public Object getValueAt(int row, int col) {
|
|
ni = (NodeItem) super.getValueAt(row, 0);
|
|
Object obj = null;
|
|
switch (col) {
|
|
case 0:
|
|
obj = ni.getNickName();
|
|
break;
|
|
case 1:
|
|
obj = ni.getCountryName();
|
|
break;
|
|
case 2:
|
|
obj = ni.getBandwidth();
|
|
break;
|
|
case 3:
|
|
obj = ni.isGuardEnabled();
|
|
break;
|
|
case 4:
|
|
obj = ni.getFingerprint();
|
|
break;
|
|
}
|
|
return obj;
|
|
}
|
|
|
|
/**
|
|
* Add rowdata with given data object array
|
|
*
|
|
* @param rowData
|
|
*/
|
|
@Override
|
|
public void addRow(Object[] rowData) {
|
|
super.addRow(rowData);
|
|
ni = (NodeItem) rowData[0];
|
|
if (ni.isGuardEnabled()) {
|
|
enabledcount++;
|
|
}
|
|
salFinger.add(ni.getFingerprint());
|
|
}
|
|
|
|
/**
|
|
* Get column name at given index
|
|
*
|
|
* @param index
|
|
* @return name as string
|
|
*/
|
|
@Override
|
|
public String getColumnName(int index) {
|
|
return columnNames[index];
|
|
}
|
|
|
|
/**
|
|
* Set the column name at the specified index
|
|
*
|
|
* @param name
|
|
* @param index
|
|
*/
|
|
public void setColumnName(String name, int index) {
|
|
if (index < columnNames.length) {
|
|
columnNames[index] = name;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get column class at given index
|
|
*
|
|
* @param index
|
|
* @return Class
|
|
*/
|
|
@Override
|
|
public Class getColumnClass(int index) {
|
|
Class cl;
|
|
switch (index) {
|
|
case 2:
|
|
cl = Float.class;
|
|
break;
|
|
case 3:
|
|
cl = Boolean.class;
|
|
break;
|
|
default:
|
|
cl = String.class;
|
|
break;
|
|
}
|
|
return cl;
|
|
}
|
|
|
|
}
|