Mercurial > hg > Members > nobuyasu > jungle-network
changeset 171:df063cf6f3b5
add Delete Node Method
author | tatsuki |
---|---|
date | Wed, 30 Jul 2014 10:57:19 +0900 |
parents | 2403b9a4416f |
children | 00c3cca1903c |
files | src/main/java/app/bbs/NetworkBulletinBoard.java src/main/java/app/bbs/NetworkJungleBulletinBoard.java src/main/java/app/bbs/thinks/CreateNode.java src/main/java/app/bbs/thinks/ShowMatrix.java src/main/java/app/bbs/thinks/deleteNodeServlet.java |
diffstat | 5 files changed, 54 insertions(+), 23 deletions(-) [+] |
line wrap: on
line diff
--- a/src/main/java/app/bbs/NetworkBulletinBoard.java Wed Jul 30 10:20:01 2014 +0900 +++ b/src/main/java/app/bbs/NetworkBulletinBoard.java Wed Jul 30 10:57:19 2014 +0900 @@ -16,4 +16,5 @@ public getAttributeImp getAttribute(String _bname, String nodeNum); public void editAttribute(String boardName, String path, String id, String message); public void deleteAttribute(String _board, String _path , String id); + public void deleteNode(String _board, String _path, String id); }
--- a/src/main/java/app/bbs/NetworkJungleBulletinBoard.java Wed Jul 30 10:20:01 2014 +0900 +++ b/src/main/java/app/bbs/NetworkJungleBulletinBoard.java Wed Jul 30 10:57:19 2014 +0900 @@ -409,7 +409,37 @@ either = editor.success(); } while (either.isA()); } + + + public void deleteNode(String _board, String _path, String _id) { + requestCounter.incrementAndGet(); + int id = Integer.parseInt(_id); + final long timestamp = System.currentTimeMillis(); + final ByteBuffer tBuffer = ByteBuffer.allocate(16); + tBuffer.putLong(timestamp); + JungleTree tree = jungle.getTreeByName(_board); + Either<Error, JungleTreeEditor> either = null; + DefaultNodePath path = new DefaultNodePath(); + do { + try { + for (int count = 0; _path.substring(count, count + 1) != null; count++) { + if (!_path.substring(count, count + 1).equals("/")) + path = path.add(Integer.parseInt(_path.substring(count, count + 1))); + } + } catch (Exception _e) { + } + + JungleTreeEditor editor = tree.getTreeEditor(); + either = editor.deleteChildAt(path, id); + if (either.isA()) { + throw new IllegalStateException(); + } + editor = either.b(); + either = editor.success(); + } while (either.isA()); + + } public void deleteAttribute(String _board, String _path ,final String id) { requestCounter.incrementAndGet(); final long timestamp = System.currentTimeMillis(); @@ -597,4 +627,5 @@ } + }
--- a/src/main/java/app/bbs/thinks/CreateNode.java Wed Jul 30 10:20:01 2014 +0900 +++ b/src/main/java/app/bbs/thinks/CreateNode.java Wed Jul 30 10:57:19 2014 +0900 @@ -14,7 +14,7 @@ private static final String PARAM_BOARD_AUTHOR = "author"; private static final String PARAM_BOARD_INITMESSAGE = "msg"; private static final String PARAM_BOARD_EDITKEY = "key"; - + private static final String PARAM_BOARD_UUID = "uuid"; private static final long serialVersionUID = 1L; public CreateNode(NetworkBulletinBoard _bbs) { @@ -26,7 +26,7 @@ String author = _req.getParameter(PARAM_BOARD_AUTHOR); String msg = _req.getParameter(PARAM_BOARD_INITMESSAGE); String key = _req.getParameter(PARAM_BOARD_EDITKEY); - String nodeNum = _req.getParameter("uuid"); + String nodeNum = _req.getParameter(PARAM_BOARD_UUID); try { bbs.createFolder(boardName, author, msg, key, nodeNum);
--- a/src/main/java/app/bbs/thinks/ShowMatrix.java Wed Jul 30 10:20:01 2014 +0900 +++ b/src/main/java/app/bbs/thinks/ShowMatrix.java Wed Jul 30 10:57:19 2014 +0900 @@ -13,21 +13,21 @@ public class ShowMatrix extends HttpServlet { /** - * - */ + * edit Node Path is rename editNodePath + **/ private static final long serialVersionUID = 1L; private final NetworkBulletinBoard bbs; private final String createBoardMessagePath; - private final String editMessagePath; + private final String editNodePath; private final String showMatrixPath; private final String createAttributePath; private final String editAttributePath; private final String deleteAttributePath; private final String deleteNodePath; private static final String PARAM_BOARD_NAME = "bname"; - + private static final String PARAM_BOARD_UUID = "uuid"; public ShowMatrix(NetworkBulletinBoard _bbs, - String _createBoardMessagePath, String _editMessagePath, + String _createBoardMessagePath, String _editNodePath, String _showMatrixPath, String _createAttributePath, String _editAttributePath, String _deleteAttributePath, String _deleteNodePath, ThreadPool thp) { bbs = _bbs; deleteAttributePath = _deleteAttributePath; @@ -36,12 +36,12 @@ editAttributePath = _editAttributePath; showMatrixPath = _showMatrixPath; createBoardMessagePath = _createBoardMessagePath; - editMessagePath = _editMessagePath; + editNodePath = _editNodePath; } public void doGet(HttpServletRequest _req, HttpServletResponse _res) { final String bname = _req.getParameter(PARAM_BOARD_NAME); - String nodeNum = _req.getParameter("uuid"); + String nodeNum = _req.getParameter(PARAM_BOARD_UUID); String nodeName = _req.getParameter("nodeName"); try { printBoard(bname, nodeNum, nodeName, _res.getWriter()); @@ -80,7 +80,9 @@ for (BoardMessage msg : bbs.getFolder(_bname, nodeNum)) { _pw.write("<small><a href=" + showMatrixPath + "?bname=" + _bname + "&uuid=" + nodeNum + "/" + msg.getUUID() + "&nodeName=" + msg.getMessage() + ">" + msg.getMessage() + "</a></small>"); _pw.write(" "); - _pw.write("<small><a href='" + editMessagePath + "?bname=" + _bname + "&uuid=" + nodeNum + "/"+ msg.getUUID() + "'>edit</a><br><br></small>"); + _pw.write("<small><a href='" + editNodePath + "?bname=" + _bname + "&uuid=" + nodeNum + "/"+ msg.getUUID() + "'>edit</a></small>"); + _pw.write(" "); + _pw.write("<small><a href='" + deleteNodePath + "?bname=" + _bname + "&path=" + nodeNum + "&id=" + msg.getUUID() + "'>delete</a><br><br></small>"); }
--- a/src/main/java/app/bbs/thinks/deleteNodeServlet.java Wed Jul 30 10:20:01 2014 +0900 +++ b/src/main/java/app/bbs/thinks/deleteNodeServlet.java Wed Jul 30 10:57:19 2014 +0900 @@ -13,9 +13,8 @@ { private final NetworkBulletinBoard bbs; private static final String PARAM_BOARD_NAME = "bname"; - private static final String PARAM_BOARD_MSGID = "uuid"; - private static final String PARAM_BOARD_MESSAGE= "msg"; - private static final String PARAM_BOARD_EDITKEY = "key"; + private static final String PARAM_BOARD_PATH = "path"; + private static final String PARAM_NODE_ID = "id"; private static final long serialVersionUID = 1L; @@ -27,17 +26,16 @@ public void doGet(HttpServletRequest _req,HttpServletResponse _res) { String bname = _req.getParameter(PARAM_BOARD_NAME); - String path = _req.getParameter("path"); - String id = _req.getParameter("count"); - + String path = _req.getParameter(PARAM_BOARD_PATH ); + String id = _req.getParameter(PARAM_NODE_ID); try{ PrintWriter pw = _res.getWriter(); pw.write("<html><body><h1>本当に削除しますか?message</h1>"); pw.write("<form method='POST'\n"); - pw.write("<p><input type='hidden' name='path' value='"+path+"'/>" + - "<input type='hidden' name='id' value='"+id+"'/>" + - "<input type='hidden' name='bname' value='"+bname+"'</p>\n"); + pw.write("<p><input type='hidden' name='path' value='" + path + "'/>" + + "<input type='hidden' name='id' value='" + id +"'/>" + + "<input type='hidden' name='bname' value='" + bname + "'</p>\n"); pw.write("<p><input type='submit' value='submit'/></p>\n"); pw.write("</body></html>"); pw.flush(); @@ -49,11 +47,10 @@ public void doPost(HttpServletRequest _req,HttpServletResponse _res) { String boardName = _req.getParameter(PARAM_BOARD_NAME); - String path = _req.getParameter("path"); - String id = _req.getParameter("id"); - + String path = _req.getParameter(PARAM_BOARD_PATH); + String id = _req.getParameter(PARAM_NODE_ID); try{ - bbs.deleteAttribute(boardName, path,id); + bbs.deleteNode(boardName, path, id); PrintWriter pw = _res.getWriter(); pw.write("successfully written"); pw.flush();