/*
* Aipo is a groupware program developed by TOWN, Inc.
* Copyright (C) 2004-2015 TOWN, Inc.
* http://www.aipo.com
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 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 Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package com.aimluck.eip.msgboard;
import java.util.ArrayList;
import java.util.List;
import java.util.jar.Attributes;
import org.apache.cayenne.exp.Expression;
import org.apache.cayenne.exp.ExpressionFactory;
import org.apache.jetspeed.services.logging.JetspeedLogFactoryService;
import org.apache.jetspeed.services.logging.JetspeedLogger;
import org.apache.turbine.services.TurbineServices;
import org.apache.turbine.util.RunData;
import org.apache.velocity.context.Context;
import com.aimluck.commons.utils.ALDateUtil;
import com.aimluck.eip.cayenne.om.portlet.EipTMsgboardCategory;
import com.aimluck.eip.cayenne.om.portlet.EipTMsgboardCategoryMap;
import com.aimluck.eip.cayenne.om.security.TurbineUser;
import com.aimluck.eip.common.ALAbstractSelectData;
import com.aimluck.eip.common.ALDBErrorException;
import com.aimluck.eip.common.ALData;
import com.aimluck.eip.common.ALEipConstants;
import com.aimluck.eip.common.ALEipUser;
import com.aimluck.eip.common.ALPageNotFoundException;
import com.aimluck.eip.common.ALPermissionException;
import com.aimluck.eip.modules.actions.common.ALAction;
import com.aimluck.eip.msgboard.util.MsgboardUtils;
import com.aimluck.eip.orm.Database;
import com.aimluck.eip.orm.query.ResultList;
import com.aimluck.eip.orm.query.SelectQuery;
import com.aimluck.eip.services.accessctl.ALAccessControlConstants;
import com.aimluck.eip.services.accessctl.ALAccessControlFactoryService;
import com.aimluck.eip.services.accessctl.ALAccessControlHandler;
import com.aimluck.eip.util.ALCommonUtils;
import com.aimluck.eip.util.ALEipUtils;
/**
* 掲示板カテゴリ検索データを管理するクラスです。 <BR>
*
*/
public class MsgboardCategorySelectData extends
ALAbstractSelectData<EipTMsgboardCategoryMap, EipTMsgboardCategory>
implements ALData {
/** logger */
private static final JetspeedLogger logger = JetspeedLogFactoryService
.getLogger(MsgboardCategorySelectData.class.getName());
/** カテゴリ一覧 */
private List<MsgboardCategoryResultData> categoryList;
/** カテゴリの総数 */
private int categorySum;
/** ログインユーザ ID */
private int uid;
/** <code>members</code> 共有メンバー */
private List<ALEipUser> members;
/** 他人のカテゴリ詳細表示権限 */
private boolean authority_detail;
/** 他人のカテゴリ編集権限 */
private boolean authority_edit;
/** 他人のカテゴリ削除権限 */
private boolean authority_delete;
/**
*
* @param action
* @param rundata
* @param context
*/
@Override
public void init(ALAction action, RunData rundata, Context context)
throws ALPageNotFoundException, ALDBErrorException {
String sort = ALEipUtils.getTemp(rundata, context, LIST_SORT_STR);
if (sort == null || sort.equals("")) {
ALEipUtils.setTemp(rundata, context, LIST_SORT_STR, "category_name");
logger.debug("[MsgboardCategorySelectData] Init Parameter. : "
+ "category_name");
}
uid = ALEipUtils.getUserId(rundata);
authority_detail =
MsgboardUtils.checkPermission(
rundata,
context,
ALAccessControlConstants.VALUE_ACL_DETAIL,
ALAccessControlConstants.POERTLET_FEATURE_MSGBOARD_CATEGORY_OTHER);
authority_edit =
MsgboardUtils.checkPermission(
rundata,
context,
ALAccessControlConstants.VALUE_ACL_UPDATE,
ALAccessControlConstants.POERTLET_FEATURE_MSGBOARD_CATEGORY_OTHER);
authority_delete =
MsgboardUtils.checkPermission(
rundata,
context,
ALAccessControlConstants.VALUE_ACL_DELETE,
ALAccessControlConstants.POERTLET_FEATURE_MSGBOARD_CATEGORY_OTHER);
super.init(action, rundata, context);
}
/**
*
* @param rundata
* @param context
*/
public void loadCategoryList(RunData rundata) {
// カテゴリ一覧
categoryList = MsgboardUtils.loadCategoryList(rundata);
}
/**
* 一覧データを取得します。 <BR>
*
* @param rundata
* @param context
* @return
*/
@Override
protected ResultList<EipTMsgboardCategoryMap> selectList(RunData rundata,
Context context) {
try {
SelectQuery<EipTMsgboardCategoryMap> query =
getSelectQuery(rundata, context);
buildSelectQueryForListView(query);
buildSelectQueryForListViewSort(query, rundata, context);
ResultList<EipTMsgboardCategoryMap> list = query.getResultList();
// 件数をセットする.
categorySum = list.getTotalCount();
return list;
} catch (Exception ex) {
logger.error("msgboard", ex);
return null;
}
}
/**
* 検索条件を設定した SelectQuery を返します。 <BR>
*
* @param rundata
* @param context
* @return
*/
private SelectQuery<EipTMsgboardCategoryMap> getSelectQuery(RunData rundata,
Context context) {
SelectQuery<EipTMsgboardCategoryMap> query =
Database.query(EipTMsgboardCategoryMap.class);
Expression exp1 =
ExpressionFactory.noMatchDbExp(
EipTMsgboardCategoryMap.EIP_TMSGBOARD_CATEGORY_PROPERTY
+ "."
+ EipTMsgboardCategory.TURBINE_USER_PROPERTY
+ "."
+ TurbineUser.USER_ID_PK_COLUMN,
Integer.valueOf(0));
query.setQualifier(exp1);
// アクセス制御
int loginUserId = ALEipUtils.getUserId(rundata);
ALAccessControlFactoryService aclservice =
(ALAccessControlFactoryService) ((TurbineServices) TurbineServices
.getInstance()).getService(ALAccessControlFactoryService.SERVICE_NAME);
ALAccessControlHandler aclhandler = aclservice.getAccessControlHandler();
boolean hasAclviewOther =
aclhandler.hasAuthority(
loginUserId,
ALAccessControlConstants.POERTLET_FEATURE_MSGBOARD_CATEGORY_OTHER,
ALAccessControlConstants.VALUE_ACL_LIST);
Expression exp01 =
ExpressionFactory.matchExp(
EipTMsgboardCategoryMap.EIP_TMSGBOARD_CATEGORY_PROPERTY
+ "."
+ EipTMsgboardCategory.PUBLIC_FLAG_PROPERTY,
MsgboardUtils.PUBLIC_FLG_VALUE_PUBLIC);
Expression exp02 =
ExpressionFactory.matchExp(
EipTMsgboardCategoryMap.STATUS_PROPERTY,
MsgboardUtils.STAT_VALUE_OWNER);
Expression exp03 =
ExpressionFactory.matchExp(
EipTMsgboardCategoryMap.STATUS_PROPERTY,
MsgboardUtils.STAT_VALUE_ALL);
Expression exp11 =
ExpressionFactory.matchExp(
EipTMsgboardCategoryMap.EIP_TMSGBOARD_CATEGORY_PROPERTY
+ "."
+ EipTMsgboardCategory.PUBLIC_FLAG_PROPERTY,
MsgboardUtils.PUBLIC_FLG_VALUE_NONPUBLIC);
Expression exp12 =
ExpressionFactory.matchExp(
EipTMsgboardCategoryMap.USER_ID_PROPERTY,
Integer.valueOf(ALEipUtils.getUserId(rundata)));
if (!hasAclviewOther) {
query.andQualifier((exp01.andExp(exp02.orExp(exp03))).orExp(exp11
.andExp(exp12)));
} else {
query.andQualifier((exp01.andExp(exp02.orExp(exp03))).orExp(exp11
.andExp(exp02.orExp(exp03))));
}
query.distinct(true);
return query;
}
/**
* 詳細データを取得します。 <BR>
*
* @param rundata
* @param context
* @return
*/
@Override
protected EipTMsgboardCategory selectDetail(RunData rundata, Context context)
throws ALPageNotFoundException, ALDBErrorException {
// オブジェクトモデルを取得
return MsgboardUtils.getEipTMsgboardCategory(rundata, context, false);
}
/**
* ResultDataを取得します。(一覧データ) <BR>
*
* @param obj
* @return
*/
@Override
protected Object getResultData(EipTMsgboardCategoryMap record)
throws ALPageNotFoundException, ALDBErrorException {
MsgboardCategoryResultData rd = new MsgboardCategoryResultData();
rd.initField();
try {
EipTMsgboardCategory category = record.getEipTMsgboardCategory();
rd.setCategoryId(category.getCategoryId().intValue());
rd.setCategoryName(ALCommonUtils.compressString(category
.getCategoryName(), getStrLength()));
rd.setNote(category.getNote());
rd.setOwnerId(category.getTurbineUser().getUserId().longValue());
// 公開/非公開を設定する.
rd.setPublicFlag((MsgboardUtils.PUBLIC_FLG_VALUE_PUBLIC).equals(category
.getPublicFlag()));
rd.setOwnerName(ALEipUtils.getUserFullName(category
.getTurbineUser()
.getUserId()
.intValue()));
rd.setLoginUserId(uid);
} catch (Exception e) {
logger.error("[MsgboardCategorySelectData]", e);
throw new ALDBErrorException();
}
return rd;
}
/**
* ResultDataを取得します。(詳細データ) <BR>
*
* @param obj
* @return
*/
@Override
protected Object getResultDataDetail(EipTMsgboardCategory record)
throws ALPageNotFoundException, ALDBErrorException {
MsgboardCategoryResultData rd = new MsgboardCategoryResultData();
rd.initField();
try {
String loginUserStatus = null;
// 公開区分
boolean public_flag =
(MsgboardUtils.PUBLIC_FLG_VALUE_PUBLIC).equals(record.getPublicFlag());
SelectQuery<EipTMsgboardCategoryMap> mapquery =
Database.query(EipTMsgboardCategoryMap.class);
Expression mapexp =
ExpressionFactory.matchDbExp(
EipTMsgboardCategory.CATEGORY_ID_PK_COLUMN,
record.getCategoryId());
mapquery.setQualifier(mapexp);
List<EipTMsgboardCategoryMap> list = mapquery.fetchList();
List<Integer> users = new ArrayList<Integer>();
int size = list.size();
if (size == 1) {
EipTMsgboardCategoryMap map = list.get(0);
users.add(map.getUserId());
loginUserStatus = map.getStatus();
} else {
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));
members = ALEipUtils.getUsersFromSelectQuery(query);
rd.setCategoryId(record.getCategoryId().intValue());
rd.setCategoryName(record.getCategoryName());
rd.setNote(record.getNote());
// 公開/非公開を設定する.
// rd.setPublicFlag("T".equals(record.getPublicFlag()));
rd.setOwnerId(record.getTurbineUser().getUserId().intValue());
rd.setOwnerName(ALEipUtils.getUserFullName(record
.getTurbineUser()
.getUserId()
.intValue()));
rd.setCreateDate(ALDateUtil.format(record.getCreateDate(), "yyyy年M月d日"));
rd.setUpdateDate(ALDateUtil.format(record.getUpdateDate(), "yyyy年M月d日"));
rd.setLoginUserId(uid);
if (public_flag) {
if ((MsgboardUtils.STAT_VALUE_ALL).equals(loginUserStatus)) {
rd.setAccessFlag(MsgboardUtils.ACCESS_PUBLIC_ALL);
} else {
rd.setAccessFlag(MsgboardUtils.ACCESS_PUBLIC_MEMBER);
}
} else {
if ((MsgboardUtils.STAT_VALUE_ALL).equals(loginUserStatus)) {
rd.setAccessFlag(MsgboardUtils.ACCESS_SEACRET_SELF);
} else {
rd.setAccessFlag(MsgboardUtils.ACCESS_SEACRET_MEMBER);
}
}
} catch (Exception e) {
logger.error("[MsgboardCategorySelectData]", e);
throw new ALDBErrorException();
}
return rd;
}
@Override
public boolean doViewDetail(ALAction action, RunData rundata, Context context) {
try {
init(action, rundata, context);
doCheckAclPermission(
rundata,
context,
ALAccessControlConstants.VALUE_ACL_DETAIL);
action.setMode(ALEipConstants.MODE_DETAIL);
EipTMsgboardCategory obj = selectDetail(rundata, context);
if (obj != null) {
data = getResultDataDetail(obj);
// 公開区分
boolean public_flag =
(MsgboardUtils.PUBLIC_FLG_VALUE_PUBLIC).equals(obj.getPublicFlag());
boolean isMember = false;
// このカテゴリを共有しているメンバーを取得
SelectQuery<EipTMsgboardCategoryMap> mapquery =
Database.query(EipTMsgboardCategoryMap.class);
Expression mapexp =
ExpressionFactory.matchDbExp(
EipTMsgboardCategory.CATEGORY_ID_PK_COLUMN,
obj.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()) {
isMember = true;
}
}
// 自分がメンバーではない非公開のカテゴリで、他人のカテゴリの詳細表示権限がない場合はエラー
if (!public_flag && !isMember && !authority_detail) {
throw new ALPermissionException();
}
}
action.setResultData(this);
action.putData(rundata, context);
return (data != null);
} catch (ALPermissionException e) {
ALEipUtils.redirectPermissionError(rundata);
return false;
} catch (ALPageNotFoundException e) {
ALEipUtils.redirectPageNotFound(rundata);
return false;
} catch (ALDBErrorException e) {
ALEipUtils.redirectDBError(rundata);
return false;
}
}
/**
*
* @return
*/
public List<MsgboardCategoryResultData> getCategoryList() {
return categoryList;
}
/**
* @return
*
*/
@Override
protected Attributes getColumnMap() {
Attributes map = new Attributes();
map.putValue(
"category_name",
EipTMsgboardCategoryMap.EIP_TMSGBOARD_CATEGORY_PROPERTY
+ "."
+ EipTMsgboardCategory.CATEGORY_NAME_PROPERTY);
map.putValue(
"create_user",
EipTMsgboardCategoryMap.EIP_TMSGBOARD_CATEGORY_PROPERTY
+ "."
+ EipTMsgboardCategory.TURBINE_USER_PROPERTY
+ "."
+ TurbineUser.LAST_NAME_KANA_PROPERTY);
return map;
}
public int getCategorySum() {
return categorySum;
}
public int getUserId() {
return uid;
}
/**
*
* @param id
* @return
*/
public boolean isMatch(int id1, long id2) {
return id1 == (int) id2;
}
public boolean getAuthorityEdit() {
return authority_edit;
}
public boolean getAuthorityDelete() {
return authority_delete;
}
/**
* 共有メンバーを取得します。
*
* @return
*/
public List<ALEipUser> getMemberList() {
return members;
}
/**
* アクセス権限チェック用メソッド。 アクセス権限の機能名を返します。
*
* @return
*/
@Override
public String getAclPortletFeature() {
return ALAccessControlConstants.POERTLET_FEATURE_MSGBOARD_CATEGORY;
}
}