diff --git a/pom.xml b/pom.xml
index 143921f..be2c1be 100644
--- a/pom.xml
+++ b/pom.xml
@@ -5,7 +5,7 @@
org.berndpruenster.netlayer
parent
- 0.6.5.2
+ 0.6.6
pom
Netlayer
diff --git a/tor.external/pom.xml b/tor.external/pom.xml
index faf8090..6307e61 100644
--- a/tor.external/pom.xml
+++ b/tor.external/pom.xml
@@ -6,7 +6,7 @@
org.berndpruenster.netlayer
parent
- 0.6.5.2
+ 0.6.6
tor.external
diff --git a/tor.native/pom.xml b/tor.native/pom.xml
index 3c78aed..9597b2b 100644
--- a/tor.native/pom.xml
+++ b/tor.native/pom.xml
@@ -6,7 +6,7 @@
org.berndpruenster.netlayer
parent
- 0.6.5.2
+ 0.6.6
tor.native
@@ -34,6 +34,16 @@
tor-binary-linux64
${tor-binary.version}
+
+ com.github.JesusMcCloud.tor-binary
+ tor-binary-linux-armhf
+ ${tor-binary.version}
+
+
+ com.github.JesusMcCloud.tor-binary
+ tor-binary-linux-arm64
+ ${tor-binary.version}
+
com.github.JesusMcCloud.tor-binary
tor-binary-windows
diff --git a/tor.native/src/main/kotlin/org/berndpruenster/netlayer/tor/NativeTor.kt b/tor.native/src/main/kotlin/org/berndpruenster/netlayer/tor/NativeTor.kt
index 0db5711..44e7f56 100644
--- a/tor.native/src/main/kotlin/org/berndpruenster/netlayer/tor/NativeTor.kt
+++ b/tor.native/src/main/kotlin/org/berndpruenster/netlayer/tor/NativeTor.kt
@@ -44,6 +44,8 @@ private const val BINARY_TOR_LNX = "tor"
private const val PATH_LNX = "linux/"
private const val PATH_LNX64 = "${PATH_LNX}x64/"
private const val PATH_LNX32 = "${PATH_LNX}x86/"
+private const val PATH_LNXARMHF = "${PATH_LNX}armhf/"
+private const val PATH_LNXARM64 = "${PATH_LNX}arm64/"
private const val PATH_MACOS = "osx/"
private const val PATH_MACOS64 = "${PATH_MACOS}x64/"
private const val PATH_WIN = "windows/"
@@ -53,7 +55,7 @@ private const val PATH_NATIVE = "native/"
private const val OS_UNSUPPORTED = "We don't support Tor on this OS"
class NativeTor @JvmOverloads @Throws(TorCtlException::class) constructor(workingDirectory: File, bridgeLines: Collection? = null, torrcOverrides: Torrc? = null, automaticShutdown : Boolean = true) : Tor() {
-
+
private val context : NativeContext = NativeContext(workingDirectory, torrcOverrides)
private val bridgeConfig: List = bridgeLines?.filter { it.length > 10 } ?: emptyList()
@@ -151,6 +153,8 @@ class NativeContext(workingDirectory: File, overrides: Torrc?) : TorContext(work
OsType.MACOS -> PATH_NATIVE + PATH_MACOS64
OsType.LNX32 -> PATH_NATIVE + PATH_LNX32
OsType.LNX64 -> PATH_NATIVE + PATH_LNX64
+ OsType.LNXARMHF -> PATH_NATIVE + PATH_LNXARMHF
+ OsType.LNXARM64 -> PATH_NATIVE + PATH_LNXARM64
else -> throw RuntimeException(OS_UNSUPPORTED)
}
}
@@ -159,7 +163,7 @@ class NativeContext(workingDirectory: File, overrides: Torrc?) : TorContext(work
when (OsType.current) {
OsType.WIN -> PATH_NATIVE + PATH_WIN
OsType.MACOS -> PATH_NATIVE + PATH_MACOS
- OsType.LNX32, OsType.LNX64 -> PATH_NATIVE + PATH_LNX
+ OsType.LNX32, OsType.LNX64, OsType.LNXARMHF, OsType.LNXARM64 -> PATH_NATIVE + PATH_LNX
else -> throw RuntimeException(OS_UNSUPPORTED)
}
}
@@ -167,7 +171,7 @@ class NativeContext(workingDirectory: File, overrides: Torrc?) : TorContext(work
override val torExecutableFileName: String by lazy {
when (OsType.current) {
- OsType.LNX32, OsType.LNX64 -> BINARY_TOR_LNX
+ OsType.LNX32, OsType.LNX64, OsType.LNXARMHF, OsType.LNXARM64 -> BINARY_TOR_LNX
OsType.WIN -> BINARY_TOR_WIN
OsType.MACOS -> BINARY_TOR_MACOS
else -> throw RuntimeException(OS_UNSUPPORTED)
@@ -182,7 +186,7 @@ class NativeContext(workingDirectory: File, overrides: Torrc?) : TorContext(work
override fun installFiles() {
super.installFiles()
when (OsType.current) {
- OsType.WIN, OsType.LNX32, OsType.LNX64, OsType.MACOS -> extractContentFromArchive(workingDirectory,
+ OsType.WIN, OsType.LNX32, OsType.LNX64, OsType.LNXARMHF, OsType.LNXARM64, OsType.MACOS -> extractContentFromArchive(workingDirectory,
getByName(
pathToTorExecutable + FILE_ARCHIVE))
else -> throw RuntimeException(OS_UNSUPPORTED)
diff --git a/tor.native/src/main/kotlin/org/berndpruenster/netlayer/tor/TorContext.kt b/tor.native/src/main/kotlin/org/berndpruenster/netlayer/tor/TorContext.kt
index dfd28d6..6a0cb0e 100644
--- a/tor.native/src/main/kotlin/org/berndpruenster/netlayer/tor/TorContext.kt
+++ b/tor.native/src/main/kotlin/org/berndpruenster/netlayer/tor/TorContext.kt
@@ -238,7 +238,7 @@ abstract class TorContext @Throws(IOException::class) protected constructor(val
val environment = processBuilder.environment()
environment.put("HOME", workingDirectory.absolutePath)
when (OsType.current) {
- OsType.LNX32, OsType.LNX64 ->
+ OsType.LNX32, OsType.LNX64, OsType.LNXARMHF, OsType.LNXARM64 ->
// We have to provide the LD_LIBRARY_PATH because when looking
// for dynamic libraries
// Linux apparently will not look in the current directory by
diff --git a/tor/pom.xml b/tor/pom.xml
index ee9225c..866d0ed 100644
--- a/tor/pom.xml
+++ b/tor/pom.xml
@@ -6,7 +6,7 @@
org.berndpruenster.netlayer
parent
- 0.6.5.2
+ 0.6.6
tor
diff --git a/tor/src/main/kotlin/org/berndpruenster/netlayer/tor/OsType.kt b/tor/src/main/kotlin/org/berndpruenster/netlayer/tor/OsType.kt
index 92b9c1e..e9d184f 100644
--- a/tor/src/main/kotlin/org/berndpruenster/netlayer/tor/OsType.kt
+++ b/tor/src/main/kotlin/org/berndpruenster/netlayer/tor/OsType.kt
@@ -40,6 +40,8 @@ import java.util.*
enum class OsType { WIN,
LNX32,
LNX64,
+ LNXARMHF,
+ LNXARM64,
MACOS,
ANDROID;
@@ -86,6 +88,12 @@ enum class OsType { WIN,
if (unameOutput.compareTo("x86_64") == 0) {
return LNX64
}
+ if (unameOutput.matches(Regex("arm.+"))) {
+ return LNXARMHF
+ }
+ if (unameOutput.compareTo("aarch64") == 0) {
+ return LNXARM64
+ }
throw RuntimeException("Could not understand uname output, not sure what bitness")
} catch (e: IOException) {
throw RuntimeException("Uname failure", e)
@@ -99,7 +107,6 @@ enum class OsType { WIN,
}
fun isUnixoid(): Boolean {
- return listOf(LNX32, LNX64, MACOS).contains(this)
+ return listOf(LNX32, LNX64, LNXARMHF, LNXARM64, MACOS).contains(this)
}
}
-