/* * 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.modules.screens; import java.util.ArrayList; import java.util.List; import java.util.ListIterator; import org.apache.cayenne.ObjectId; import org.apache.cayenne.exp.Expression; import org.apache.cayenne.exp.ExpressionFactory; import org.apache.jetspeed.om.security.Group; import org.apache.jetspeed.om.security.Role; import org.apache.jetspeed.services.JetspeedSecurity; import org.apache.jetspeed.services.logging.JetspeedLogFactoryService; import org.apache.jetspeed.services.logging.JetspeedLogger; import org.apache.turbine.util.RunData; import com.aimluck.commons.field.ALStringField; import com.aimluck.commons.utils.ALStringUtil; import com.aimluck.eip.account.AccountResultData; import com.aimluck.eip.account.util.AccountUtils; import com.aimluck.eip.cayenne.om.account.EipMUserPosition; import com.aimluck.eip.cayenne.om.security.TurbineGroup; import com.aimluck.eip.cayenne.om.security.TurbineUser; import com.aimluck.eip.cayenne.om.security.TurbineUserGroupRole; import com.aimluck.eip.common.ALEipManager; import com.aimluck.eip.common.ALPermissionException; import com.aimluck.eip.orm.Database; import com.aimluck.eip.orm.query.Operations; import com.aimluck.eip.orm.query.ResultList; import com.aimluck.eip.orm.query.SelectQuery; import com.aimluck.eip.util.ALEipUtils; /** * * */ public class AccountUserCsvExportScreen extends ALCSVScreen { /** logger */ private static final JetspeedLogger logger = JetspeedLogFactoryService .getLogger(AccountUserCsvExportScreen.class.getName()); /** * * @param rundata * @return */ @Override protected String getContentType(RunData rundata) { return "application/octet-stream"; } /** * ResultData に値を格納して返します。(一覧データ) <BR> * * @param obj * @return */ protected AccountResultData getResultData(TurbineUser record) { try { Integer id = Integer.valueOf(record.getUserId()); AccountResultData rd = new AccountResultData(); rd.initField(); rd.setUserId(Integer.valueOf(record.getUserId()).intValue()); rd.setUserName(record.getLoginName()); rd.setName(new StringBuffer() .append(record.getLastName()) .append(" ") .append(record.getFirstName()) .toString()); rd.setFirstName(record.getFirstName()); rd.setLastName(record.getLastName()); rd.setNameKana(new StringBuffer() .append(record.getLastNameKana()) .append(" ") .append(record.getFirstNameKana()) .toString()); rd.setFirstNameKana(record.getFirstNameKana()); rd.setLastNameKana(record.getLastNameKana()); rd.setEmail(record.getEmail()); rd.setOutTelephone(record.getOutTelephone()); rd.setInTelephone(record.getInTelephone()); rd.setCellularPhone(record.getCellularPhone()); rd.setCellularMail(record.getCellularMail()); rd.setPostNameList(ALEipUtils.getPostNameList(id.intValue())); rd.setPositionName(ALEipUtils.getPositionName(record.getPositionId())); rd.setDisabled(record.getDisabled()); rd.setIsAdmin(ALEipUtils.isAdmin(Integer.valueOf(record.getUserId()))); rd.setPhotoModified(record.getPhotoModified().getTime()); rd.setCode(record.getCode()); return rd; } catch (Exception ex) { logger.error("AccountUserCsvExportScreen.getResultData", ex); return null; } } /** * */ @Override protected String getCSVString(RunData rundata) throws Exception { if (ALEipUtils.isAdmin(rundata)) { SelectQuery<TurbineUser> query = getSelectQuery(rundata); ResultList<TurbineUser> list = query.getResultList(); String LINE_SEPARATOR = System.getProperty("line.separator"); try { AccountResultData data; StringBuffer sb = new StringBuffer("\"ユーザー名\",\"パスワード\",\"名前(姓)\",\"名前(名)\"," + "\"名前(姓・フリガナ)\",\"名前(名・フリガナ)\",\"メールアドレス\"," + "\"電話番号(外線)\",\"電話番号(内線)\",\"電話番号(携帯)\"," + "\"携帯メールアドレス\",\"部署名\",\"役職\",\"社員コード\""); for (ListIterator<TurbineUser> iterator = list.listIterator(list.size()); iterator.hasPrevious();) { sb.append(LINE_SEPARATOR); data = getResultData(iterator.previous()); sb.append("\""); sb.append(data.getUserName()); sb.append("\",\""); sb.append("*");// Password sb.append("\",\""); sb.append(data.getLastName()); sb.append("\",\""); sb.append(data.getFirstName()); sb.append("\",\""); sb.append(data.getLastNameKana()); sb.append("\",\""); sb.append(data.getFirstNameKana()); sb.append("\",\""); sb.append(data.getEmail()); sb.append("\",\""); sb.append(data.getOutTelephone()); sb.append("\",\""); sb.append(data.getInTelephone()); sb.append("\",\""); sb.append(data.getCellularPhone()); sb.append("\",\""); sb.append(data.getCellularMail()); sb.append("\",\""); int i = 0, size = data.getPostNameList().size(); while (i < size - 1) { sb.append(data.getPostNameList().get(i)); sb.append("/"); ++i; } if (i == size - 1) { sb.append(data.getPostNameList().get(i)); } sb.append("\",\""); sb.append(data.getPositionName()); sb.append("\",\""); sb.append(data.getCode()); sb.append("\""); } return sb.toString(); } catch (Exception e) { logger.error("AccountUserCsvExportScreen.getCSVString", e); return null; } } else { throw new ALPermissionException(); } } /** * @param rundata * @return */ private SelectQuery<TurbineUser> getSelectQuery(RunData rundata) { ObjectId oid = new ObjectId("TurbineUser", TurbineUser.USER_ID_PK_COLUMN, 3); Expression exp_base = ExpressionFactory.matchAllDbExp( oid.getIdSnapshot(), Expression.GREATER_THAN); SelectQuery<TurbineUser> query = Database.query(TurbineUser.class, exp_base).where( Operations.eq(TurbineUser.COMPANY_ID_PROPERTY, Integer.valueOf(1)), Operations.ne(TurbineUser.DISABLED_PROPERTY, "T")); ALStringField target_keyword = new ALStringField(); target_keyword.setValue(rundata.getParameters().get("target_keyword")); String filter = rundata.getParameters().get("current_post"); String filter_role = rundata.getParameters().get("current_role"); if (target_keyword.getValue() != null && !target_keyword.getValue().equals("")) { String transWord = ALStringUtil.convertHiragana2Katakana(ALStringUtil .convertH2ZKana(target_keyword.getValue())); transWord = transWord.replace(" ", "").replace(" ", ""); // 全角/半角スペースを削除 String[] transWords = transWord.split(""); // 1文字ずつに分解 for (int i = 0; i < transWords.length; i++) { Expression exp11 = ExpressionFactory.likeExp(TurbineUser.FIRST_NAME_PROPERTY, "%" + target_keyword.getValue() + "%"); Expression exp12 = ExpressionFactory.likeExp(TurbineUser.LAST_NAME_PROPERTY, "%" + target_keyword.getValue() + "%"); Expression exp13 = ExpressionFactory.likeExp(TurbineUser.FIRST_NAME_KANA_PROPERTY, "%" + target_keyword.getValue() + "%"); Expression exp14 = ExpressionFactory.likeExp(TurbineUser.LAST_NAME_KANA_PROPERTY, "%" + target_keyword.getValue() + "%"); Expression exp15 = ExpressionFactory.likeExp(TurbineUser.EMAIL_PROPERTY, "%" + target_keyword.getValue() + "%"); Expression exp16 = ExpressionFactory.likeExp( TurbineUser.TURBINE_USER_GROUP_ROLE_PROPERTY + "." + TurbineUserGroupRole.TURBINE_GROUP_PROPERTY + "." + TurbineGroup.GROUP_ALIAS_NAME_PROPERTY, "%" + target_keyword.getValue() + "%"); Expression exp17 = ExpressionFactory.likeExp(TurbineUser.LOGIN_NAME_PROPERTY, "%" + target_keyword.getValue() + "%"); Expression exp21 = ExpressionFactory.likeExp(TurbineUser.OUT_TELEPHONE_PROPERTY, "%" + target_keyword.getValue() + "%"); Expression exp22 = ExpressionFactory.likeExp(TurbineUser.IN_TELEPHONE_PROPERTY, "%" + target_keyword.getValue() + "%"); Expression exp23 = ExpressionFactory.likeExp(TurbineUser.CELLULAR_PHONE_PROPERTY, "%" + target_keyword.getValue() + "%"); Expression exp31 = ExpressionFactory.likeExp(TurbineUser.FIRST_NAME_PROPERTY, "%" + transWords[i] + "%"); Expression exp32 = ExpressionFactory.likeExp(TurbineUser.LAST_NAME_PROPERTY, "%" + transWords[i] + "%"); Expression exp33 = ExpressionFactory.likeExp(TurbineUser.FIRST_NAME_KANA_PROPERTY, "%" + transWords[i] + "%"); Expression exp34 = ExpressionFactory.likeExp(TurbineUser.LAST_NAME_KANA_PROPERTY, "%" + transWords[i] + "%"); Expression exp35 = ExpressionFactory.likeExp( TurbineUser.TURBINE_USER_GROUP_ROLE_PROPERTY + "." + TurbineUserGroupRole.TURBINE_GROUP_PROPERTY + "." + TurbineGroup.GROUP_ALIAS_NAME_PROPERTY, "%" + transWords[i] + "%"); Expression exp36 = ExpressionFactory.likeExp(TurbineUser.CODE_PROPERTY, "%" + transWords[i] + "%"); query.andQualifier(exp11.orExp(exp12).orExp(exp13).orExp(exp14).orExp( exp15).orExp(exp16).orExp(exp17).orExp(exp21).orExp(exp22).orExp( exp23).orExp(exp31).orExp(exp32).orExp(exp33).orExp(exp34).orExp( exp35).orExp(exp36)); } } // ユーザーの状態によるフィルターが指定されている場合。 if (filter_role != null && !filter_role.equals("")) { // 管理者かどうか if (filter_role.equals(AccountUtils.ROLE_ADMIN.toString())) { try { Group group = JetspeedSecurity.getGroup("LoginUser"); Role adminrole = JetspeedSecurity.getRole("admin"); List<TurbineUserGroupRole> admins = Database .query(TurbineUserGroupRole.class) .where( Operations.eq( TurbineUserGroupRole.TURBINE_ROLE_PROPERTY, adminrole.getId()), Operations.eq( TurbineUserGroupRole.TURBINE_GROUP_PROPERTY, group.getId()), Operations.ne(TurbineUserGroupRole.TURBINE_USER_PROPERTY, 1)) .distinct(true) .fetchList(); List<Integer> admin_ids = new ArrayList<Integer>(); admin_ids.add(Integer.valueOf(1)); for (TurbineUserGroupRole tugr : admins) { admin_ids.add(tugr.getTurbineUser().getUserId()); } query.andQualifier(ExpressionFactory.inDbExp( TurbineUser.USER_ID_PK_COLUMN, admin_ids)); } catch (Exception ex) { logger.error("AccountUserCsvExportScreen.getSelectQuery", ex); } } // 有効ユーザーかどうか if (filter_role.equals(AccountUtils.ROLE_ACTIVE.toString())) { query.andQualifier(ExpressionFactory.matchExp( TurbineUser.DISABLED_PROPERTY, "F")); } // 有効ユーザーかどうか if (filter_role.equals(AccountUtils.ROLE_IN_ACTIVE.toString())) { query.andQualifier(ExpressionFactory.matchExp( TurbineUser.DISABLED_PROPERTY, "N")); } } // 部署によるフィルターが指定されている場合。 if (filter != null && !filter.equals("")) { String groupName = (ALEipManager.getInstance().getPostMap().get(Integer.valueOf(filter))) .getGroupName() .getValue(); query.where(Operations.eq(TurbineUser.TURBINE_USER_GROUP_ROLE_PROPERTY + "." + TurbineUserGroupRole.TURBINE_GROUP_PROPERTY + "." + TurbineGroup.GROUP_NAME_PROPERTY, groupName)); } query.distinct(); query.orderDesending(TurbineUser.EIP_MUSER_POSITION_PROPERTY + "." + EipMUserPosition.POSITION_PROPERTY); return query; } @Override protected String getFileName() { return "Aipo_users.csv"; } }