001: /**
002: * Copyright (c) 2000-2008 Liferay, Inc. All rights reserved.
003: *
004: * Permission is hereby granted, free of charge, to any person obtaining a copy
005: * of this software and associated documentation files (the "Software"), to deal
006: * in the Software without restriction, including without limitation the rights
007: * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
008: * copies of the Software, and to permit persons to whom the Software is
009: * furnished to do so, subject to the following conditions:
010: *
011: * The above copyright notice and this permission notice shall be included in
012: * all copies or substantial portions of the Software.
013: *
014: * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
015: * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
016: * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
017: * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
018: * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
019: * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
020: * SOFTWARE.
021: */package com.liferay.portal.service.http;
022:
023: import com.liferay.portal.service.AddressServiceUtil;
024:
025: import org.json.JSONArray;
026: import org.json.JSONObject;
027:
028: /**
029: * <a href="AddressServiceJSON.java.html"><b><i>View Source</i></b></a>
030: *
031: * <p>
032: * ServiceBuilder generated this class. Modifications in this class will be
033: * overwritten the next time is generated.
034: * </p>
035: *
036: * <p>
037: * This class provides a JSON utility for the
038: * <code>com.liferay.portal.service.AddressServiceUtil</code>
039: * service utility. The static methods of this class calls the same methods of
040: * the service utility. However, the signatures are different because it is
041: * difficult for JSON to support certain types.
042: * </p>
043: *
044: * <p>
045: * ServiceBuilder follows certain rules in translating the methods. For example,
046: * if the method in the service utility returns a <code>java.util.List</code>,
047: * that is translated to a <code>org.json.JSONArray</code>. If the method in the
048: * service utility returns a <code>com.liferay.portal.model.Address</code>,
049: * that is translated to a <code>org.json.JSONObject</code>. Methods that JSON
050: * cannot safely use are skipped. The logic for the translation is encapsulated
051: * in <code>com.liferay.portal.service.http.AddressJSONSerializer</code>.
052: * </p>
053: *
054: * <p>
055: * This allows you to call the the backend services directly from JavaScript.
056: * See <code>portal-web/docroot/html/portlet/tags_admin/unpacked.js</code> for a
057: * reference of how that portlet uses the generated JavaScript in
058: * <code>portal-web/docroot/html/js/service.js</code> to call the backend
059: * services directly from JavaScript.
060: * </p>
061: *
062: * <p>
063: * The JSON utility is only generated for remote services.
064: * </p>
065: *
066: * @author Brian Wing Shun Chan
067: *
068: * @see com.liferay.portal.service.AddressServiceUtil
069: * @see com.liferay.portal.service.http.AddressJSONSerializer
070: *
071: */
072: public class AddressServiceJSON {
073: public static JSONObject addAddress(java.lang.String className,
074: long classPK, java.lang.String street1,
075: java.lang.String street2, java.lang.String street3,
076: java.lang.String city, java.lang.String zip, long regionId,
077: long countryId, int typeId, boolean mailing, boolean primary)
078: throws java.rmi.RemoteException,
079: com.liferay.portal.SystemException,
080: com.liferay.portal.PortalException {
081: com.liferay.portal.model.Address returnValue = AddressServiceUtil
082: .addAddress(className, classPK, street1, street2,
083: street3, city, zip, regionId, countryId,
084: typeId, mailing, primary);
085:
086: return AddressJSONSerializer.toJSONObject(returnValue);
087: }
088:
089: public static void deleteAddress(long addressId)
090: throws java.rmi.RemoteException,
091: com.liferay.portal.SystemException,
092: com.liferay.portal.PortalException {
093: AddressServiceUtil.deleteAddress(addressId);
094: }
095:
096: public static JSONObject getAddress(long addressId)
097: throws java.rmi.RemoteException,
098: com.liferay.portal.SystemException,
099: com.liferay.portal.PortalException {
100: com.liferay.portal.model.Address returnValue = AddressServiceUtil
101: .getAddress(addressId);
102:
103: return AddressJSONSerializer.toJSONObject(returnValue);
104: }
105:
106: public static JSONArray getAddresses(java.lang.String className,
107: long classPK) throws java.rmi.RemoteException,
108: com.liferay.portal.SystemException,
109: com.liferay.portal.PortalException {
110: java.util.List returnValue = AddressServiceUtil.getAddresses(
111: className, classPK);
112:
113: return AddressJSONSerializer.toJSONArray(returnValue);
114: }
115:
116: public static JSONObject updateAddress(long addressId,
117: java.lang.String street1, java.lang.String street2,
118: java.lang.String street3, java.lang.String city,
119: java.lang.String zip, long regionId, long countryId,
120: int typeId, boolean mailing, boolean primary)
121: throws java.rmi.RemoteException,
122: com.liferay.portal.SystemException,
123: com.liferay.portal.PortalException {
124: com.liferay.portal.model.Address returnValue = AddressServiceUtil
125: .updateAddress(addressId, street1, street2, street3,
126: city, zip, regionId, countryId, typeId,
127: mailing, primary);
128:
129: return AddressJSONSerializer.toJSONObject(returnValue);
130: }
131: }
|