Skip to content
This repository has been archived by the owner on Apr 9, 2021. It is now read-only.

Commit

Permalink
Fix/maven modularization (#221)
Browse files Browse the repository at this point in the history
* Properly modularize the project with maven

* More pom clean up and documentation
  • Loading branch information
schnapster authored and freyacodes committed Jul 15, 2017
1 parent 60cb312 commit 5ce5f64
Show file tree
Hide file tree
Showing 24 changed files with 225 additions and 160 deletions.
38 changes: 23 additions & 15 deletions FredBoat-Bootloader/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -24,17 +24,33 @@
~
-->

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<groupId>fredboat</groupId>
<artifactId>FredBoat-Root</artifactId>
<version>1.0</version>
</parent>

<modelVersion>4.0.0</modelVersion>
<groupId>com.frederikam</groupId>
<artifactId>FredBoat-Bootloader</artifactId>
<version>1.0</version>
<packaging>jar</packaging>

<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<start-class>fredboat.bootloader.Bootloader</start-class>
</properties>

<dependencies>
<dependency>
<!-- fredboat internal shared library -->
<groupId>fredboat</groupId>
<artifactId>Shared</artifactId>
<version>1.0</version>
</dependency>
</dependencies>

<build>
<plugins>
<plugin>
Expand All @@ -51,7 +67,7 @@
<transformers>
<transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
<manifestEntries>
<Main-Class>com.frederikam.fredboat.bootloader.Bootloader</Main-Class>
<Main-Class>fredboat.bootloader.Bootloader</Main-Class>
</manifestEntries>
</transformer>
</transformers>
Expand All @@ -61,12 +77,4 @@
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>org.json</groupId>
<artifactId>json</artifactId>
<version>20170516</version>
<type>jar</type>
</dependency>
</dependencies>
</project>
</project>

This file was deleted.

Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
/*
*
* MIT License
*
* Copyright (c) 2017 Frederik Ar. Mikkelsen
Expand All @@ -20,42 +21,43 @@
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*
*/

package com.frederikam.fredboat.bootloader;
package fredboat.bootloader;

import fredboat.shared.constant.ExitCodes;
import org.json.JSONArray;
import org.json.JSONObject;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.Scanner;
import org.json.JSONArray;
import org.json.JSONObject;

public class Bootloader {

private static JSONArray command;
private static String jarName;
private static int recentBoots = 0;
private static long lastBoot = 0L;

public static void main(String[] args) throws IOException, InterruptedException {
OUTER:
while (true) {
InputStream is = new FileInputStream(new File("./bootloader.json"));
Scanner scanner = new Scanner(is);
JSONObject json = new JSONObject(scanner.useDelimiter("\\A").next());
scanner.close();

command = json.getJSONArray("command");
jarName = json.getString("jarName");

Process process = boot();
process.waitFor();
System.out.println("[BOOTLOADER] Bot exited with code " + process.exitValue());

switch (process.exitValue()) {
case ExitCodes.EXIT_CODE_UPDATE:
System.out.println("[BOOTLOADER] Now updating...");
Expand All @@ -65,7 +67,7 @@ public static void main(String[] args) throws IOException, InterruptedException
case ExitCodes.EXIT_CODE_NORMAL:
System.out.println("[BOOTLOADER] Now shutting down...");
break OUTER;
//SIGINT received or clean exit
//SIGINT received or clean exit
default:
System.out.println("[BOOTLOADER] Now restarting..");
break;
Expand All @@ -75,28 +77,28 @@ public static void main(String[] args) throws IOException, InterruptedException

private static Process boot() throws IOException {
//Check that we are not booting too quick (we could be stuck in a login loop)
if(System.currentTimeMillis() - lastBoot > 3000 * 1000){
if (System.currentTimeMillis() - lastBoot > 3000 * 1000) {
recentBoots = 0;
}

recentBoots++;
lastBoot = System.currentTimeMillis();
if(recentBoots >= 4){

if (recentBoots >= 4) {
System.out.println("[BOOTLOADER] Failed to restart 3 times, probably due to login errors. Exiting...");
System.exit(-1);
}

//ProcessBuilder pb = new ProcessBuilder(System.getProperty("java.home") + "/bin/java -jar "+new File("FredBoat-1.0.jar").getAbsolutePath())
ProcessBuilder pb = new ProcessBuilder()
.inheritIO();
ArrayList<String> list = new ArrayList<>();
command.forEach((Object str) -> {
list.add((String) str);
});

pb.command(list);

Process process = pb.start();
return process;
}
Expand Down
Loading

0 comments on commit 5ce5f64

Please sign in to comment.