1   /**
2    * Copyright (c) 2000-2009 Liferay, Inc. All rights reserved.
3    *
4    * The contents of this file are subject to the terms of the Liferay Enterprise
5    * Subscription License ("License"). You may not use this file except in
6    * compliance with the License. You can obtain a copy of the License by
7    * contacting Liferay, Inc. See the License for the specific language governing
8    * permissions and limitations under the License, including but not limited to
9    * distribution rights of the Software.
10   *
11   * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
12   * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
13   * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
14   * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
15   * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
16   * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
17   * SOFTWARE.
18   */
19  
20  package com.liferay.portal.service.http;
21  
22  import com.liferay.portal.kernel.json.JSONArray;
23  import com.liferay.portal.kernel.json.JSONObject;
24  import com.liferay.portal.service.PhoneServiceUtil;
25  
26  /**
27   * <a href="PhoneServiceJSON.java.html"><b><i>View Source</i></b></a>
28   *
29   * <p>
30   * ServiceBuilder generated this class. Modifications in this class will be
31   * overwritten the next time is generated.
32   * </p>
33   *
34   * <p>
35   * This class provides a JSON utility for the
36   * <code>com.liferay.portal.service.PhoneServiceUtil</code>
37   * service utility. The static methods of this class calls the same methods of
38   * the service utility. However, the signatures are different because it is
39   * difficult for JSON to support certain types.
40   * </p>
41   *
42   * <p>
43   * ServiceBuilder follows certain rules in translating the methods. For example,
44   * if the method in the service utility returns a <code>java.util.List</code>,
45   * that is translated to a
46   * <code>com.liferay.portal.kernel.json.JSONArray</code>. If the method in the
47   * service utility returns a <code>com.liferay.portal.model.Phone</code>,
48   * that is translated to a
49   * <code>com.liferay.portal.kernel.json.JSONObject</code>. Methods that JSON
50   * cannot safely use are skipped. The logic for the translation is encapsulated
51   * in <code>com.liferay.portal.service.http.PhoneJSONSerializer</code>.
52   * </p>
53   *
54   * <p>
55   * This allows you to call the the backend services directly from JavaScript.
56   * See <code>portal-web/docroot/html/portlet/tags_admin/unpacked.js</code> for a
57   * reference of how that portlet uses the generated JavaScript in
58   * <code>portal-web/docroot/html/js/service.js</code> to call the backend
59   * services directly from JavaScript.
60   * </p>
61   *
62   * <p>
63   * The JSON utility is only generated for remote services.
64   * </p>
65   *
66   * @author Brian Wing Shun Chan
67   *
68   * @see com.liferay.portal.service.PhoneServiceUtil
69   * @see com.liferay.portal.service.http.PhoneJSONSerializer
70   *
71   */
72  public class PhoneServiceJSON {
73      public static JSONObject addPhone(java.lang.String className, long classPK,
74          java.lang.String number, java.lang.String extension, int typeId,
75          boolean primary)
76          throws java.rmi.RemoteException, com.liferay.portal.PortalException,
77              com.liferay.portal.SystemException {
78          com.liferay.portal.model.Phone returnValue = PhoneServiceUtil.addPhone(className,
79                  classPK, number, extension, typeId, primary);
80  
81          return PhoneJSONSerializer.toJSONObject(returnValue);
82      }
83  
84      public static void deletePhone(long phoneId)
85          throws java.rmi.RemoteException, com.liferay.portal.PortalException,
86              com.liferay.portal.SystemException {
87          PhoneServiceUtil.deletePhone(phoneId);
88      }
89  
90      public static JSONObject getPhone(long phoneId)
91          throws java.rmi.RemoteException, com.liferay.portal.PortalException,
92              com.liferay.portal.SystemException {
93          com.liferay.portal.model.Phone returnValue = PhoneServiceUtil.getPhone(phoneId);
94  
95          return PhoneJSONSerializer.toJSONObject(returnValue);
96      }
97  
98      public static JSONArray getPhones(java.lang.String className, long classPK)
99          throws java.rmi.RemoteException, com.liferay.portal.PortalException,
100             com.liferay.portal.SystemException {
101         java.util.List<com.liferay.portal.model.Phone> returnValue = PhoneServiceUtil.getPhones(className,
102                 classPK);
103 
104         return PhoneJSONSerializer.toJSONArray(returnValue);
105     }
106 
107     public static JSONObject updatePhone(long phoneId, java.lang.String number,
108         java.lang.String extension, int typeId, boolean primary)
109         throws java.rmi.RemoteException, com.liferay.portal.PortalException,
110             com.liferay.portal.SystemException {
111         com.liferay.portal.model.Phone returnValue = PhoneServiceUtil.updatePhone(phoneId,
112                 number, extension, typeId, primary);
113 
114         return PhoneJSONSerializer.toJSONObject(returnValue);
115     }
116 }