/*Copyright ©2016 TommyLemon(https://github.com/TommyLemon/APIJSON) Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.*/ package apijson.demo; import java.util.ArrayList; import java.util.Arrays; import java.util.Collection; import java.util.List; import jakarta.servlet.http.HttpSession; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import apijson.JSONResponse; import apijson.NotNull; import apijson.RequestMethod; import apijson.StringUtil; import apijson.framework.APIJSONFunctionParser; import apijson.orm.AbstractVerifier; import apijson.orm.JSONRequest; import apijson.orm.Visitor; /**可远程调用的函数类,用于自定义业务逻辑处理 * 具体见 https://github.com/Tencent/APIJSON/issues/101 * @author Lemon */ public class DemoFunctionParser extends APIJSONFunctionParser { public static final String TAG = "DemoFunctionParser"; public DemoFunctionParser() { this(null, null, 0, null, null); } public DemoFunctionParser(RequestMethod method, String tag, int version, JSONObject request, HttpSession session) { super(method, tag, version, request, session); } public Visitor getCurrentUser(@NotNull JSONObject current) { return DemoVerifier.getVisitor(getSession()); } public Long getCurrentUserId(@NotNull JSONObject current) { return DemoVerifier.getVisitorId(getSession()); } public List getCurrentUserIdAsList(@NotNull JSONObject current) { List list = new ArrayList<>(1); list.add(DemoVerifier.getVisitorId(getSession())); return list; } public List getCurrentContactIdList(@NotNull JSONObject current) { Visitor user = getCurrentUser(current); return user == null ? null : user.getContactIdList(); } /** * @param current * @param idList * @return * @throws Exception */ public void verifyIdList(@NotNull JSONObject current, @NotNull String idList) throws Exception { Object obj = current.get(idList); if (obj == null) { return; } if (obj instanceof Collection == false) { throw new IllegalArgumentException(idList + " 不符合 Array 数组类型! 结构必须是 [] !"); } Collection collection = (Collection) obj; if (collection != null) { int i = -1; for (Object item : collection) { i ++; if (item instanceof Long == false && item instanceof Integer == false) { throw new IllegalArgumentException(idList + "/" + i + ": " + item + " 不符合 Long 数字类型!"); } } } } /** * @param current * @param urlList * @return * @throws Exception */ public void verifyURLList(@NotNull JSONObject current, @NotNull String urlList) throws Exception { Object obj = current.get(urlList); if (obj == null) { return; } if (obj instanceof Collection == false) { throw new IllegalArgumentException(urlList + " 不符合 Array 数组类型! 结构必须是 [] !"); } Collection collection = (Collection) obj; if (collection != null) { int i = -1; for (Object item : collection) { i ++; if (item instanceof String == false || StringUtil.isUrl((String) item) == false) { throw new IllegalArgumentException(urlList + "/" + i + ": " + item + " 不符合 URL 字符串格式!"); } } } } /** * @param current * @param momentId * @return * @throws Exception */ public int deleteCommentOfMoment(@NotNull JSONObject current, @NotNull String momentId) throws Exception { long mid = current.getLongValue(momentId); if (mid <= 0 || current.getIntValue(JSONResponse.KEY_COUNT) <= 0) { return 0; } JSONRequest request = new JSONRequest(); //Comment<<<<<<<<<<<<<<<<<<<<<<<<<<<<< JSONRequest comment = new JSONRequest(); comment.put("momentId", mid); request.put("Comment", comment); //Comment>>>>>>>>>>>>>>>>>>>>>>>>>>>>> JSONObject rp = new DemoParser(RequestMethod.DELETE).setNeedVerify(false).parseResponse(request); JSONObject c = rp.getJSONObject("Comment"); return c == null ? 0 : c.getIntValue(JSONResponse.KEY_COUNT); } /**删除评论的子评论 * @param current * @param toId * @return */ public int deleteChildComment(@NotNull JSONObject current, @NotNull String toId) throws Exception { long tid = current.getLongValue(toId); if (tid <= 0 || current.getIntValue(JSONResponse.KEY_COUNT) <= 0) { return 0; } //递归获取到全部子评论id JSONRequest request = new JSONRequest(); //Comment<<<<<<<<<<<<<<<<<<<<<<<<<<<<< JSONRequest comment = new JSONRequest(); comment.put("id{}", getChildCommentIdList(tid)); request.put("Comment", comment); //Comment>>>>>>>>>>>>>>>>>>>>>>>>>>>>> JSONObject rp = new DemoParser(RequestMethod.DELETE).setNeedVerify(false).parseResponse(request); JSONObject c = rp.getJSONObject("Comment"); return c == null ? 0 : c.getIntValue(JSONResponse.KEY_COUNT); } private JSONArray getChildCommentIdList(long tid) { JSONArray arr = new JSONArray(); JSONRequest request = new JSONRequest(); //Comment-id[]<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< JSONRequest idItem = new JSONRequest(); //Comment<<<<<<<<<<<<<<<<<<<<<<<<<<<<< JSONRequest comment = new JSONRequest(); comment.put("toId", tid); comment.setColumn("id"); idItem.put("Comment", comment); //Comment>>>>>>>>>>>>>>>>>>>>>>>>>>>>> request.putAll(idItem.toArray(0, 0, "Comment-id")); //Comment-id[]>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> JSONObject rp = new DemoParser().setNeedVerify(false).parseResponse(request); JSONArray a = rp.getJSONArray("Comment-id[]"); if (a != null) { arr.addAll(a); JSONArray a2; for (int i = 0; i < a.size(); i++) { a2 = getChildCommentIdList(a.getLongValue(i)); if (a2 != null) { arr.addAll(a2); } } } return arr; } /**TODO 仅用来测试 "key-()":"getIdList()" 和 "key()":"getIdList()" * @param current * @return JSONArray 只能用JSONArray,用long[]会在SQLConfig解析崩溃 * @throws Exception */ public JSONArray getIdList(@NotNull JSONObject current) { return new JSONArray(new ArrayList(Arrays.asList(12, 15, 301, 82001, 82002, 38710))); } /**TODO 仅用来测试 "key-()":"verifyAccess()" * @param current * @return * @throws Exception */ public Object verifyAccess(@NotNull JSONObject current) throws Exception { long userId = current.getLongValue(JSONRequest.KEY_USER_ID); String role = current.getString(JSONRequest.KEY_ROLE); if (AbstractVerifier.OWNER.equals(role) && userId != (Long) DemoVerifier.getVisitorId(getSession())) { throw new IllegalAccessException("登录用户与角色OWNER不匹配!"); } return null; } }