diff options
author | Simon Rettberg | 2019-02-12 15:03:04 +0100 |
---|---|---|
committer | Simon Rettberg | 2019-02-12 15:03:04 +0100 |
commit | 6581210de2a1644fcf665b93819b5cb08aa9b1b2 (patch) | |
tree | f09c1956c9cc9687ee626f75b7de4e692a63b76f /src/main/java/org/openslx/taskmanager/tasks/CompileIPxe.java | |
parent | [CreateLdapConfig] Fix detection of valid CN (diff) | |
download | tmlite-bwlp-6581210de2a1644fcf665b93819b5cb08aa9b1b2.tar.gz tmlite-bwlp-6581210de2a1644fcf665b93819b5cb08aa9b1b2.tar.xz tmlite-bwlp-6581210de2a1644fcf665b93819b5cb08aa9b1b2.zip |
[CompileIPxe*] Separate legacy pxelinux and new ipxe-only approach
Diffstat (limited to 'src/main/java/org/openslx/taskmanager/tasks/CompileIPxe.java')
-rw-r--r-- | src/main/java/org/openslx/taskmanager/tasks/CompileIPxe.java | 175 |
1 files changed, 0 insertions, 175 deletions
diff --git a/src/main/java/org/openslx/taskmanager/tasks/CompileIPxe.java b/src/main/java/org/openslx/taskmanager/tasks/CompileIPxe.java deleted file mode 100644 index bb69559..0000000 --- a/src/main/java/org/openslx/taskmanager/tasks/CompileIPxe.java +++ /dev/null @@ -1,175 +0,0 @@ -package org.openslx.taskmanager.tasks; - -import java.io.File; -import java.io.IOException; -import java.nio.charset.Charset; -import java.nio.charset.StandardCharsets; -import java.util.concurrent.atomic.AtomicBoolean; - -import org.apache.commons.io.FileUtils; -import org.apache.log4j.Logger; -import org.openslx.satserver.util.Exec; -import org.openslx.taskmanager.api.AbstractTask; - -import com.google.gson.annotations.Expose; - -public class CompileIPxe extends AbstractTask -{ - private static final Logger LOG = Logger.getLogger( CompileIPxe.class ); - - @Expose - private String defaultentry = null; - @Expose - private int timeout = 0; - @Expose - private String custom = null; - @Expose - private String ipaddress = null; - @Expose - private String masterpassword = null; - - private Output status = new Output(); - - private static AtomicBoolean isRunning = new AtomicBoolean(); - - @Override - protected boolean initTask() - { - this.setStatusObject( this.status ); - if ( this.ipaddress == null || this.ipaddress.isEmpty() ) { - status.error = "No IP address given!"; - return false; - } - if ( this.defaultentry == null ) - this.defaultentry = "net"; - if ( this.custom == null ) - this.custom = ""; - if ( this.masterpassword == null ) - this.masterpassword = ""; - return true; - } - - @Override - protected boolean execute() - { - if ( !isRunning.compareAndSet( false, true ) ) { - status.error = "Another operation is already in progress."; - return false; - } - try { - boolean ret = true; - if ( !updateMenu() ) - ret = false; - if ( !updateIpxe() ) - ret = false; - return ret; - } finally { - isRunning.set( false ); - } - } - - private boolean updateMenu() - { - // Prepare menu - String template; - try { - template = FileUtils.readFileToString( new File( "./data/pxemenu.template" ), StandardCharsets.UTF_8 ); - } catch ( IOException e ) { - status.error = e.toString(); - return false; - } - // Substitutions - template = template.replace( "%timeout%", Integer.toString( this.timeout * 10 ) ); - template = template.replace( "%totaltimeout%", Integer.toString( this.timeout * 40 ) ); - template = template.replace( "%default%", this.defaultentry ); - template = template.replace( "%custom%", this.custom ); - template = template.replace( "%ipaddress%", this.ipaddress ); - template = template.replace( "%masterpassword%", this.masterpassword ); - // Default selection net - if ( this.defaultentry.equals( "net" ) ) - template = template.replace( "%default-net%", "MENU DEFAULT" ); - else - template = template.replace( "%default-net%", "" ); - // Default selection hdd - if ( this.defaultentry.equals( "hdd" ) ) - template = template.replace( "%default-hdd%", "MENU DEFAULT" ); - else - template = template.replace( "%default-hdd%", "" ); - // Write out - try { - Charset cs; - if ( Charset.isSupported( "IBM437" ) ) - cs = Charset.forName( "IBM437" ); - else if ( Charset.isSupported( "Cp437" ) ) - cs = Charset.forName( "Cp437" ); - else - cs = StandardCharsets.UTF_8; - FileUtils.writeStringToFile( new File( "/srv/openslx/tftp/pxelinux.cfg/default" ), template, cs ); - } catch ( IOException e ) { - status.error = e.toString(); - return false; - } - return true; - } - - private boolean updateIpxe() - { - // Prepare menu - String template; - try { - template = FileUtils.readFileToString( new File( "./data/ipxe-embed.template" ), StandardCharsets.UTF_8 ); - } catch ( IOException e ) { - status.error = e.toString(); - return false; - } - // Substitution - String hybridEmbed = template.replace( "%ipaddress%", this.ipaddress ); - String usbEmbed = hybridEmbed.replaceFirst( "ifopen", "ifopen net0\n" - + ":retry_dhcp\n" - + "dhcp net0 && goto dhcp_ok ||\n" - + "echo DHCP not successful, trying again in 10s...\n" - + "sleep 10\n" - + "goto retry_dhcp\n" - + ":dhcp_ok\n" - + "clear net0/ip\n" - + "clear net0/netmask\n" - + "set net0.dhcp/210:string http://" + this.ipaddress + "/tftp/ ||\n" - + "set 210:string http://" + this.ipaddress + "/tftp/ ||\n" ); - // Write out - try { - FileUtils.writeStringToFile( new File( "/opt/openslx/ipxe/ipxelinux.ipxe" ), hybridEmbed, StandardCharsets.UTF_8 ); - FileUtils.writeStringToFile( new File( "/opt/openslx/ipxe/usb.ipxe" ), usbEmbed, StandardCharsets.UTF_8 ); - } catch ( IOException e ) { - status.error = e.toString(); - return false; - } - // Compile - if ( 0 != Exec.syncAt( 240, "/opt/openslx/ipxe/src", "make", "EMBED=../ipxelinux.ipxe,../pxelinux.0", "bin/undionly.kkkpxe" ) ) { - status.error = "Compiling ipxelinux.0 failed"; - return false; - } - if ( 0 != Exec.syncAt( 240, "/opt/openslx/ipxe/src", "make", "EMBED=../usb.ipxe,../pxelinux.0", "bin/ipxe.usb" ) ) { - FileUtils.deleteQuietly( new File( "/opt/openslx/ipxe/openslx-bootstick.raw" ) ); - status.error = "Compiling ipxe usb image failed"; - return false; - } - try { - FileUtils.copyFile( new File( "/opt/openslx/ipxe/src/bin/ipxe.usb" ), new File( "/opt/openslx/ipxe/openslx-bootstick.raw" ) ); - } catch ( Exception e ) { - status.error = "Warning: could not create bootstick image"; - } - try { - FileUtils.copyFile( new File( "/opt/openslx/ipxe/src/bin/undionly.kkkpxe" ), new File( "/srv/openslx/tftp/ipxelinux.0" ) ); - } catch ( Exception e ) { - status.error = e.toString(); - return false; - } - return true; - } - - class Output - { - protected String error = null; - } - -} |