]> git.argeo.org Git - gpl/argeo-slc.git/commitdiff
Improve Linux support
authorMathieu Baudier <mbaudier@argeo.org>
Tue, 6 Jul 2010 20:41:00 +0000 (20:41 +0000)
committerMathieu Baudier <mbaudier@argeo.org>
Tue, 6 Jul 2010 20:41:00 +0000 (20:41 +0000)
git-svn-id: https://svn.argeo.org/slc/trunk@3651 4cfe0d0a-d680-48aa-b62c-e0a02a3f76cc

runtime/org.argeo.slc.support.simple/src/main/java/org/argeo/slc/jsch/SshTarget.java
runtime/org.argeo.slc.support.simple/src/main/java/org/argeo/slc/lib/linux/DefaultRedhatDeploymentData.java [new file with mode: 0644]
runtime/org.argeo.slc.support.simple/src/main/java/org/argeo/slc/lib/linux/DefaultRpmDistribution.java [new file with mode: 0644]
runtime/org.argeo.slc.support.simple/src/main/java/org/argeo/slc/lib/linux/RedhatDeploymentData.java
runtime/org.argeo.slc.support.simple/src/main/java/org/argeo/slc/lib/linux/RedhatHostManager.java
runtime/org.argeo.slc.support.simple/src/main/java/org/argeo/slc/lib/linux/RpmDistribution.java

index 80e49bb9217d107b2a29cef73183ba74151af68d..58ac9cbd34cd2f3c7e0fb39a1af6e760871be4a4 100644 (file)
@@ -25,7 +25,7 @@ public class SshTarget {
        private String host;
        private Integer port = 22;
        private String user;
-       private UserInfo userInfo;
+       private UserInfo userInfo = new SimpleUserInfo();
 
        private Boolean usePrivateKey = true;
        private File localPrivateKey = new File(System.getProperty("user.home")
diff --git a/runtime/org.argeo.slc.support.simple/src/main/java/org/argeo/slc/lib/linux/DefaultRedhatDeploymentData.java b/runtime/org.argeo.slc.support.simple/src/main/java/org/argeo/slc/lib/linux/DefaultRedhatDeploymentData.java
new file mode 100644 (file)
index 0000000..a6b0379
--- /dev/null
@@ -0,0 +1,70 @@
+/*
+ * Copyright (C) 2010 Mathieu Baudier <mbaudier@argeo.org>
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *         http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.argeo.slc.lib.linux;
+
+import org.argeo.slc.core.deploy.MultiResourceSet;
+import org.argeo.slc.core.deploy.ResourceSet;
+
+public class DefaultRedhatDeploymentData implements RedhatDeploymentData {
+       private ResourceSet configurationFiles;
+       private String runlevelsScript;
+       private String permissionsScript;
+
+       private RedhatDeploymentData parent;
+
+       public ResourceSet getConfigurationFiles() {
+               if (parent != null && parent.getConfigurationFiles() != null) {
+                       MultiResourceSet mrs = new MultiResourceSet();
+                       mrs.getResourceSets().add(parent.getConfigurationFiles());
+                       mrs.getResourceSets().add(configurationFiles);
+                       return mrs;
+               } else {
+                       return configurationFiles;
+               }
+       }
+
+       public String getRunlevelsScript() {
+               if (parent != null && parent.getRunlevelsScript() != null)
+                       return parent.getRunlevelsScript() + "\n" + runlevelsScript;
+               else
+                       return runlevelsScript;
+       }
+
+       public String getPermissionsScript() {
+               if (parent != null && parent.getPermissionsScript() != null)
+                       return parent.getPermissionsScript() + "\n" + permissionsScript;
+               else
+                       return permissionsScript;
+       }
+
+       public void setRunlevelsScript(String runlevelsScript) {
+               this.runlevelsScript = runlevelsScript;
+       }
+
+       public void setConfigurationFiles(ResourceSet configurationFiles) {
+               this.configurationFiles = configurationFiles;
+       }
+
+       public void setPermissionsScript(String permissionsScript) {
+               this.permissionsScript = permissionsScript;
+       }
+
+       public void setParent(RedhatDeploymentData parentDeploymentData) {
+               this.parent = parentDeploymentData;
+       }
+
+}
diff --git a/runtime/org.argeo.slc.support.simple/src/main/java/org/argeo/slc/lib/linux/DefaultRpmDistribution.java b/runtime/org.argeo.slc.support.simple/src/main/java/org/argeo/slc/lib/linux/DefaultRpmDistribution.java
new file mode 100644 (file)
index 0000000..3e0a9c1
--- /dev/null
@@ -0,0 +1,37 @@
+/*
+ * Copyright (C) 2010 Mathieu Baudier <mbaudier@argeo.org>
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *         http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.argeo.slc.lib.linux;
+
+import java.util.List;
+
+public class DefaultRpmDistribution implements RpmDistribution {
+       private List<String> additionalPackages;
+
+       public String getDistributionId() {
+               // TODO Auto-generated method stub
+               return null;
+       }
+
+       public List<String> getAdditionalPackages() {
+               return additionalPackages;
+       }
+
+       public void setAdditionalPackages(List<String> additionalPackages) {
+               this.additionalPackages = additionalPackages;
+       }
+
+}
index 484378a4383d0ab3d3a965a940622e521bf04a58..cb735022b941b5a6ad589f2e699ef806da6e54c1 100644 (file)
 
 package org.argeo.slc.lib.linux;
 
-import org.argeo.slc.core.deploy.MultiResourceSet;
 import org.argeo.slc.core.deploy.ResourceSet;
 import org.argeo.slc.deploy.DeploymentData;
 
-public class RedhatDeploymentData implements DeploymentData {
-       private ResourceSet configurationFiles;
-       private String runlevelsScript;
-       private String permissionsScript;
+public interface RedhatDeploymentData extends DeploymentData {
+       public ResourceSet getConfigurationFiles();
 
-       private RedhatDeploymentData parent;
-
-       public ResourceSet getConfigurationFiles() {
-               if (parent != null && parent.getConfigurationFiles() != null) {
-                       MultiResourceSet mrs = new MultiResourceSet();
-                       mrs.getResourceSets().add(parent.getConfigurationFiles());
-                       mrs.getResourceSets().add(configurationFiles);
-                       return mrs;
-               } else {
-                       return configurationFiles;
-               }
-       }
-
-       public String getRunlevelsScript() {
-               if (parent != null && parent.getRunlevelsScript() != null)
-                       return parent.getRunlevelsScript() + "\n" + runlevelsScript;
-               else
-                       return runlevelsScript;
-       }
-
-       public String getPermissionsScript() {
-               if (parent != null && parent.getPermissionsScript() != null)
-                       return parent.getPermissionsScript() + "\n" + permissionsScript;
-               else
-                       return permissionsScript;
-       }
-
-       public void setRunlevelsScript(String runlevelsScript) {
-               this.runlevelsScript = runlevelsScript;
-       }
-
-       public void setConfigurationFiles(ResourceSet configurationFiles) {
-               this.configurationFiles = configurationFiles;
-       }
-
-       public void setPermissionsScript(String permissionsScript) {
-               this.permissionsScript = permissionsScript;
-       }
-
-       public void setParent(RedhatDeploymentData parentDeploymentData) {
-               this.parent = parentDeploymentData;
-       }
+       public String getRunlevelsScript();
 
+       public String getPermissionsScript();
 }
index a583921936aea780deb931c3cc8b4992e2350f02..f4e0076b3e657229c220e594d7bbc7a293e6a8a1 100644 (file)
@@ -62,9 +62,14 @@ public class RedhatHostManager {
        }
 
        protected void executeCommand(String command) {
-               if (useSsh)
-                       new RemoteExec(getSshTarget(), command).run();
-               else
+               if (command == null)
+                       return;
+
+               if (useSsh) {
+                       RemoteExec rExec = new RemoteExec(getSshTarget(), command);
+                       rExec.setFailOnBadExitStatus(false);
+                       rExec.run();
+               } else
                        new SystemCall(command).run();
        }
 
index e9ff8db863d606060808b423b58b29c688ccf036..ebe02869363b6c6c0ffb932bb297eb31c560b1c5 100644 (file)
@@ -20,20 +20,9 @@ import java.util.List;
 
 import org.argeo.slc.build.Distribution;
 
-public class RpmDistribution implements Distribution {
-       private List<String> additionalPackages;
+public interface RpmDistribution extends Distribution {
+       public List<String> getAdditionalPackages();
 
-       public String getDistributionId() {
-               // TODO Auto-generated method stub
-               return null;
-       }
-
-       public List<String> getAdditionalPackages() {
-               return additionalPackages;
-       }
-
-       public void setAdditionalPackages(List<String> additionalPackages) {
-               this.additionalPackages = additionalPackages;
-       }
+       public void setAdditionalPackages(List<String> additionalPackages);
 
 }