/* * 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 net.sf.json.JSONArray; 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.eip.schedule.util.ScheduleUtils; 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.userfacility.util.UserFacilityUtils; import com.aimluck.eip.util.ALEipUtils; /** * 設備情報をJSONデータとして出力するクラスです。 <br /> * */ public class ScheduleUserFacilityLiteJSONScreen extends ALJSONScreen { /** logger */ private static final JetspeedLogger logger = JetspeedLogFactoryService .getLogger(ScheduleUserFacilityLiteJSONScreen.class.getName()); @Override protected String getJSONString(RunData rundata, Context context) throws Exception { String result = ""; JSONArray json; try { String mode = rundata.getParameters().getString("mode"); if ("group".equals(mode)) { String[] groupname = rundata.getParameters().getString("groupname").split(";"); if ("f".equals(groupname[0])) { if ("all".equals(groupname[1])) { json = JSONArray.fromObject(UserFacilityUtils .getAllFacilityLiteBeans(rundata)); } else { json = JSONArray.fromObject(UserFacilityUtils .getFacilityLiteBeansFromGroup(rundata, Integer .valueOf(groupname[1]))); } } else { if ("allgroups".equals(groupname[0])) { json = JSONArray.fromObject(UserFacilityUtils .getAllFacilityLiteBeans(rundata)); } else { boolean hasAclviewOther; int userid = ALEipUtils.getUserId(rundata); // アクセス権限 ALAccessControlFactoryService aclservice = (ALAccessControlFactoryService) ((TurbineServices) TurbineServices .getInstance()) .getService(ALAccessControlFactoryService.SERVICE_NAME); ALAccessControlHandler aclhandler = aclservice.getAccessControlHandler(); hasAclviewOther = aclhandler.hasAuthority( userid, ALAccessControlConstants.POERTLET_FEATURE_SCHEDULE_OTHER, ALAccessControlConstants.VALUE_ACL_LIST); if (hasAclviewOther) { json = JSONArray.fromObject(UserFacilityUtils .getUserFacilityLiteBeansFromGroup(rundata, groupname[0])); } else { json = JSONArray.fromObject(ScheduleUtils .getUserFacilityLiteBeansFromGroup(rundata, groupname[0])); } } } } else { json = new JSONArray(); } result = json.toString(); } catch (Exception e) { logger.error("[UserLiteJSONScreen]", e); } return result; } }