/** * 掲示板カテゴリをデータベースに格納します。 <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; }
/** * データベースに格納されている掲示板カテゴリを更新します。 <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 loadFormData(RunData rundata, Context context, List<String> msgList) throws ALPageNotFoundException, ALDBErrorException { try { String loginUserStatus = null; int uid = (int) login_user.getUserId().getValue(); // オブジェクトモデルを取得 EipTMsgboardCategory category = MsgboardUtils.getEipTMsgboardCategory(rundata, context, true); if (category == null) { return false; } // カテゴリ名 category_name.setValue(category.getCategoryName()); // メモ note.setValue(category.getNote()); // 公開区分 boolean public_flag = (MsgboardUtils.PUBLIC_FLG_VALUE_PUBLIC).equals(category.getPublicFlag()); // このカテゴリを共有しているメンバーを取得 SelectQuery<EipTMsgboardCategoryMap> mapquery = Database.query(EipTMsgboardCategoryMap.class); Expression mapexp = ExpressionFactory.matchDbExp( EipTMsgboardCategory.CATEGORY_ID_PK_COLUMN, category.getCategoryId()); mapquery.setQualifier(mapexp); List<EipTMsgboardCategoryMap> list = mapquery.fetchList(); List<Integer> users = new ArrayList<Integer>(); int size = list.size(); for (int i = 0; i < size; i++) { EipTMsgboardCategoryMap map = list.get(i); users.add(map.getUserId()); if (uid == map.getUserId().intValue()) { loginUserStatus = map.getStatus(); } } SelectQuery<TurbineUser> query = Database.query(TurbineUser.class); Expression exp = ExpressionFactory.inDbExp(TurbineUser.USER_ID_PK_COLUMN, users); Expression nonDisabledexp = ExpressionFactory.noMatchExp(TurbineUser.DISABLED_PROPERTY, "T"); query.setQualifier(exp.andExp(nonDisabledexp)); memberList.addAll(ALEipUtils.getUsersFromSelectQuery(query)); if (public_flag) { if ((MsgboardUtils.STAT_VALUE_ALL).equals(loginUserStatus)) { access_flag.setValue(MsgboardUtils.ACCESS_PUBLIC_ALL); is_member = false; } else { access_flag.setValue(MsgboardUtils.ACCESS_PUBLIC_MEMBER); is_member = true; } } else { if ((MsgboardUtils.STAT_VALUE_ALL).equals(loginUserStatus)) { access_flag.setValue(MsgboardUtils.ACCESS_SEACRET_SELF); is_member = false; } else { access_flag.setValue(MsgboardUtils.ACCESS_SEACRET_MEMBER); is_member = true; } } } catch (Exception e) { logger.error("[MsgboardFormData]", e); throw new ALDBErrorException(); } return true; }