ResourceServiceHttp.java |
1 /** 2 * Copyright (c) 2000-2009 Liferay, Inc. All rights reserved. 3 * 4 * Permission is hereby granted, free of charge, to any person obtaining a copy 5 * of this software and associated documentation files (the "Software"), to deal 6 * in the Software without restriction, including without limitation the rights 7 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 8 * copies of the Software, and to permit persons to whom the Software is 9 * furnished to do so, subject to the following conditions: 10 * 11 * The above copyright notice and this permission notice shall be included in 12 * all copies or substantial portions of the Software. 13 * 14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 17 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 18 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 19 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 20 * SOFTWARE. 21 */ 22 23 package com.liferay.portal.service.http; 24 25 import com.liferay.portal.kernel.log.Log; 26 import com.liferay.portal.kernel.log.LogFactoryUtil; 27 import com.liferay.portal.kernel.util.IntegerWrapper; 28 import com.liferay.portal.kernel.util.LongWrapper; 29 import com.liferay.portal.kernel.util.MethodWrapper; 30 import com.liferay.portal.kernel.util.NullWrapper; 31 import com.liferay.portal.security.auth.HttpPrincipal; 32 import com.liferay.portal.service.ResourceServiceUtil; 33 34 /** 35 * <a href="ResourceServiceHttp.java.html"><b><i>View Source</i></b></a> 36 * 37 * <p> 38 * ServiceBuilder generated this class. Modifications in this class will be 39 * overwritten the next time is generated. 40 * </p> 41 * 42 * <p> 43 * This class provides a HTTP utility for the 44 * <code>com.liferay.portal.service.ResourceServiceUtil</code> service 45 * utility. The static methods of this class calls the same methods of the 46 * service utility. However, the signatures are different because it requires an 47 * additional <code>com.liferay.portal.security.auth.HttpPrincipal</code> 48 * parameter. 49 * </p> 50 * 51 * <p> 52 * The benefits of using the HTTP utility is that it is fast and allows for 53 * tunneling without the cost of serializing to text. The drawback is that it 54 * only works with Java. 55 * </p> 56 * 57 * <p> 58 * Set the property <code>tunnel.servlet.hosts.allowed</code> in 59 * portal.properties to configure security. 60 * </p> 61 * 62 * <p> 63 * The HTTP utility is only generated for remote services. 64 * </p> 65 * 66 * @author Brian Wing Shun Chan 67 * 68 * @see com.liferay.portal.security.auth.HttpPrincipal 69 * @see com.liferay.portal.service.ResourceServiceUtil 70 * @see com.liferay.portal.service.http.ResourceServiceSoap 71 * 72 */ 73 public class ResourceServiceHttp { 74 public static com.liferay.portal.model.Resource getResource( 75 HttpPrincipal httpPrincipal, long companyId, java.lang.String name, 76 int scope, java.lang.String primKey) 77 throws com.liferay.portal.PortalException, 78 com.liferay.portal.SystemException { 79 try { 80 Object paramObj0 = new LongWrapper(companyId); 81 82 Object paramObj1 = name; 83 84 if (name == null) { 85 paramObj1 = new NullWrapper("java.lang.String"); 86 } 87 88 Object paramObj2 = new IntegerWrapper(scope); 89 90 Object paramObj3 = primKey; 91 92 if (primKey == null) { 93 paramObj3 = new NullWrapper("java.lang.String"); 94 } 95 96 MethodWrapper methodWrapper = new MethodWrapper(ResourceServiceUtil.class.getName(), 97 "getResource", 98 new Object[] { paramObj0, paramObj1, paramObj2, paramObj3 }); 99 100 Object returnObj = null; 101 102 try { 103 returnObj = TunnelUtil.invoke(httpPrincipal, methodWrapper); 104 } 105 catch (Exception e) { 106 if (e instanceof com.liferay.portal.PortalException) { 107 throw (com.liferay.portal.PortalException)e; 108 } 109 110 if (e instanceof com.liferay.portal.SystemException) { 111 throw (com.liferay.portal.SystemException)e; 112 } 113 114 throw new com.liferay.portal.SystemException(e); 115 } 116 117 return (com.liferay.portal.model.Resource)returnObj; 118 } 119 catch (com.liferay.portal.SystemException se) { 120 _log.error(se, se); 121 122 throw se; 123 } 124 } 125 126 private static Log _log = LogFactoryUtil.getLog(ResourceServiceHttp.class); 127 }