001: /*
002: * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
003: *
004: * Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.
005: *
006: * The contents of this file are subject to the terms of either the GNU General
007: * Public License Version 2 only ("GPL") or the Common Development and Distribution
008: * License("CDDL") (collectively, the "License"). You may not use this file except in
009: * compliance with the License. You can obtain a copy of the License at
010: * http://www.netbeans.org/cddl-gplv2.html or nbbuild/licenses/CDDL-GPL-2-CP. See the
011: * License for the specific language governing permissions and limitations under the
012: * License. When distributing the software, include this License Header Notice in
013: * each file and include the License file at nbbuild/licenses/CDDL-GPL-2-CP. Sun
014: * designates this particular file as subject to the "Classpath" exception as
015: * provided by Sun in the GPL Version 2 section of the License file that
016: * accompanied this code. If applicable, add the following below the License Header,
017: * with the fields enclosed by brackets [] replaced by your own identifying
018: * information: "Portions Copyrighted [year] [name of copyright owner]"
019: *
020: * Contributor(s):
021: *
022: * The Original Software is NetBeans. The Initial Developer of the Original Software
023: * is Sun Microsystems, Inc. Portions Copyright 1997-2007 Sun Microsystems, Inc. All
024: * Rights Reserved.
025: *
026: * If you wish your version of this file to be governed by only the CDDL or only the
027: * GPL Version 2, indicate your decision by adding "[Contributor] elects to include
028: * this software in this distribution under the [CDDL or GPL Version 2] license." If
029: * you do not indicate a single choice of license, a recipient has the option to
030: * distribute your version of this file under either the CDDL, the GPL Version 2 or
031: * to extend the choice of license to its licensees as provided above. However, if
032: * you add GPL Version 2 code and therefore, elected the GPL Version 2 license, then
033: * the option applies only if the new code is made subject to such option by the
034: * copyright holder.
035: */
036:
037: package org.netbeans.installer.infra.build.ant;
038:
039: import java.io.File;
040: import java.io.IOException;
041: import java.util.HashMap;
042: import java.util.Map;
043: import org.apache.tools.ant.BuildException;
044: import org.apache.tools.ant.Task;
045: import org.netbeans.installer.infra.build.ant.utils.Utils;
046:
047: /**
048: * This class is an ant task that is capable or releasing an NBI package archive.
049: *
050: * @author Kirill Sorokin
051: */
052: public class ReleasePackage extends Task {
053: /////////////////////////////////////////////////////////////////////////////////
054: // Instance
055: /**
056: * URL of the registries server to which the package should be released.
057: */
058: private String url;
059:
060: /**
061: * Name of the registry into which the package should be imported.
062: */
063: private String registry;
064:
065: /**
066: * Uid of the parent component for the package.
067: */
068: private String uid;
069:
070: /**
071: * Version of the parent component for the package.
072: */
073: private String version;
074:
075: /**
076: * Platforms of the parent component for the package.
077: */
078: private String platforms;
079:
080: /**
081: * The package archive.
082: */
083: private File archive;
084:
085: // setters //////////////////////////////////////////////////////////////////////
086: /**
087: * Setter for the 'url' property.
088: *
089: * @param url The new value of the 'url' property.
090: */
091: public void setUrl(String url) {
092: this .url = url;
093: }
094:
095: /**
096: * Setter for the 'registry' property.
097: *
098: * @param registry The new value of the 'registry' property.
099: */
100: public void setRegistry(String registry) {
101: this .registry = registry;
102: }
103:
104: /**
105: * Setter for the 'uid' property.
106: *
107: * @param uid The new value of the 'uid' property.
108: */
109: public void setUid(String uid) {
110: this .uid = uid;
111: }
112:
113: /**
114: * Setter for the 'version' property.
115: *
116: * @param version The new value of the 'version' property.
117: */
118: public void setVersion(String version) {
119: this .version = version;
120: }
121:
122: /**
123: * Setter for the 'platforms' property.
124: *
125: * @param platforms The new value of the 'platforms' property.
126: */
127: public void setPlatforms(String platforms) {
128: this .platforms = platforms;
129: }
130:
131: /**
132: * Setter for the 'archive' property.
133: *
134: * @param path The new value of the 'archive' property.
135: */
136: public void setArchive(String path) {
137: archive = new File(path);
138: if (!archive.equals(archive.getAbsoluteFile())) {
139: archive = new File(getProject().getBaseDir(), path);
140: }
141: }
142:
143: // execution ////////////////////////////////////////////////////////////////////
144: /**
145: * Executes the task. This method sends an HTTP POST request to the server,
146: * uploading the package archive.
147: *
148: * @throws org.apache.tools.ant.BuildException if an I/O error occurs.
149: */
150: public void execute() throws BuildException {
151: try {
152: final Map<String, Object> args = new HashMap<String, Object>();
153:
154: args.put("registry", registry); // NOI18N
155: args.put("uid", uid); // NOI18N
156: args.put("version", version); // NOI18N
157: args.put("platforms", platforms); // NOI18N
158: args.put("archive", archive); // NOI18N
159:
160: String response = Utils.post(url + "/add-package", args); // NOI18N
161:
162: log(response);
163: if (!response.startsWith("200")) { // NOI18N
164: throw new BuildException(
165: "Failed to release the package."); // NOI18N
166: }
167: } catch (IOException e) {
168: throw new BuildException(e);
169: }
170: }
171: }
|