| /******************************************************************************* |
| * Copyright (c) 2008, 2009 IBM Corporation and others. |
| * All rights reserved. This program and the accompanying materials |
| * are made available under the terms of the Eclipse Public License v1.0 |
| * which accompanies this distribution, and is available at |
| * http://www.eclipse.org/legal/epl-v10.html |
| * |
| * Contributors: |
| * Red Hat Incorporated - initial API and implementation |
| * IBM Corporation - ongoing development |
| * Cloudsmith Inc - ongoing development |
| *******************************************************************************/ |
| package org.eclipse.equinox.internal.p2.touchpoint.eclipse.actions; |
| |
| import java.io.*; |
| import java.util.ArrayList; |
| import java.util.Map; |
| import org.eclipse.core.runtime.*; |
| import org.eclipse.equinox.internal.p2.touchpoint.eclipse.EclipseTouchpoint; |
| import org.eclipse.equinox.internal.p2.touchpoint.eclipse.Util; |
| import org.eclipse.equinox.internal.provisional.p2.engine.IProfile; |
| import org.eclipse.equinox.internal.provisional.p2.engine.ProvisioningAction; |
| import org.eclipse.equinox.internal.provisional.p2.metadata.IArtifactKey; |
| import org.eclipse.equinox.internal.provisional.p2.metadata.IInstallableUnit; |
| import org.eclipse.osgi.util.NLS; |
| |
| // This basically a copy of the chmod action in the native touchpoint only it provides @artifact support. |
| // We should just use the native touchpoint copy when we have a replacement for the use of @artifact in parameters |
| public class ChmodAction extends ProvisioningAction { |
| private static final String ACTION_CHMOD = "chmod"; //$NON-NLS-1$ |
| |
| public IStatus execute(Map parameters) { |
| String targetDir = (String) parameters.get(ActionConstants.PARM_TARGET_DIR); |
| if (targetDir == null) |
| return Util.createError(NLS.bind(Messages.parameter_not_set, ActionConstants.PARM_TARGET_DIR, ACTION_CHMOD)); |
| if (targetDir.equals(ActionConstants.PARM_ARTIFACT)) { |
| try { |
| targetDir = resolveArtifactParam(parameters); |
| } catch (CoreException e) { |
| return e.getStatus(); |
| } |
| |
| File dir = new File(targetDir); |
| if (!dir.isDirectory()) { |
| return Util.createError(NLS.bind(Messages.artifact_not_directory, dir)); |
| } |
| } |
| |
| String targetFile = (String) parameters.get(ActionConstants.PARM_TARGET_FILE); |
| if (targetFile == null) |
| return Util.createError(NLS.bind(Messages.parameter_not_set, ActionConstants.PARM_TARGET_FILE, ACTION_CHMOD)); |
| String permissions = (String) parameters.get(ActionConstants.PARM_PERMISSIONS); |
| if (permissions == null) |
| return Util.createError(NLS.bind(Messages.parameter_not_set, ActionConstants.PARM_PERMISSIONS, ACTION_CHMOD)); |
| String optionsString = (String) parameters.get(ActionConstants.PARM_OPTIONS); |
| |
| // Check that file exist |
| File probe = new File(targetDir + IPath.SEPARATOR + targetFile); |
| if (!probe.exists()) |
| return Util.createError(NLS.bind(Messages.action_0_failed_file_1_doesNotExist, ACTION_CHMOD, probe.toString())); |
| |
| String options[] = null; |
| if (optionsString != null) { |
| ArrayList collect = new ArrayList(); |
| String r = optionsString.trim(); |
| while (r.length() > 0) { |
| int spaceIdx = r.indexOf(' '); |
| if (spaceIdx < 0) { |
| collect.add(r); |
| r = ""; //$NON-NLS-1$ |
| } else { |
| collect.add(r.substring(0, spaceIdx)); |
| r = r.substring(spaceIdx + 1); |
| r = r.trim(); |
| } |
| } |
| if (collect.size() > 0) { |
| options = new String[collect.size()]; |
| collect.toArray(options); |
| } |
| } |
| |
| chmod(targetDir, targetFile, permissions, options); |
| return Status.OK_STATUS; |
| } |
| |
| public IStatus undo(Map parameters) { |
| //TODO: implement undo ?? |
| return Status.OK_STATUS; |
| } |
| |
| public void chmod(String targetDir, String targetFile, String perms, String[] options) { |
| Runtime r = Runtime.getRuntime(); |
| try { |
| // Note: 3 is from chmod, permissions, and target |
| String[] args = new String[3 + (options == null ? 0 : options.length)]; |
| int i = 0; |
| args[i++] = "chmod"; //$NON-NLS-1$ |
| if (options != null) { |
| for (int j = 0; j < options.length; j++) |
| args[i++] = options[j]; |
| } |
| args[i++] = perms; |
| args[i] = targetDir + IPath.SEPARATOR + targetFile; |
| Process process = r.exec(args); |
| readOffStream(process.getErrorStream()); |
| readOffStream(process.getInputStream()); |
| try { |
| process.waitFor(); |
| } catch (InterruptedException e) { |
| // mark thread interrupted and continue |
| Thread.currentThread().interrupt(); |
| } |
| } catch (IOException e) { |
| // ignore |
| } |
| } |
| |
| private void readOffStream(InputStream inputStream) { |
| BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream)); |
| try { |
| while (reader.readLine() != null) { |
| // do nothing |
| } |
| } catch (IOException e) { |
| // ignore |
| } finally { |
| try { |
| reader.close(); |
| } catch (IOException e) { |
| // ignore |
| } |
| } |
| } |
| |
| private static String resolveArtifactParam(Map parameters) throws CoreException { |
| IProfile profile = (IProfile) parameters.get(ActionConstants.PARM_PROFILE); |
| IInstallableUnit iu = (IInstallableUnit) parameters.get(EclipseTouchpoint.PARM_IU); |
| IArtifactKey[] artifacts = iu.getArtifacts(); |
| if (artifacts == null || artifacts.length == 0) |
| throw new CoreException(Util.createError(NLS.bind(Messages.iu_contains_no_arifacts, iu))); |
| |
| IArtifactKey artifactKey = artifacts[0]; |
| |
| File fileLocation = Util.getArtifactFile(artifactKey, profile); |
| if (fileLocation == null || !fileLocation.exists()) |
| throw new CoreException(Util.createError(NLS.bind(Messages.artifact_file_not_found, artifactKey))); |
| return fileLocation.getAbsolutePath(); |
| } |
| } |