/** * Update request mode means that the user requests the application to update existing information * with supplied information. In update request mode, data is stored in persistent storage. The * request should provide data for all properties of the {@link PersistentBean}. If the update * operation succeeds, the data is imply displayed in a non-editable way. If the update operation * fails, the data is displayed in an HTML form, so that it can be corrected. This method first * sets the id of the persistent bean from the request. Next, the persistent bean is retrieved * from the database. Only after that, the information from the request is filled out into the * bean. This is done to have an early warning of errors in the key, or access violations, but * mainly to make it possible to operate easily with a request that contains only partial * information, i.e., a request that only carries values for a subset of the properties of the * persistent bean. With this protocol, the given information will overwrite information that is * currently in persistent storage, but if there is no data in the request for a given property, * it's old value is retained. Once the data that is offered in the request is copied successfully * in the persistent bean, it is stored. * * @pre form != null; * @pre form.getPersistentBean() != null; * @pre request != null; */ private void templateUpdate(final CrudDynaActionForm form, final HttpServletRequest request) throws IdException, CompoundPropertyException, TechnicalException { assert form != null; assert request != null; if (LOG.isDebugEnabled()) { LOG.debug("update action ..."); // $NON-NLS-1$ } AsynchronousCRUD asyncCRUD = createAsynchronousCRUD(request); try { asyncCRUD.startTransaction(); retrieveWithId(form, asyncCRUD); // IdException, TechnicalException assert form.getPersistentBean() != null; // @mudo (dvankeer): toString() needs to be replaced by something more // usefull. String oldBeanString = form.getPersistentBean().toString(); form.formToBean(asyncCRUD); // PropertyException, inside transaction asyncCRUD.updatePersistentBean(form.getPersistentBean()); // PropertyException form.beanToForm(asyncCRUD); // inside transaction asyncCRUD.commitTransaction(form.getPersistentBean()); releaseAsynchronousCRUD(asyncCRUD); // do not do this in a finally block; this can throw exceptions too form.setViewModeEdit(false); // @todo (jand): try to move this delta stuff to AsynchronousCRUD instead // of here fireCommittedEvent(new UpdatedEvent(form.getPersistentBean(), oldBeanString)); } catch (CompoundPropertyException cpExc) { form.beanToForm(asyncCRUD); if (LOG.isDebugEnabled()) { LOG.debug("update action failed; cancelling ...", cpExc); // $NON-NLS-1$ } asyncCRUD.cancelTransaction(); releaseAsynchronousCRUD(asyncCRUD); // do not do this in a finally block; this can throw exceptions too form.setViewModeEdit(true); LOG.debug("update action cancelled; rethrowing exeption"); // $NON-NLS-1$ throw cpExc; } /* * on IdException, we go to a different page that shows a not found message. * For this page we do not need to set any information */ form.setViewModeDeleted(false); form.setViewModeNew(false); }
/** * Create request mode means that the user requests the application to create a new persistent * bean with supplied information.. In create request mode, new data is stored in persistent * storage. The request should provide data for all properties of the {@link PersistentBean}, * except the {@link PersistentBean#getId()}. If the create operation succeeds, the data is simply * displayed in a non-editable way. If the create operation fails, the data is displayed in an * HTML form, so that it can be corrected. * * @pre form != null; * @pre form.getPersistentBean() != null; * @pre request != null; */ private void templateCreate(final CrudDynaActionForm form, final HttpServletRequest request) throws CompoundPropertyException, TechnicalException { assert form != null; assert request != null; if (LOG.isDebugEnabled()) { LOG.debug("create action ..."); // $NON-NLS-1$ } form.initBean(); /* * BeanInstantiationException; this means that the app is wrongly * configured; this will generate a general error page. */ assert form.getPersistentBean() != null; assert form.getPersistentBean().getId() == null; form.setViewModeDeleted(false); AsynchronousCRUD asyncCRUD = createAsynchronousCRUD(request); try { asyncCRUD.startTransaction(); form.formToBean(asyncCRUD); // PropertyException, inside transaction form.getPersistentBean().setId(null); asyncCRUD.createPersistentBean(form.getPersistentBean()); // PropertyException form.beanToId(); form.beanToForm(asyncCRUD); // inside transaction asyncCRUD.commitTransaction(form.getPersistentBean()); form.setViewModeEdit(false); CreatedEvent pbnEvent = new CreatedEvent(form.getPersistentBean()); fireCommittedEvent(pbnEvent); assert !form.isViewModeNew(); assert !form.isViewModeDeleted(); if (LOG.isDebugEnabled()) { LOG.debug("create action succeeded"); // $NON-NLS-1$ } } catch (CompoundPropertyException cpExc) { form.beanToForm(asyncCRUD); asyncCRUD.cancelTransaction(); form.setViewModeNew(true); assert form.isViewModeEdit(); assert !form.isViewModeDeleted(); throw cpExc; } finally { releaseAsynchronousCRUD(asyncCRUD); } }
/** * Delete request mode means that the user requests the application to delete an existing bean. In * delete request mode, existing data is deleted from persistent storage. The request should * provide data for the {@link PersistentBean#getId()}. If the delete operation succeeds, the data * is displayed in a non-editable way, with a notice that signifies successful deletion. If the * delete operation fails, the data is displayed in a non-editable way, with an error notice. This * method first sets the id of the persistent bean from the request. Next, the persistent bean is * retrieved from the database. Only after that, the persistent bean will be deleted. This is done * to have an early warning of errors in the key, or access violations. * * @idea (jand) This would also make it possible to check here whether all information in the * request matches the information in persistent storage during this transaction. * @pre form != null; * @pre form.getPersistentBean() != null; * @pre request != null; */ private void templateDelete(final CrudDynaActionForm form, final HttpServletRequest request) throws CompoundPropertyException, IdException, TechnicalException { assert form != null; // assert form.getPersistentBean() != null; assert request != null; if (LOG.isDebugEnabled()) { LOG.debug("delete action ..."); // $NON-NLS-1$ } form.setViewModeEdit(false); AsynchronousCRUD asyncCRUD = createAsynchronousCRUD(request); DeletedEvent pbdEvent = null; try { asyncCRUD.startTransaction(); retrieveWithId(form, asyncCRUD); // IdException assert form.getPersistentBean() != null; pbdEvent = new DeletedEvent(form.getPersistentBean()); asyncCRUD.deletePersistentBean(form.getPersistentBean()); asyncCRUD.commitTransaction(form.getPersistentBean()); assert form.getPersistentBean().getId() == null; form.beanToId(); // must be null form.setViewModeDeleted(true); // rae.isEmpty()); if (LOG.isDebugEnabled()) { LOG.debug("delete action succeeded"); // $NON-NLS-1$ } } catch (CompoundPropertyException cpExc) { asyncCRUD.cancelTransaction(); form.setViewModeDeleted(false); throw cpExc; } catch (IdException pkvExc) { asyncCRUD.cancelTransaction(); form.setViewModeDeleted(false); throw pkvExc; } finally { form.beanToForm(asyncCRUD); releaseAsynchronousCRUD(asyncCRUD); } fireCommittedEvent(pbdEvent); assert !form.isViewModeNew(); assert !form.isViewModeEdit(); }
/** * Display request mode means that the user requested the application to display an object. In * display request mode, data is retrieved from persistent storage and simply displayed in a * non-editable way. The request should provide an {@link PersistentBean#getId()}. Edit request * mode means that the user request the application to display an existing object for editing. In * edit request mode, data is retrieved from persistent storage and displayed in an HTML form, so * that it can be edited. The request should provide an {@link PersistentBean#getId()}. * * @pre form.getPersistentBean() != null; * @pre request != null; */ private void templateRetrieve( final CrudDynaActionForm form, final boolean viewModeEdit, final HttpServletRequest request) throws IdException, TechnicalException { assert request != null; if (LOG.isDebugEnabled()) { LOG.debug( "retrieve for " //$NON-NLS-1$ + (viewModeEdit ? "edit" //$NON-NLS-1$ : "display") //$NON-NLS-1$ + " ..."); //$NON-NLS-1$ } AsynchronousCRUD asyncCRUD = createAsynchronousCRUD(request); try { // we are not doing this in a transaction, deliberately retrieveWithId(form, asyncCRUD); // IdException if (LOG.isDebugEnabled()) { LOG.debug("retrieve action succeeded"); // $NON-NLS-1$ } form.beanToForm(asyncCRUD); /* * We are not doing this in a transaction, deliberately. This means data * that is shown could be out of sync; but chances are this will hardly * occur, and if it does, errors will be caught when something is really * done. @todo (jand): think more about this */ /* * on IdException, we go to a different page that shows a not found * message. For this page we do not need to set any information */ } finally { releaseAsynchronousCRUD(asyncCRUD); } form.setViewModeEdit(viewModeEdit); form.setViewModeDeleted(false); form.setViewModeNew(false); }