Clover Coverage Report - Pebble 2.5-SNAPSHOT
Coverage timestamp: Sat Jun 12 2010 09:39:29 EST
../../../../../img/srcFileCovDistChart0.png 48% of files have more coverage
37   130   7   18,5
8   67   0,19   2
2     3,5  
1    
This report was generated with an evaluation server license. Purchase Clover or configure your license.
 
  SaveBlogSecurityAction       Line # 52 37 0% 7 47 0% 0.0
 
No Tests
 
1    /*
2    * Copyright (c) 2003-2006, Simon Brown
3    * All rights reserved.
4    *
5    * Redistribution and use in source and binary forms, with or without
6    * modification, are permitted provided that the following conditions are met:
7    *
8    * - Redistributions of source code must retain the above copyright
9    * notice, this list of conditions and the following disclaimer.
10    *
11    * - Redistributions in binary form must reproduce the above copyright
12    * notice, this list of conditions and the following disclaimer in
13    * the documentation and/or other materials provided with the
14    * distribution.
15    *
16    * - Neither the name of Pebble nor the names of its contributors may
17    * be used to endorse or promote products derived from this software
18    * without specific prior written permission.
19    *
20    * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21    * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22    * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23    * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
24    * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25    * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26    * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27    * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28    * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29    * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30    * POSSIBILITY OF SUCH DAMAGE.
31    */
32    package net.sourceforge.pebble.web.action;
33   
34    import net.sourceforge.pebble.Constants;
35    import net.sourceforge.pebble.domain.Blog;
36    import net.sourceforge.pebble.domain.BlogServiceException;
37    import net.sourceforge.pebble.web.controller.RequireSecurityToken;
38    import net.sourceforge.pebble.web.view.RedirectView;
39    import net.sourceforge.pebble.web.view.View;
40   
41    import javax.servlet.ServletException;
42    import javax.servlet.http.HttpServletRequest;
43    import javax.servlet.http.HttpServletResponse;
44    import java.util.Enumeration;
45   
46    /**
47    * Saves the security properties associated with the current Blog.
48    *
49    * @author Simon Brown
50    */
51    @RequireSecurityToken
 
52    public class SaveBlogSecurityAction extends SecureAction {
53   
54    /**
55    * Peforms the processing associated with this action.
56    *
57    * @param request the HttpServletRequest instance
58    * @param response the HttpServletResponse instance
59    * @return the name of the next view
60    */
 
61  0 toggle public View process(HttpServletRequest request, HttpServletResponse response) throws ServletException {
62  0 Blog blog = (Blog)getModel().get(Constants.BLOG_KEY);
63   
64  0 String privateBlog = request.getParameter("private");
65  0 blog.setProperty(Blog.PRIVATE_KEY, privateBlog);
66   
67  0 String values[] = request.getParameterValues("blogOwners");
68  0 StringBuffer blogOwners = new StringBuffer();
69  0 if (values != null) {
70  0 for (String value : values) {
71  0 blogOwners.append(value);
72  0 blogOwners.append(",");
73    }
74    }
75  0 blog.setProperty(Blog.BLOG_OWNERS_KEY, blogOwners.toString());
76   
77  0 values = request.getParameterValues("blogPublishers");
78  0 StringBuffer blogPublishers = new StringBuffer();
79  0 if (values != null) {
80  0 for (String value : values) {
81  0 blogPublishers.append(value);
82  0 blogPublishers.append(",");
83    }
84    }
85  0 blog.setProperty(Blog.BLOG_PUBLISHERS_KEY, blogPublishers.toString());
86   
87  0 values = request.getParameterValues("blogContributors");
88  0 StringBuffer blogContributors = new StringBuffer();
89  0 if (values != null) {
90  0 for (String value : values) {
91  0 blogContributors.append(value);
92  0 blogContributors.append(",");
93    }
94    }
95  0 blog.setProperty(Blog.BLOG_CONTRIBUTORS_KEY, blogContributors.toString());
96   
97  0 values = request.getParameterValues("blogReaders");
98  0 StringBuffer blogReaders = new StringBuffer();
99  0 if (values != null) {
100  0 for (String value : values) {
101  0 blogReaders.append(value);
102  0 blogReaders.append(",");
103    }
104    }
105  0 blog.setProperty(Blog.BLOG_READERS_KEY, blogReaders.toString());
106   
107  0 try {
108  0 blog.storeProperties();
109  0 blog.info("Blog security settings saved.");
110    } catch (BlogServiceException e) {
111  0 throw new ServletException(e);
112    }
113   
114  0 return new RedirectView(blog.getUrl() + "viewBlogSecurity.secureaction");
115    }
116   
117    /**
118    * Gets a list of all roles that are allowed to access this action.
119    *
120    * @return an array of Strings representing role names
121    * @param request the originating request
122    */
 
123  0 toggle public String[] getRoles(HttpServletRequest request) {
124  0 return new String[]{
125    Constants.BLOG_ADMIN_ROLE,
126    Constants.BLOG_OWNER_ROLE
127    };
128    }
129   
130    }