69: Create new Accounting Portlet

Task-Url: https://support.d4science.org/issues/69

Updated Filters Management

git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/portlets/admin/accounting-manager@117577 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
Giancarlo Panichi 2015-07-30 16:35:01 +00:00
parent e9e2386440
commit a54249c9c8
13 changed files with 731 additions and 51 deletions

View File

@ -238,7 +238,7 @@ public class AccountingManagerController {
CalendarUtil.addMonthsToDate(d, -1);
SeriesRequest seriesRequest=new SeriesRequest(
new AccountingPeriod(d,new Date(),AccountingPeriodMode.DAILY));
new AccountingPeriod(d,new Date(),AccountingPeriodMode.DAILY), null);
this.accountingType = accountingType;
AccountingStateData accountingStateData = new AccountingStateData(

View File

@ -0,0 +1,457 @@
package org.gcube.portlets.admin.accountingmanager.client.filters;
import java.util.ArrayList;
import java.util.List;
import org.gcube.portlets.admin.accountingmanager.client.event.SessionExpiredEvent;
import org.gcube.portlets.admin.accountingmanager.client.event.StateChangeEvent;
import org.gcube.portlets.admin.accountingmanager.client.properties.AccountingFilterProperties;
import org.gcube.portlets.admin.accountingmanager.client.rpc.AccountingManagerServiceAsync;
import org.gcube.portlets.admin.accountingmanager.client.state.AccountingStateData;
import org.gcube.portlets.admin.accountingmanager.client.type.SessionExpiredType;
import org.gcube.portlets.admin.accountingmanager.client.utils.UtilsGXT3;
import org.gcube.portlets.admin.accountingmanager.shared.data.AccountingFilter;
import org.gcube.portlets.admin.accountingmanager.shared.data.AccountingType;
import org.gcube.portlets.admin.accountingmanager.shared.data.FilterKey;
import org.gcube.portlets.admin.accountingmanager.shared.exception.AccountingManagerSessionExpiredException;
import com.allen_sauer.gwt.log.client.Log;
import com.google.gwt.cell.client.AbstractCell;
import com.google.gwt.core.client.GWT;
import com.google.gwt.editor.client.Editor.Path;
import com.google.gwt.event.shared.EventBus;
import com.google.gwt.safehtml.shared.SafeHtml;
import com.google.gwt.safehtml.shared.SafeHtmlBuilder;
import com.google.gwt.user.client.rpc.AsyncCallback;
import com.sencha.gxt.cell.core.client.ButtonCell.IconAlign;
import com.sencha.gxt.cell.core.client.form.ComboBoxCell.TriggerAction;
import com.sencha.gxt.core.client.Style.SelectionMode;
import com.sencha.gxt.core.client.XTemplates;
import com.sencha.gxt.core.client.util.Margins;
import com.sencha.gxt.data.shared.LabelProvider;
import com.sencha.gxt.data.shared.ListStore;
import com.sencha.gxt.data.shared.ModelKeyProvider;
import com.sencha.gxt.data.shared.PropertyAccess;
import com.sencha.gxt.dnd.core.client.DND.Feedback;
import com.sencha.gxt.dnd.core.client.DndDragStartEvent;
import com.sencha.gxt.dnd.core.client.DndDragStartEvent.DndDragStartHandler;
import com.sencha.gxt.dnd.core.client.GridDragSource;
import com.sencha.gxt.dnd.core.client.GridDropTarget;
import com.sencha.gxt.widget.core.client.button.ButtonBar;
import com.sencha.gxt.widget.core.client.button.TextButton;
import com.sencha.gxt.widget.core.client.container.MarginData;
import com.sencha.gxt.widget.core.client.container.SimpleContainer;
import com.sencha.gxt.widget.core.client.container.VerticalLayoutContainer;
import com.sencha.gxt.widget.core.client.container.VerticalLayoutContainer.VerticalLayoutData;
import com.sencha.gxt.widget.core.client.event.BeforeStartEditEvent;
import com.sencha.gxt.widget.core.client.event.BeforeStartEditEvent.BeforeStartEditHandler;
import com.sencha.gxt.widget.core.client.event.CancelEditEvent;
import com.sencha.gxt.widget.core.client.event.CancelEditEvent.CancelEditHandler;
import com.sencha.gxt.widget.core.client.event.CompleteEditEvent;
import com.sencha.gxt.widget.core.client.event.CompleteEditEvent.CompleteEditHandler;
import com.sencha.gxt.widget.core.client.event.SelectEvent;
import com.sencha.gxt.widget.core.client.event.SelectEvent.SelectHandler;
import com.sencha.gxt.widget.core.client.form.ComboBox;
import com.sencha.gxt.widget.core.client.form.FieldSet;
import com.sencha.gxt.widget.core.client.form.TextField;
import com.sencha.gxt.widget.core.client.form.validator.EmptyValidator;
import com.sencha.gxt.widget.core.client.grid.ColumnConfig;
import com.sencha.gxt.widget.core.client.grid.ColumnModel;
import com.sencha.gxt.widget.core.client.grid.Grid;
import com.sencha.gxt.widget.core.client.grid.Grid.GridCell;
import com.sencha.gxt.widget.core.client.grid.GridSelectionModel;
import com.sencha.gxt.widget.core.client.grid.editing.GridRowEditing;
import com.sencha.gxt.widget.core.client.toolbar.ToolBar;
/**
*
* @author giancarlo email: <a
* href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
*
*/
public class ActiveFiltersPanel extends SimpleContainer {
private EventBus eventBus;
private Grid<AccountingFilter> grid;
private ListStore<AccountingFilter> store;
private boolean addStatus;
private List<FilterKey> filterKeys;
private AccountingStateData accountingStateData;
private ListStore<FilterKey> storeComboFilterKey;
public interface FilterKeyPropertiesCombo extends PropertyAccess<FilterKey> {
@Path("id")
ModelKeyProvider<FilterKey> id();
LabelProvider<FilterKey> key();
}
interface FilterKeyTemplates extends XTemplates {
@XTemplate("<span title=\"{value}\">{value}</span>")
SafeHtml format(String value);
}
public ActiveFiltersPanel(EventBus eventBus) {
super();
Log.debug("ActiveFiltersPanel");
this.eventBus = eventBus;
init();
create();
bindToEvents();
}
private void init() {
}
private void create() {
// Grid
AccountingFilterProperties props = GWT
.create(AccountingFilterProperties.class);
ColumnConfig<AccountingFilter, FilterKey> keyColumn = new ColumnConfig<AccountingFilter, FilterKey>(
props.key(), 130, "Key");
keyColumn.setCell(new AbstractCell<FilterKey>() {
@Override
public void render(Context context, FilterKey value, SafeHtmlBuilder sb) {
FilterKeyTemplates filterKeyTemplates = GWT
.create(FilterKeyTemplates.class);
sb.append(filterKeyTemplates.format(value.getKey()));
}
});
ColumnConfig<AccountingFilter, String> valueColumn = new ColumnConfig<AccountingFilter, String>(
props.value(), 130, "Value");
ArrayList<ColumnConfig<AccountingFilter, ?>> l = new ArrayList<ColumnConfig<AccountingFilter, ?>>();
l.add(keyColumn);
l.add(valueColumn);
ColumnModel<AccountingFilter> columns = new ColumnModel<AccountingFilter>(
l);
store = new ListStore<AccountingFilter>(props.id());
final GridSelectionModel<AccountingFilter> sm = new GridSelectionModel<AccountingFilter>();
sm.setSelectionMode(SelectionMode.SINGLE);
grid = new Grid<AccountingFilter>(store, columns);
grid.setSelectionModel(sm);
grid.getView().setStripeRows(true);
grid.getView().setColumnLines(true);
grid.getView().setAutoFill(true);
grid.setBorders(false);
grid.setColumnReordering(false);
grid.getView().setAutoExpandColumn(valueColumn);
grid.getView().setSortingEnabled(false);
GridDragSource<AccountingFilter> ds = new GridDragSource<AccountingFilter>(
grid);
ds.addDragStartHandler(new DndDragStartHandler() {
@Override
public void onDragStart(DndDragStartEvent event) {
@SuppressWarnings("unchecked")
ArrayList<AccountingFilter> draggingSelection = (ArrayList<AccountingFilter>) event
.getData();
Log.debug("Start Drag: " + draggingSelection);
}
});
GridDropTarget<AccountingFilter> dt = new GridDropTarget<AccountingFilter>(
grid);
dt.setFeedback(Feedback.BOTH);
dt.setAllowSelfAsSource(true);
// EDITING //
FilterKeyPropertiesCombo filterKeyPropertiesCombo = GWT
.create(FilterKeyPropertiesCombo.class);
storeComboFilterKey = new ListStore<FilterKey>(
filterKeyPropertiesCombo.id());
//
ComboBox<FilterKey> comboFilterKey = new ComboBox<FilterKey>(
storeComboFilterKey, filterKeyPropertiesCombo.key());
comboFilterKey.setClearValueOnParseError(false);
comboFilterKey.setTriggerAction(TriggerAction.ALL);
final TextField valueField = new TextField();
valueField.addValidator(new EmptyValidator<String>());
final GridRowEditing<AccountingFilter> editing = new GridRowEditing<AccountingFilter>(
grid);
editing.addEditor(keyColumn, comboFilterKey);
editing.addEditor(valueColumn, valueField);
final TextButton addButton = new TextButton("Add Filter");
// addButton.setIcon(ResourceBundle.INSTANCE.columnAdd24());
addButton.setIconAlign(IconAlign.RIGHT);
addButton.setToolTip("Add Filter");
addButton.addSelectHandler(new SelectHandler() {
@Override
public void onSelect(SelectEvent event) {
List<AccountingFilter> filtersSet=store.getAll();
FilterKey fk=null;
if(filterKeys==null|| filterKeys.size()<0){
} else {
for(FilterKey availableFilterKey:filterKeys){
boolean isSet=false;
for(AccountingFilter filterSet:filtersSet){
if(availableFilterKey.getKey().compareTo(filterSet.getFilterKey().getKey())==0){
isSet=true;
break;
}
}
if(!isSet){
fk=availableFilterKey;
break;
}
}
}
AccountingFilter newAccountingFilter = new AccountingFilter(
fk, "");
editing.cancelEditing();
addStatus = true;
editing.getCancelButton().setVisible(false);
store.add(newAccountingFilter);
int row = store.indexOf(newAccountingFilter);
editing.startEditing(new GridCell(row, 0));
}
});
TextButton deleteBtn = new TextButton("Delete");
deleteBtn.addSelectHandler(new SelectEvent.SelectHandler() {
public void onSelect(SelectEvent event) {
GridCell cell = editing.getActiveCell();
int rowIndex = cell.getRow();
editing.cancelEditing();
store.remove(rowIndex);
store.commitChanges();
editing.getCancelButton().setVisible(true);
addButton.setEnabled(true);
if (addStatus) {
addStatus = false;
}
}
});
ButtonBar buttonBar = editing.getButtonBar();
buttonBar.add(deleteBtn);
editing.addBeforeStartEditHandler(new BeforeStartEditHandler<AccountingFilter>() {
@Override
public void onBeforeStartEdit(
BeforeStartEditEvent<AccountingFilter> event) {
addButton.setEnabled(false);
// setEnableNextButton(false);
}
});
editing.addCancelEditHandler(new CancelEditHandler<AccountingFilter>() {
@Override
public void onCancelEdit(CancelEditEvent<AccountingFilter> event) {
store.rejectChanges();
addButton.setEnabled(true);
// setEnableNextButton(true);
}
});
editing.addCompleteEditHandler(new CompleteEditHandler<AccountingFilter>() {
@Override
public void onCompleteEdit(CompleteEditEvent<AccountingFilter> event) {
try {
String value = valueField.getCurrentValue();
Log.debug("Current Value: " + value);
boolean exist = false;
GridCell cell = event.getEditCell();
int rowIndex = cell.getRow();
AccountingFilter newFilter = store.get(rowIndex);
Log.debug("Store: " + store.getAll().toString());
for (AccountingFilter filter : store.getAll()) {
if (newFilter.getId().compareTo(filter.getId()) != 0) {
exist = true;
break;
}
}
Log.debug("Exist: " + exist);
if (exist) {
Log.debug("AddStatus: " + addStatus);
if (addStatus) {
addStatus = false;
store.remove(rowIndex);
store.commitChanges();
} else {
store.rejectChanges();
}
UtilsGXT3
.alert("Attention",
"This label is already present, please choose another(case insensitive)!");
} else {
store.commitChanges();
}
editing.getCancelButton().setVisible(true);
addButton.setEnabled(true);
// setEnableNextButton(true);
} catch (Throwable e) {
Log.error("Error in RuleOnTableNewDefinitionCard: "
+ e.getLocalizedMessage());
e.printStackTrace();
}
}
});
//
ToolBar toolBar = new ToolBar();
toolBar.add(addButton);
VerticalLayoutContainer vlc = new VerticalLayoutContainer();
vlc.add(toolBar, new VerticalLayoutData(1, -1, new Margins(0)));
vlc.add(grid, new VerticalLayoutData(1, 1, new Margins(0)));
FieldSet fieldSet = new FieldSet();
fieldSet.setHeadingHtml("<b>Active Filters</b>");
fieldSet.setCollapsible(false);
fieldSet.add(vlc);
add(fieldSet, new MarginData(0));
}
// Bind to Events
private void bindToEvents() {
eventBus.addHandler(StateChangeEvent.TYPE,
new StateChangeEvent.StateChangeEventHandler() {
@Override
public void onStateChange(StateChangeEvent event) {
Log.debug("Catch Event State Change");
doStateChangeCommand(event);
}
});
}
private void doStateChangeCommand(StateChangeEvent event) {
if (event.getStateChangeType() == null) {
return;
}
switch (event.getStateChangeType()) {
case Restore:
onRestoreStateChange(event);
break;
case Update:
break;
default:
break;
}
}
private void onRestoreStateChange(StateChangeEvent event) {
if (event.getAccountingStateData() != null) {
accountingStateData=event.getAccountingStateData();
retrieveFilterKey(event.getAccountingStateData().getAccountingType());
} else {
accountingStateData=null;
}
forceLayout();
}
private void changeActiveFilters() {
storeComboFilterKey.clear();
storeComboFilterKey.addAll(filterKeys);
storeComboFilterKey.commitChanges();
if (accountingStateData.getSeriesRequest() != null) {
List<AccountingFilter> filters = accountingStateData.getSeriesRequest().getFilters();
store.clear();
store.addAll(filters);
store.commitChanges();
} else {
store.clear();
store.commitChanges();
}
forceLayout();
}
public List<AccountingFilter> getActiveFilters() {
try {
if (store == null || store.size() <= 0) {
return null;
} else {
return store.getAll();
}
} catch (Throwable e) {
Log.error(e.getLocalizedMessage());
e.printStackTrace();
UtilsGXT3.alert("Attention", e.getLocalizedMessage());
return null;
}
}
private void retrieveFilterKey(AccountingType accountingType) {
AccountingManagerServiceAsync.INSTANCE.getFilterKeys(accountingType,
new AsyncCallback<ArrayList<FilterKey>>() {
@Override
public void onFailure(Throwable caught) {
if (caught instanceof AccountingManagerSessionExpiredException) {
eventBus.fireEvent(new SessionExpiredEvent(
SessionExpiredType.EXPIREDONSERVER));
} else {
Log.error("Error retrieving filter keys:"
+ caught.getLocalizedMessage());
UtilsGXT3.alert("Error retrieving filter keys",
caught.getLocalizedMessage());
}
}
@Override
public void onSuccess(ArrayList<FilterKey> result) {
Log.debug("FilterKeys: " + result);
filterKeys = result;
changeActiveFilters();
}
});
}
}

View File

@ -1,8 +1,11 @@
package org.gcube.portlets.admin.accountingmanager.client.filters;
import java.util.List;
import org.gcube.portlets.admin.accountingmanager.client.event.FiltersChangeEvent;
import org.gcube.portlets.admin.accountingmanager.client.resource.AccountingManagerResources;
import org.gcube.portlets.admin.accountingmanager.client.type.FiltersChangeType;
import org.gcube.portlets.admin.accountingmanager.shared.data.AccountingFilter;
import org.gcube.portlets.admin.accountingmanager.shared.data.AccountingPeriod;
import org.gcube.portlets.admin.accountingmanager.shared.data.query.SeriesRequest;
@ -31,6 +34,7 @@ public class FiltersPanel extends FramedPanel {
private EventBus eventBus;
private AccountingPeriodPanel accountPeriodPanel;
private TextButton updateCharts;
private ActiveFiltersPanel activeFiltersPanel;
public FiltersPanel(EventBus eventBus) {
super();
@ -52,7 +56,8 @@ public class FiltersPanel extends FramedPanel {
protected void create() {
accountPeriodPanel = new AccountingPeriodPanel(eventBus);
activeFiltersPanel = new ActiveFiltersPanel(eventBus);
updateCharts = new TextButton("Update Chart");
updateCharts.setIcon(AccountingManagerResources.INSTANCE
.accountingReload24());
@ -75,6 +80,9 @@ public class FiltersPanel extends FramedPanel {
vlc.setScrollMode(ScrollMode.AUTO);
vlc.add(accountPeriodPanel, new VerticalLayoutData(1, -1, new Margins(
4, 0, 2, 4)));
vlc.add(activeFiltersPanel, new VerticalLayoutData(1, 1, new Margins(
4, 0, 2, 4)));
vlc.add(hBox, new VerticalLayoutData(1, -1, new Margins(0)));
add(vlc);
@ -83,8 +91,10 @@ public class FiltersPanel extends FramedPanel {
protected void updateChart() {
AccountingPeriod accountingPeriod = accountPeriodPanel
.getAccountingPeriod();
List<AccountingFilter> activeFilters=activeFiltersPanel.getActiveFilters();
if (accountingPeriod != null) {
SeriesRequest seriesRequest = new SeriesRequest(accountingPeriod);
SeriesRequest seriesRequest = new SeriesRequest(accountingPeriod,activeFilters);
FiltersChangeEvent filtersChangeEvent = new FiltersChangeEvent(
FiltersChangeType.Update, seriesRequest);
eventBus.fireEvent(filtersChangeEvent);

View File

@ -0,0 +1,25 @@
package org.gcube.portlets.admin.accountingmanager.client.properties;
import org.gcube.portlets.admin.accountingmanager.shared.data.AccountingFilter;
import org.gcube.portlets.admin.accountingmanager.shared.data.FilterKey;
import com.sencha.gxt.core.client.ValueProvider;
import com.sencha.gxt.data.shared.ModelKeyProvider;
import com.sencha.gxt.data.shared.PropertyAccess;
/**
*
* @author giancarlo
* email: <a href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
*
*/
public interface AccountingFilterProperties extends
PropertyAccess<AccountingFilter> {
ModelKeyProvider<AccountingFilter> id();
ValueProvider<AccountingFilter, FilterKey> key();
ValueProvider<AccountingFilter, String> value();
}

View File

@ -1,7 +1,9 @@
package org.gcube.portlets.admin.accountingmanager.client.rpc;
import java.util.ArrayList;
import org.gcube.portlets.admin.accountingmanager.shared.data.AccountingType;
import org.gcube.portlets.admin.accountingmanager.shared.data.FilterKey;
import org.gcube.portlets.admin.accountingmanager.shared.data.query.SeriesRequest;
import org.gcube.portlets.admin.accountingmanager.shared.data.response.SeriesResponse;
import org.gcube.portlets.admin.accountingmanager.shared.exception.AccountingManagerServiceException;
@ -12,8 +14,8 @@ import com.google.gwt.user.client.rpc.RemoteServiceRelativePath;
/**
*
* @author "Giancarlo Panichi"
* <a href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
* @author "Giancarlo Panichi" <a
* href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
*
*/
@RemoteServiceRelativePath("ams")
@ -25,15 +27,29 @@ public interface AccountingManagerService extends RemoteService {
* @throws AccountingManagerServiceException
*/
public UserInfo hello() throws AccountingManagerServiceException;
/**
* Retrieve Accounting Series
*
* @param accountingType the resource on which to accounting
* @param seriesRequest filters and constraints descriptions
* @param accountingType
* the resource on which to accounting
* @param seriesRequest
* filters and constraints descriptions
* @return
* @throws AccountingManagerServiceException
*/
public SeriesResponse getSeries(AccountingType accountingType, SeriesRequest seriesRequest) throws AccountingManagerServiceException;
public SeriesResponse getSeries(AccountingType accountingType,
SeriesRequest seriesRequest)
throws AccountingManagerServiceException;
/**
*
* @param accountingType
* type of accounting
* @return list of filter keys
* @throws AccountingManagerServiceException
*/
public ArrayList<FilterKey> getFilterKeys(AccountingType accountingType)
throws AccountingManagerServiceException;
}

View File

@ -3,8 +3,10 @@
*/
package org.gcube.portlets.admin.accountingmanager.client.rpc;
import java.util.ArrayList;
import org.gcube.portlets.admin.accountingmanager.shared.data.AccountingType;
import org.gcube.portlets.admin.accountingmanager.shared.data.FilterKey;
import org.gcube.portlets.admin.accountingmanager.shared.data.query.SeriesRequest;
import org.gcube.portlets.admin.accountingmanager.shared.data.response.SeriesResponse;
import org.gcube.portlets.admin.accountingmanager.shared.session.UserInfo;
@ -14,30 +16,40 @@ import com.google.gwt.user.client.rpc.AsyncCallback;
/**
*
* @author "Giancarlo Panichi"
* <a href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
* @author "Giancarlo Panichi" <a
* href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
*
*/
public interface AccountingManagerServiceAsync {
public static AccountingManagerServiceAsync INSTANCE = (AccountingManagerServiceAsync) GWT
.create(AccountingManagerService.class);
/**
*
* @param callback
*/
void hello(AsyncCallback<UserInfo> callback);
/**
* Retrieve Accounting Series
*
* @param accountingType the resource on which to accounting
* @param seriesRequest filters and constraints descriptions
* @param accountingType
* the resource on which to accounting
* @param seriesRequest
* filters and constraints descriptions
* @param callback
*/
void getSeries(AccountingType accountingType, SeriesRequest seriesRequest,AsyncCallback<SeriesResponse> callback);
void getSeries(AccountingType accountingType, SeriesRequest seriesRequest,
AsyncCallback<SeriesResponse> callback);
/**
*
* @param accountingType
* accounting type
* @param callback
*/
void getFilterKeys(AccountingType accountingType,
AsyncCallback<ArrayList<FilterKey>> callback);
}

View File

@ -1,5 +1,8 @@
package org.gcube.portlets.admin.accountingmanager.server;
import java.util.ArrayList;
import java.util.Arrays;
import javax.servlet.ServletException;
import javax.servlet.http.HttpSession;
@ -7,6 +10,7 @@ import org.gcube.application.framework.core.session.ASLSession;
import org.gcube.portlets.admin.accountingmanager.client.rpc.AccountingManagerService;
import org.gcube.portlets.admin.accountingmanager.server.amservice.AccountingCaller;
import org.gcube.portlets.admin.accountingmanager.shared.data.AccountingType;
import org.gcube.portlets.admin.accountingmanager.shared.data.FilterKey;
import org.gcube.portlets.admin.accountingmanager.shared.data.query.SeriesRequest;
import org.gcube.portlets.admin.accountingmanager.shared.data.response.SeriesResponse;
import org.gcube.portlets.admin.accountingmanager.shared.exception.AccountingManagerServiceException;
@ -16,14 +20,16 @@ import org.slf4j.LoggerFactory;
import com.google.gwt.user.server.rpc.RemoteServiceServlet;
/**
* The server side implementation of the RPC service.
*/
@SuppressWarnings("serial")
public class AccountingManagerServiceImpl extends RemoteServiceServlet implements AccountingManagerService {
public class AccountingManagerServiceImpl extends RemoteServiceServlet
implements AccountingManagerService {
private static Logger logger = LoggerFactory
.getLogger(AccountingManagerServiceImpl.class);
private static Logger logger = LoggerFactory.getLogger(AccountingManagerServiceImpl.class);
/**
* {@inheritDoc}
*/
@ -32,19 +38,17 @@ public class AccountingManagerServiceImpl extends RemoteServiceServlet implement
super.init();
System.out.println("Fix JAXP: jdk.xml.entityExpansionLimit=0");
System.setProperty("jdk.xml.entityExpansionLimit", "0");
System.out.println("initializing AccountingManager");
}
/**
*
* {@inheritDoc}
*/
@Override
public UserInfo hello() throws AccountingManagerServiceException {
public UserInfo hello() throws AccountingManagerServiceException {
try {
HttpSession session = this.getThreadLocalRequest().getSession();
ASLSession aslSession = SessionUtil.getAslSession(session);
@ -64,32 +68,73 @@ public class AccountingManagerServiceImpl extends RemoteServiceServlet implement
}
}
/**
*
* {@inheritDoc}
*/
@Override
public SeriesResponse getSeries(AccountingType accountingType, SeriesRequest seriesRequest) throws AccountingManagerServiceException {
public SeriesResponse getSeries(AccountingType accountingType,
SeriesRequest seriesRequest)
throws AccountingManagerServiceException {
try {
HttpSession session = this.getThreadLocalRequest().getSession();
SessionUtil.getAslSession(session);
AccountingCaller accountingCaller=new AccountingCaller();
SeriesResponse seriesResponse=accountingCaller.getSeries(accountingType,seriesRequest);
AccountingCaller accountingCaller = new AccountingCaller();
SeriesResponse seriesResponse = accountingCaller.getSeries(
accountingType, seriesRequest);
return seriesResponse;
} catch (AccountingManagerServiceException e) {
e.printStackTrace();
throw e;
} catch (Throwable e) {
e.printStackTrace();
logger.error("Hello(): " + e.getLocalizedMessage(), e);
logger.error("getSeries(): " + e.getLocalizedMessage(), e);
throw new AccountingManagerServiceException(e.getLocalizedMessage());
}
}
@Override
public ArrayList<FilterKey> getFilterKeys(AccountingType accountingType)
throws AccountingManagerServiceException {
try {
HttpSession session = this.getThreadLocalRequest().getSession();
SessionUtil.getAslSession(session);
if (accountingType == null) {
return new ArrayList<FilterKey>();
}
switch (accountingType) {
case JOB:
return new ArrayList<FilterKey>();
case PORTLET:
return new ArrayList<FilterKey>();
case SERVICE:
return new ArrayList<FilterKey>(Arrays.asList(new FilterKey("consumerId"),
new FilterKey("host"), new FilterKey("scope"), new FilterKey("serviceName")));
case STORAGE:
return new ArrayList<FilterKey>(Arrays.asList(new FilterKey("consumerId"),
new FilterKey("dataType"), new FilterKey("scope"), new FilterKey("providerURI"), new FilterKey("resourceOwner")));
case TASK:
return new ArrayList<FilterKey>();
default:
return new ArrayList<FilterKey>();
}
} catch (AccountingManagerServiceException e) {
e.printStackTrace();
throw e;
} catch (Throwable e) {
e.printStackTrace();
logger.error("getFilterKeys(): " + e.getLocalizedMessage(), e);
throw new AccountingManagerServiceException(e.getLocalizedMessage());
}
}
}

View File

@ -61,6 +61,7 @@ public class AccountingCaller {
"Error in invocation: Operation not supported");
}
List<Info> infos = rrq.getInfo(query.getType(),
query.getTemporalConstraint(), null, true);
if (infos == null) {

View File

@ -4,7 +4,7 @@ import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import org.gcube.accounting.aggregation.ServiceUsageRecord;
import org.gcube.accounting.aggregation.AggregatedServiceUsageRecord;
import org.gcube.accounting.analytics.Info;
import org.gcube.portlets.admin.accountingmanager.shared.data.response.SeriesService;
import org.gcube.portlets.admin.accountingmanager.shared.data.response.SeriesServiceData;
@ -42,14 +42,14 @@ public class SeriesResponse4Service extends SeriesResponseBuilder {
for (Info info : infos) {
Date date = info.getDate();
JSONObject jso = info.getValue();
Long duration = jso.getLong(ServiceUsageRecord.DURATION);
Long duration = jso.getLong(AggregatedServiceUsageRecord.DURATION);
Long operationCount = jso
.getLong(ServiceUsageRecord.OPERATION_COUNT);
Long maxInvocationTime = jso.getLong(ServiceUsageRecord.MAX_INVOCATION_TIME);
Long minInvocationTime = jso.getLong(ServiceUsageRecord.MIN_INVOCATION_TIME);
.getLong(AggregatedServiceUsageRecord.OPERATION_COUNT);
Long maxInvocationTime = jso.getLong(AggregatedServiceUsageRecord.MAX_INVOCATION_TIME);
Long minInvocationTime = jso.getLong(AggregatedServiceUsageRecord.MIN_INVOCATION_TIME);
series.add(new SeriesServiceData(date, operationCount, duration, maxInvocationTime, minInvocationTime));
}
SeriesService seriesService = new SeriesService(series);

View File

@ -4,7 +4,7 @@ import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import org.gcube.accounting.aggregation.StorageUsageRecord;
import org.gcube.accounting.aggregation.AggregatedStorageUsageRecord;
import org.gcube.accounting.analytics.Info;
import org.gcube.portlets.admin.accountingmanager.shared.data.response.SeriesStorage;
import org.gcube.portlets.admin.accountingmanager.shared.data.response.SeriesStorageData;
@ -42,9 +42,9 @@ public class SeriesResponse4Storage extends SeriesResponseBuilder {
for (Info info : infos) {
Date date = info.getDate();
JSONObject jso = info.getValue();
Long dataVolume = jso.getLong(StorageUsageRecord.DATA_VOLUME);
Long dataVolume = jso.getLong(AggregatedStorageUsageRecord.DATA_VOLUME);
Long operationCount = jso
.getLong(StorageUsageRecord.OPERATION_COUNT);
.getLong(AggregatedStorageUsageRecord.OPERATION_COUNT);
series.add(new SeriesStorageData(date, dataVolume, operationCount));
}

View File

@ -0,0 +1,57 @@
package org.gcube.portlets.admin.accountingmanager.shared.data;
import java.io.Serializable;
/**
*
* @author giancarlo email: <a
* href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
*
*/
public class AccountingFilter implements Serializable {
private static final long serialVersionUID = 7200526591393559078L;
private FilterKey filterKey;
private String value;
public AccountingFilter() {
super();
}
public AccountingFilter(FilterKey filterKey, String value) {
super();
this.filterKey = filterKey;
this.value = value;
}
public String getId() {
if (filterKey != null) {
return filterKey.getId();
} else {
return null;
}
}
public FilterKey getFilterKey() {
return filterKey;
}
public void setFilterKey(FilterKey filterKey) {
this.filterKey = filterKey;
}
public String getValue() {
return value;
}
public void setValue(String value) {
this.value = value;
}
@Override
public String toString() {
return "AccountingFilter [filterKey=" + filterKey + ", value=" + value
+ "]";
}
}

View File

@ -0,0 +1,45 @@
package org.gcube.portlets.admin.accountingmanager.shared.data;
import java.io.Serializable;
/**
*
* @author giancarlo
* email: <a href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
*
*/
public class FilterKey implements Serializable {
private static final long serialVersionUID = 7200526591393559078L;
private String key;
public FilterKey(){
super();
}
public FilterKey(String key) {
super();
this.key = key;
}
public String getId(){
return key;
}
public String getKey() {
return key;
}
public void setKey(String key) {
this.key = key;
}
@Override
public String toString() {
return "FilterKey [key=" + key + "]";
}
}

View File

@ -1,7 +1,9 @@
package org.gcube.portlets.admin.accountingmanager.shared.data.query;
import java.io.Serializable;
import java.util.List;
import org.gcube.portlets.admin.accountingmanager.shared.data.AccountingFilter;
import org.gcube.portlets.admin.accountingmanager.shared.data.AccountingPeriod;
/**
@ -14,14 +16,17 @@ public class SeriesRequest implements Serializable {
private static final long serialVersionUID = -109538024097615414L;
private AccountingPeriod accountingPeriod;
private List<AccountingFilter> filters;
public SeriesRequest() {
super();
}
public SeriesRequest(AccountingPeriod accountingPeriod) {
public SeriesRequest(AccountingPeriod accountingPeriod,
List<AccountingFilter> filters) {
super();
this.accountingPeriod = accountingPeriod;
this.filters = filters;
}
public AccountingPeriod getAccountingPeriod() {
@ -32,13 +37,20 @@ public class SeriesRequest implements Serializable {
this.accountingPeriod = accountingPeriod;
}
public List<AccountingFilter> getFilters() {
return filters;
}
public void setFilters(List<AccountingFilter> filters) {
this.filters = filters;
}
@Override
public String toString() {
return "SeriesRequest [accountingPeriod=" + accountingPeriod + "]";
return "SeriesRequest [accountingPeriod=" + accountingPeriod
+ ", filters=" + filters + "]";
}
}