/** * 『役職』を追加します。 <br> * * @param rundata * @param context * @param msgList * @return */ @Override protected boolean insertFormData(RunData rundata, Context context, List<String> msgList) { try { EipMPosition position = Database.create(EipMPosition.class); position.setPositionName(position_name.getValue()); Date now = new Date(); position.setCreateDate(now); position.setUpdateDate(now); Database.commit(); // イベントログに保存 ALEventlogFactoryService.getInstance() .getEventlogHandler() .log( position.getPositionId(), ALEventlogConstants.PORTLET_TYPE_ACCOUNT, "役職「" + position.getPositionName() + "」を追加"); position_id = position.getPositionId().intValue(); ALEipManager.getInstance().reloadPosition(); } catch (Exception ex) { Database.rollback(); logger.error("AccountPositionFormData.insertFormData", ex); return false; } return true; }
/** * 『役職』を更新します。 <br> * * @param rundata * @param context * @param msgList * @return */ @Override protected boolean updateFormData(RunData rundata, Context context, List<String> msgList) { try { // オブジェクトモデルを取得 EipMPosition record = AccountUtils.getEipMPosition(rundata, context); if (record == null) { return false; } record.setPositionName(position_name.getValue()); record.setUpdateDate(new Date()); Database.commit(); // イベントログに保存 ALEventlogFactoryService.getInstance() .getEventlogHandler() .log( record.getPositionId(), ALEventlogConstants.PORTLET_TYPE_ACCOUNT, "役職「" + record.getPositionName() + "」を更新"); ALEipManager.getInstance().reloadPosition(); } catch (Exception ex) { Database.rollback(); logger.error("AccountPositionFormData.updateFormData", ex); return false; } return true; }
/** * @param rundata * @param context * @param values * @param msgList * @return * @throws ALPageNotFoundException * @throws ALDBErrorException */ @Override protected boolean action( RunData rundata, Context context, List<String> values, List<String> msgList) throws ALPageNotFoundException, ALDBErrorException { try { Expression exp1 = ExpressionFactory.matchExp( EipTNoteMap.USER_ID_PROPERTY, Integer.valueOf(ALEipUtils.getUserId(rundata))); Expression exp2 = ExpressionFactory.inDbExp(EipTNote.NOTE_ID_PK_COLUMN, values); List<EipTNoteMap> list = Database.query(EipTNoteMap.class, exp1).andQualifier(exp2).fetchList(); if (list == null || list.size() <= 0) { return false; } for (EipTNoteMap notemap : list) { notemap.setNoteStat(NoteUtils.NOTE_STAT_READ); } Database.commit(); } catch (Exception ex) { Database.rollback(); logger.error("note", ex); return false; } return true; }
/** * ロールをデータベースに格納します。 <br> * * @param rundata * @param context * @param msgList * @return TRUE 成功 FALSE 失敗 */ @Override protected boolean insertFormData(RunData rundata, Context context, List<String> msgList) { try { Date now = Calendar.getInstance().getTime(); // 新規オブジェクトモデル EipTAclRole aclrole = Database.create(EipTAclRole.class); aclrole.setRoleName(acl_role_name.getValue()); aclrole.setNote(note.getValue()); long aclType = getAclTypeValue(); aclrole.setAclType(Integer.valueOf((int) aclType)); EipTAclPortletFeature feature = Database.get(EipTAclPortletFeature.class, Integer.valueOf((int) feature_id.getValue())); aclrole.setEipTAclPortletFeature(feature); // 登録日 aclrole.setCreateDate(now); // 更新日 aclrole.setUpdateDate(now); // userMapの登録 insertEipTAclUserRoleMap(aclrole, memberList.get(0)); // メンバー登録 int size = memberList.size(); for (int i = 1; i < size; i++) { insertEipTAclUserRoleMap(aclrole, memberList.get(i)); } // ロールを登録 Database.commit(); // イベントログに保存 ALEventlogFactoryService.getInstance() .getEventlogHandler() .log( aclrole.getRoleId(), ALEventlogConstants.PORTLET_TYPE_ACCESSCTL, ALLocalizationUtils.getl10nFormat("ACCESSCTL_EVENTLOG_ADD", aclrole.getRoleName())); } catch (Exception ex) { Database.rollback(); logger.error("AccessControlFormData.insertFormData", ex); return false; } return true; }
/** * @param rundata * @param context * @param values * @param msgList * @return */ @SuppressWarnings("unchecked") @Override protected boolean action( RunData rundata, Context context, List<String> values, List<String> msgList) { try { // カテゴリを削除 // DBテーブルのカスケード設定で, // トピックおよび添付ファイルのレコードも自動的に削除される. SelectQuery<EipTMsgboardCategory> query = getSelectQuery(rundata, values); List<EipTMsgboardCategory> list = query.fetchList(); if (list == null || list.size() == 0) { // カテゴリリストが空の場合 logger.debug("[MsgboardMultiDelete] Empty CategoryIDs..."); return false; } for (EipTMsgboardCategory category : list) { // 添付ファイルの削除 List<EipTMsgboardTopic> topics = category.getEipTMsgboardTopics(); for (EipTMsgboardTopic topic : topics) { MsgboardUtils.deleteAttachmentFiles(topic); } Database.delete(category); // イベントログに保存 ALEventlogFactoryService.getInstance() .getEventlogHandler() .log( category.getCategoryId(), ALEventlogConstants.PORTLET_TYPE_MSGBOARD_CATEGORY, category.getCategoryName()); } Database.commit(); // 一覧表示画面のフィルタに設定されているカテゴリのセッション情報を削除 String filtername = MsgboardTopicSelectData.class.getSimpleName() + ALEipConstants.LIST_FILTER; ALEipUtils.removeTemp(rundata, context, filtername); } catch (Exception ex) { Database.rollback(); logger.error("msgboard", ex); return false; } return true; }
/** * ロールをデータベースから削除します。 <br> * * @param rundata * @param context * @param msgList * @return TRUE 成功 FALSE 失敗 */ @Override protected boolean deleteFormData(RunData rundata, Context context, List<String> msgList) { try { String aclroleid = ALEipUtils.getTemp(rundata, context, ALEipConstants.ENTITY_ID); if (aclroleid == null || Integer.valueOf(aclroleid) == null) { // IDが空の場合 logger.debug("[AccessControlUtils] Empty ID..."); return false; } Expression exp = ExpressionFactory.matchDbExp(EipTAclRole.ROLE_ID_PK_COLUMN, aclroleid); SelectQuery<EipTAclRole> query = Database.query(EipTAclRole.class, exp); List<EipTAclRole> aclroles = query.fetchList(); if (aclroles == null || aclroles.size() == 0) { // 指定したIDのレコードが見つからない場合 logger.debug("[AccessControlUtils] Not found ID..."); return false; } // オブジェクトを削除(Cayenneのカスケード設定でEipTAclUserRoleMapも同時に削除) Database.delete(aclroles.get(0)); Database.commit(); // イベントログに保存 for (EipTAclRole role : aclroles) { ALEventlogFactoryService.getInstance() .getEventlogHandler() .log( role.getRoleId(), ALEventlogConstants.PORTLET_TYPE_ACCESSCTL, ALLocalizationUtils.getl10nFormat("ACCESSCTL_EVENTLOG_DELETE", role.getRoleName())); } } catch (Exception ex) { Database.rollback(); logger.error("AccessControlFormData.deleteFormData", ex); return false; } return true; }
/** * 掲示板カテゴリを削除します。 <br> * * @param rundata * @param context * @param msgList * @return */ @SuppressWarnings("unchecked") @Override protected boolean deleteFormData(RunData rundata, Context context, List<String> msgList) throws ALPageNotFoundException, ALDBErrorException { try { // オブジェクトモデルを取得 EipTMsgboardCategory category = MsgboardUtils.getEipTMsgboardCategory(rundata, context, true); if (category == null) { return false; } // 掲示板カテゴリを削除 // DBテーブルのカスケード設定で, // トピックおよび添付ファイルのレコードも自動的に削除される. // イベントログに保存 ALEventlogFactoryService.getInstance() .getEventlogHandler() .log( category.getCategoryId(), ALEventlogConstants.PORTLET_TYPE_MSGBOARD_CATEGORY, category.getCategoryName()); List<EipTMsgboardTopic> topics = category.getEipTMsgboardTopics(); for (EipTMsgboardTopic topic : topics) { MsgboardUtils.deleteAttachmentFiles(topic); } Database.delete(category); Database.commit(); // 一覧表示画面のフィルタに設定されているカテゴリのセッション情報を削除 String filtername = MsgboardTopicSelectData.class.getName() + ALEipConstants.LIST_FILTER; ALEipUtils.removeTemp(rundata, context, filtername); } catch (Exception e) { Database.rollback(); logger.error("[MsgboardFormData]", e); throw new ALDBErrorException(); } return true; }
/** * 『役職』を削除します。 <br> * * @param rundata * @param context * @param msgList * @return */ @Override protected boolean deleteFormData(RunData rundata, Context context, List<String> msgList) { try { // オブジェクトモデルを取得 EipMPosition record = AccountUtils.getEipMPosition(rundata, context); if (record == null) { return false; } // 役職IDを取得 int positionId = record.getPositionId(); // 役職を削除 Database.delete(record); Database.commit(); // イベントログに保存 ALEventlogFactoryService.getInstance() .getEventlogHandler() .log( record.getPositionId(), ALEventlogConstants.PORTLET_TYPE_ACCOUNT, "役職「" + record.getPositionName() + "」を削除"); // この役職に設定されているユーザーの役職IDを0とする String sql = "UPDATE turbine_user set POSITION_ID = 0 where POSITION_ID = " + positionId; Database.sql(TurbineUser.class, sql).execute(); ALEipManager.getInstance().reloadPosition(); } catch (Exception ex) { Database.rollback(); logger.error("AccountPositionFormData.deleteFormData", ex); return false; } return true; }
/** * データベースに格納されている掲示板カテゴリを更新します。 <br> * * @param rundata * @param context * @param msgList * @return */ @Override protected boolean updateFormData(RunData rundata, Context context, List<String> msgList) throws ALPageNotFoundException, ALDBErrorException { try { // オブジェクトモデルを取得 EipTMsgboardCategory category = MsgboardUtils.getEipTMsgboardCategory(rundata, context, true); if (category == null) { return false; } // カテゴリ名 category.setCategoryName(category_name.getValue()); // メモ category.setNote(note.getValue()); // 閲覧返信フラグ int accessFlag = (int) access_flag.getValue(); if (accessFlag == MsgboardUtils.ACCESS_PUBLIC_ALL || accessFlag == MsgboardUtils.ACCESS_PUBLIC_MEMBER) { category.setPublicFlag(MsgboardUtils.PUBLIC_FLG_VALUE_PUBLIC); } else { category.setPublicFlag(MsgboardUtils.PUBLIC_FLG_VALUE_NONPUBLIC); } // ユーザーID // category.setTurbineUser(tuser); // 更新日 category.setUpdateDate(Calendar.getInstance().getTime()); SelectQuery<EipTMsgboardCategoryMap> mapquery = Database.query(EipTMsgboardCategoryMap.class); Expression mapexp = ExpressionFactory.matchExp( EipTMsgboardCategoryMap.CATEGORY_ID_PROPERTY, category.getCategoryId()); mapquery.setQualifier(mapexp); List<EipTMsgboardCategoryMap> maplist = mapquery.fetchList(); Database.deleteAll(maplist); int size = memberList.size(); for (int i = 0; i < size; i++) { EipTMsgboardCategoryMap map = Database.create(EipTMsgboardCategoryMap.class); ALEipUser user = memberList.get(i); int userid = (int) user.getUserId().getValue(); map.setEipTMsgboardCategory(category); map.setUserId(Integer.valueOf(userid)); // O: 自カテゴリ S: 共有カテゴリ(Share) if (userid == ALEipUtils.getUserId(rundata)) { if (accessFlag == MsgboardUtils.ACCESS_PUBLIC_ALL || accessFlag == MsgboardUtils.ACCESS_SEACRET_SELF) { // 所属メンバーがログインユーザのみの場合 map.setStatus(MsgboardUtils.STAT_VALUE_ALL); } else { map.setStatus(MsgboardUtils.STAT_VALUE_OWNER); } } else { map.setStatus(MsgboardUtils.STAT_VALUE_SHARE); } } Database.commit(); // イベントログに保存 ALEventlogFactoryService.getInstance() .getEventlogHandler() .log( category.getCategoryId(), ALEventlogConstants.PORTLET_TYPE_MSGBOARD_CATEGORY, category.getCategoryName()); } catch (Exception e) { Database.rollback(); logger.error("[MsgboardFormData]", e); throw new ALDBErrorException(); } return true; }
/** * 掲示板カテゴリをデータベースに格納します。 <br> * * @param rundata * @param context * @param msgList * @return */ @Override protected boolean insertFormData(RunData rundata, Context context, List<String> msgList) throws ALPageNotFoundException, ALDBErrorException { try { TurbineUser tuser = Database.get(TurbineUser.class, Integer.valueOf(ALEipUtils.getUserId(rundata))); // 新規オブジェクトモデル EipTMsgboardCategory category = Database.create(EipTMsgboardCategory.class); // カテゴリ名 category.setCategoryName(category_name.getValue()); // メモ category.setNote(note.getValue()); int accessFlag = (int) access_flag.getValue(); if (accessFlag == MsgboardUtils.ACCESS_PUBLIC_ALL || accessFlag == MsgboardUtils.ACCESS_PUBLIC_MEMBER) { category.setPublicFlag(MsgboardUtils.PUBLIC_FLG_VALUE_PUBLIC); } else { category.setPublicFlag(MsgboardUtils.PUBLIC_FLG_VALUE_NONPUBLIC); } // ユーザーID category.setTurbineUser(tuser); // 作成日 category.setCreateDate(Calendar.getInstance().getTime()); // 更新日 category.setUpdateDate(Calendar.getInstance().getTime()); int size = memberList.size(); for (int i = 0; i < size; i++) { EipTMsgboardCategoryMap map = Database.create(EipTMsgboardCategoryMap.class); ALEipUser user = memberList.get(i); int userid = (int) user.getUserId().getValue(); map.setEipTMsgboardCategory(category); map.setUserId(Integer.valueOf(userid)); // O: 自カテゴリ S: 共有カテゴリ(Share) if (userid == ALEipUtils.getUserId(rundata)) { if (accessFlag == MsgboardUtils.ACCESS_PUBLIC_ALL || accessFlag == MsgboardUtils.ACCESS_SEACRET_SELF) { // 所属メンバーがログインユーザのみの場合 map.setStatus(MsgboardUtils.STAT_VALUE_ALL); } else { map.setStatus(MsgboardUtils.STAT_VALUE_OWNER); } } else { map.setStatus(MsgboardUtils.STAT_VALUE_SHARE); } } // 掲示板カテゴリを登録 Database.commit(); // イベントログに保存 ALEventlogFactoryService.getInstance() .getEventlogHandler() .log( category.getCategoryId(), ALEventlogConstants.PORTLET_TYPE_MSGBOARD_CATEGORY, category.getCategoryName()); } catch (Exception e) { Database.rollback(); logger.error("[MsgboardFormData]", e); throw new ALDBErrorException(); } return true; }
/** * 処理を実行します。 * * @param rundata RunData * @param context Context * @param values List<String> * @param msgList エラーメッセージリスト * @return TRUE 成功 FALSE 失敗 */ @Override protected boolean action( RunData rundata, Context context, List<String> values, List<String> msgList) { try { // 削除対象の区分値を取得 SelectQuery<EipMGpdbKubunValue> query = Database.query(EipMGpdbKubunValue.class); query.setQualifier( ExpressionFactory.inDbExp(EipMGpdbKubunValue.GPDB_KUBUN_VALUE_ID_PK_COLUMN, values)); List<EipMGpdbKubunValue> flist = query.fetchList(); if (flist == null || flist.isEmpty()) { return false; } // チェック List<Integer> checkedKubunList = new ArrayList<Integer>(); // チェック済み区分 for (EipMGpdbKubunValue value : flist) { EipMGpdbKubun Gpdbkubun = GpdbUtils.getEipMGpdbKubun(value.getGpdbKubunId()); int kubunCount = GpdbUtils.getRecordCountKubunUsed("" + value.getGpdbKubunValueId()); if (kubunCount > 0) { // Webデータベースレコードが登録されている場合 msgList.add( "選択項目 『" + Gpdbkubun.getGpdbKubunName() + "』 の値 『" + value.getGpdbKubunValue() + "』 は使用されているため削除できません。"); } else { int kubunId = value.getGpdbKubunId(); if (!checkedKubunList.contains(kubunId)) { SelectQuery<EipTGpdbItem> valQuery = Database.query(EipTGpdbItem.class); valQuery.setQualifier( ExpressionFactory.matchExp(EipTGpdbItem.GPDB_KUBUN_ID_PROPERTY, kubunId)); if (!valQuery.fetchList().isEmpty()) { // 区分値リストを取得 List<GpdbKubunValueResultData> valList = GpdbUtils.getGpdbKubunValueList("" + kubunId); if (valList != null && !valList.isEmpty()) { msgList.add( "選択項目 『" + Gpdbkubun.getGpdbKubunName() + "』 は項目定義されているため、全ての値は削除できません。"); } } checkedKubunList.add(kubunId); } } } if (!msgList.isEmpty()) { return false; } // 削除処理 for (EipMGpdbKubunValue value : flist) { Database.delete(value); Database.commit(); EipMGpdbKubun Gpdbkubun = GpdbUtils.getEipMGpdbKubun(value.getGpdbKubunId()); // イベントログに保存 ALEventlogFactoryService.getInstance() .getEventlogHandler() .log( value.getGpdbKubunValueId(), ALEventlogConstants.PORTLET_TYPE_GPDB, "Webデータベース 選択項目「" + Gpdbkubun.getGpdbKubunName() + "」 値 「" + value.getGpdbKubunValue() + "」 削除"); } // 区分値を持たない区分を削除 if (GpdbUtils.removeGpdbKubunNoValue()) { Database.commit(); } } catch (Exception ex) { Database.rollback(); logger.error("Exception", ex); return false; } return true; }