report package installation errors, simplify code
[teamcity/dotNetPackagesSupport.git] / nuget-server / src / jetbrains / buildServer / nuget / server / toolRegistry / tab / InstallToolController.java
1 /*\r
2  * Copyright 2000-2011 JetBrains s.r.o.\r
3  *\r
4  * Licensed under the Apache License, Version 2.0 (the "License");\r
5  * you may not use this file except in compliance with the License.\r
6  * You may obtain a copy of the License at\r
7  *\r
8  * http://www.apache.org/licenses/LICENSE-2.0\r
9  *\r
10  * Unless required by applicable law or agreed to in writing, software\r
11  * distributed under the License is distributed on an "AS IS" BASIS,\r
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
13  * See the License for the specific language governing permissions and\r
14  * limitations under the License.\r
15  */\r
16 \r
17 package jetbrains.buildServer.nuget.server.toolRegistry.tab;\r
18 \r
19 import com.intellij.openapi.diagnostic.Logger;\r
20 import jetbrains.buildServer.controllers.*;\r
21 import jetbrains.buildServer.nuget.server.toolRegistry.NuGetTool;\r
22 import jetbrains.buildServer.nuget.server.toolRegistry.NuGetToolManager;\r
23 import jetbrains.buildServer.nuget.server.toolRegistry.ToolException;\r
24 import jetbrains.buildServer.nuget.server.toolRegistry.ToolsPolicy;\r
25 import jetbrains.buildServer.serverSide.auth.AccessDeniedException;\r
26 import jetbrains.buildServer.serverSide.auth.AuthorityHolder;\r
27 import jetbrains.buildServer.util.StringUtil;\r
28 import jetbrains.buildServer.web.openapi.PluginDescriptor;\r
29 import jetbrains.buildServer.web.openapi.WebControllerManager;\r
30 import org.jdom.Element;\r
31 import org.jetbrains.annotations.NotNull;\r
32 import org.springframework.web.servlet.ModelAndView;\r
33 \r
34 import javax.servlet.http.HttpServletRequest;\r
35 import javax.servlet.http.HttpServletResponse;\r
36 import java.util.ArrayList;\r
37 import java.util.Collection;\r
38 import java.util.HashMap;\r
39 \r
40 /**\r
41  * Created by Eugene Petrenko (eugene.petrenko@gmail.com)\r
42  * Date: 11.08.11 12:12\r
43  */\r
44 public class InstallToolController extends BaseFormXmlController {\r
45   private static final Logger LOG = Logger.getInstance(InstallToolController.class.getName());\r
46 \r
47   private final String myPath;\r
48   private final NuGetToolManager myToolsManager;\r
49   private final PluginDescriptor myDescriptor;\r
50 \r
51   public InstallToolController(@NotNull final AuthorizationInterceptor auth,\r
52                                @NotNull final PermissionChecker checker,\r
53                                @NotNull final WebControllerManager web,\r
54                                @NotNull final NuGetToolManager toolsManager,\r
55                                @NotNull final PluginDescriptor descriptor) {\r
56     myToolsManager = toolsManager;\r
57     myDescriptor = descriptor;\r
58     myPath = descriptor.getPluginResourcesPath("tool/nuget-server-tab-install-tool.html");\r
59     auth.addPathBasedPermissionsChecker(myPath, new RequestPermissionsChecker() {\r
60       public void checkPermissions(@NotNull AuthorityHolder authorityHolder,\r
61                                    @NotNull HttpServletRequest request) throws AccessDeniedException {\r
62         checker.assertAccess(authorityHolder);\r
63       }\r
64     });\r
65     web.registerController(myPath, this);\r
66   }\r
67 \r
68   @NotNull\r
69   public String getPath() {\r
70     return myPath;\r
71   }\r
72 \r
73   @Override\r
74   protected ModelAndView doGet(HttpServletRequest request, HttpServletResponse response) {\r
75     final Collection<NuGetTool> availableTools = new ArrayList<NuGetTool>();\r
76 \r
77     final ToolsPolicy pol =\r
78             StringUtil.isEmptyOrSpaces(request.getParameter("fresh"))\r
79                     ? ToolsPolicy.ReturnCached\r
80                     : ToolsPolicy.FetchNew;\r
81 \r
82     try {\r
83       availableTools.addAll(myToolsManager.getAvailableTools(pol));\r
84     } catch (Exception e) {\r
85       ModelAndView mv = new ModelAndView(myDescriptor.getPluginResourcesPath("tool/installTool-error.jsp"));\r
86       mv.getModel().put("errorText", e.getMessage());\r
87       LOG.warn("Failed to fetch NuGet.Commandline package versions. " + e.getMessage(), e);\r
88       return mv;\r
89     }\r
90 \r
91     ModelAndView mv = new ModelAndView(myDescriptor.getPluginResourcesPath("tool/installTool-show.jsp"));\r
92     mv.getModelMap().put("available", availableTools);\r
93     mv.getModelMap().put("propertiesBean", new BasePropertiesBean(new HashMap<String, String>()));\r
94 \r
95     return mv;\r
96   }\r
97 \r
98   @Override\r
99   protected void doPost(HttpServletRequest request, HttpServletResponse response, Element xmlResponse) {\r
100     String toolId = request.getParameter("toolId");\r
101     if (StringUtil.isEmptyOrSpaces(toolId)) {\r
102       ActionErrors ae = new ActionErrors();\r
103       ae.addError("toolId", "Select NuGet.Commandline package version to install");\r
104       ae.serialize(xmlResponse);\r
105       return;\r
106     }\r
107 \r
108     final String whatToDo = request.getParameter("whatToDo");\r
109     try {\r
110       if ("install".equals(whatToDo)) {\r
111         myToolsManager.installTool(toolId);\r
112         return;\r
113       }\r
114 \r
115       if ("remove".equals(whatToDo)) {\r
116         myToolsManager.removeTool(toolId);\r
117       }\r
118     } catch (ToolException e) {\r
119       ActionErrors ae = new ActionErrors();\r
120       ae.addError("toolId", "Failed to install package: " + e.getMessage());\r
121       ae.serialize(xmlResponse);\r
122     }\r
123   }\r
124 }\r