Skip to content

Commit

Permalink
Upgrade to kotlin 2.0.20 (#701)
Browse files Browse the repository at this point in the history
And other dependencies.

We are not using the new `kotlin.Uuid`, as they are still experimental.

Co-authored-by: Dominique Padiou <[email protected]>
  • Loading branch information
pm47 and dpad85 authored Sep 18, 2024
1 parent 40838a3 commit 0d85f88
Show file tree
Hide file tree
Showing 52 changed files with 622 additions and 1,214 deletions.
18 changes: 2 additions & 16 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
.gradle
build/
.cxx
.kotlin

# this file is local to the dev environment and must not be pushed!
local.properties
Expand All @@ -24,23 +25,8 @@ gradle-app.setting
*.class
*.log

# sbt specific
.cache/
.history/
.lib/
dist/*
target/
lib_managed/
src_managed/
project/boot/
project/plugins/project/

# Scala-IDE specific
.scala_dependencies
.worksheet

.idea
*.iml
target/
project/target
DeleteMe*.scala

49 changes: 23 additions & 26 deletions build.gradle.kts
Original file line number Diff line number Diff line change
@@ -1,11 +1,13 @@
import org.jetbrains.kotlin.gradle.ExperimentalKotlinGradlePluginApi
import org.jetbrains.kotlin.gradle.dsl.JvmTarget
import org.jetbrains.kotlin.gradle.plugin.mpp.KotlinNativeTarget
import org.jetbrains.kotlin.gradle.targets.native.tasks.KotlinNativeSimulatorTest
import org.jetbrains.kotlin.gradle.targets.native.tasks.KotlinNativeTest

plugins {
kotlin("multiplatform") version "1.9.23"
kotlin("plugin.serialization") version "1.9.23"
id("org.jetbrains.dokka") version "1.9.10"
kotlin("multiplatform") version "2.0.20"
kotlin("plugin.serialization") version "2.0.20"
id("org.jetbrains.dokka") version "1.9.20"
`maven-publish`
}

Expand All @@ -30,16 +32,17 @@ kotlin {
val bitcoinKmpVersion = "0.20.0" // when upgrading bitcoin-kmp, keep secpJniJvmVersion in sync!
val secpJniJvmVersion = "0.15.0"

val serializationVersion = "1.6.2"
val coroutineVersion = "1.7.3"
val serializationVersion = "1.7.1"
val coroutineVersion = "1.9.0"
val datetimeVersion = "0.6.0"
val ktorVersion = "2.3.7"
val ktorVersion = "2.3.12"
fun ktor(module: String) = "io.ktor:ktor-$module:$ktorVersion"
val kermitLoggerVersion = "2.0.2"
val kermitLoggerVersion = "2.0.4"

jvm {
compilations.all {
kotlinOptions.jvmTarget = "1.8"
@OptIn(ExperimentalKotlinGradlePluginApi::class)
compilerOptions {
jvmTarget.set(JvmTarget.JVM_1_8) // TODO: update this?
}
}

Expand Down Expand Up @@ -153,15 +156,12 @@ kotlin {
resolutionStrategy.cacheChangingModulesFor(0, TimeUnit.SECONDS)
}

targets.all {
compilations.all {
kotlinOptions {
allWarningsAsErrors = true
// We use expect/actual for classes (see Chacha20Poly1305CipherFunctions). This feature is in beta and raises a warning.
// See https://youtrack.jetbrains.com/issue/KT-61573
kotlinOptions.freeCompilerArgs += "-Xexpect-actual-classes"
}
}
@OptIn(ExperimentalKotlinGradlePluginApi::class)
compilerOptions {
allWarningsAsErrors.set(true)
// We use expect/actual for classes (see Chacha20Poly1305CipherFunctions). This feature is in beta and raises a warning.
// See https://youtrack.jetbrains.com/issue/KT-61573
freeCompilerArgs.add("-Xexpect-actual-classes")
}
}

Expand Down Expand Up @@ -237,7 +237,11 @@ afterEvaluate {
compileTaskProvider.get().enabled = false
tasks[processResourcesTaskName].enabled = false
}
binaries.all { linkTask.enabled = false }
binaries.all {
linkTaskProvider {
enabled = false
}
}

mavenPublication {
val publicationToDisable = this
Expand Down Expand Up @@ -318,10 +322,3 @@ tasks
.map {
it.filter.excludeTestsMatching("*MempoolSpace*Test")
}

// Make NS_FORMAT_ARGUMENT(1) a no-op
// This fixes an issue when building PhoenixCrypto using XCode 13
// More on this: https://youtrack.jetbrains.com/issue/KT-48807#focus=Comments-27-5210791.0-0
tasks.withType(org.jetbrains.kotlin.gradle.tasks.CInteropProcess::class.java) {
settings.compilerOpts("-DNS_FORMAT_ARGUMENT(A)=")
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,14 +2,18 @@ package fr.acinq.lightning.crypto.noise

import fr.acinq.lightning.crypto.ChaCha20Poly1305

expect object Chacha20Poly1305CipherFunctions : CipherFunctions
expect object Chacha20Poly1305CipherFunctions : CipherFunctions {
override fun name(): String
override fun encrypt(k: ByteArray, n: Long, ad: ByteArray, plaintext: ByteArray): ByteArray
override fun decrypt(k: ByteArray, n: Long, ad: ByteArray, ciphertextAndMac: ByteArray): ByteArray
}

/**
* Default implementation for [[Chacha20Poly1305CipherFunctions]]. Can be used by modules by
* Default implementation for [Chacha20Poly1305CipherFunctions]. Can be used by modules by
* defining a type alias.
*/
object Chacha20Poly1305CipherFunctionsDefault : CipherFunctions {
override fun name() = "ChaChaPoly"
override fun name(): String = "ChaChaPoly"

// as specified in BOLT #8
fun nonce(n: Long): ByteArray = ByteArray(4) + ChaCha20Poly1305.write64(n)
Expand All @@ -21,7 +25,6 @@ object Chacha20Poly1305CipherFunctionsDefault : CipherFunctions {
}

// Decrypts ciphertext using a cipher key k of 32 bytes, an 8-byte unsigned integer nonce n, and associated data ad.
@Suppress("PARAMETER_NAME_CHANGED_ON_OVERRIDE")
override fun decrypt(k: ByteArray, n: Long, ad: ByteArray, ciphertextAndMac: ByteArray): ByteArray {
val ciphertext = ciphertextAndMac.dropLast(16).toByteArray()
val mac = ciphertextAndMac.takeLast(16).toByteArray()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ interface CipherFunctions {

// Decrypts ciphertext using a cipher key k of 32 bytes, an 8-byte unsigned integer nonce n, and associated data ad.
// Returns the plaintext, unless authentication fails, in which case an error is signaled to the caller.
fun decrypt(k: ByteArray, n: Long, ad: ByteArray, ciphertext: ByteArray): ByteArray
fun decrypt(k: ByteArray, n: Long, ad: ByteArray, ciphertextAndMac: ByteArray): ByteArray
}

/**
Expand Down
5 changes: 4 additions & 1 deletion src/commonMain/kotlin/fr/acinq/lightning/io/TcpSocket.kt
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package fr.acinq.lightning.io

import fr.acinq.lightning.io.TcpSocket.TLS
import fr.acinq.lightning.logging.LoggerFactory

interface TcpSocket {
Expand Down Expand Up @@ -65,6 +66,8 @@ suspend fun TcpSocket.send(bytes: ByteArray, flush: Boolean = true) = send(bytes
suspend fun TcpSocket.receiveFully(buffer: ByteArray) = receiveFully(buffer, 0, buffer.size)
suspend fun TcpSocket.receiveAvailable(buffer: ByteArray) = receiveAvailable(buffer, 0, buffer.size)

internal expect object PlatformSocketBuilder : TcpSocket.Builder
internal expect object PlatformSocketBuilder : TcpSocket.Builder {
override suspend fun connect(host: String, port: Int, tls: TLS, loggerFactory: LoggerFactory): TcpSocket
}

suspend fun TcpSocket.receiveFully(size: Int): ByteArray = ByteArray(size).also { receiveFully(it) }
24 changes: 8 additions & 16 deletions src/commonTest/resources/nonreg/v2/Closing_0ba41d17/data.json
Original file line number Diff line number Diff line change
Expand Up @@ -43,8 +43,7 @@
"trusted_swap_in_provider": "Optional",
"channel_backup_provider": "Optional"
},
"unknown": [
]
"unknown": []
}
},
"remoteParams": {
Expand Down Expand Up @@ -78,8 +77,7 @@
"channel_backup_client": "Optional",
"trampoline_payment_experimental": "Optional"
},
"unknown": [
]
"unknown": []
}
},
"channelFlags": 0
Expand All @@ -94,18 +92,13 @@
"paymentPreimage": "470394f1ea93ed652ed8fba12c00dcfe8212c4fd3295f7413f7a927e002ea4eb"
}
],
"signed": [
],
"acked": [
]
"signed": [],
"acked": []
},
"remoteChanges": {
"proposed": [
],
"acked": [
],
"signed": [
]
"proposed": [],
"acked": [],
"signed": []
},
"localNextHtlcId": 1,
"remoteNextHtlcId": 1
Expand Down Expand Up @@ -232,8 +225,7 @@
"nextRemoteCommit": null
}
],
"inactive": [
],
"inactive": [],
"payments": {
"0": "a63c8f54-772a-4912-9b2a-055f7f64ce56"
},
Expand Down
45 changes: 15 additions & 30 deletions src/commonTest/resources/nonreg/v2/Closing_0ed6ff68/data.json
Original file line number Diff line number Diff line change
Expand Up @@ -43,8 +43,7 @@
"trusted_swap_in_client": "Optional",
"channel_backup_client": "Optional"
},
"unknown": [
]
"unknown": []
}
},
"remoteParams": {
Expand Down Expand Up @@ -78,28 +77,21 @@
"channel_backup_provider": "Optional",
"trampoline_payment_experimental": "Optional"
},
"unknown": [
]
"unknown": []
}
},
"channelFlags": 0
},
"changes": {
"localChanges": {
"proposed": [
],
"signed": [
],
"acked": [
]
"proposed": [],
"signed": [],
"acked": []
},
"remoteChanges": {
"proposed": [
],
"acked": [
],
"signed": [
]
"proposed": [],
"acked": [],
"signed": []
},
"localNextHtlcId": 0,
"remoteNextHtlcId": 0
Expand All @@ -118,10 +110,8 @@
"localCommit": {
"index": 0,
"spec": {
"htlcsIn": [
],
"htlcsOut": [
],
"htlcsIn": [],
"htlcsOut": [],
"feerate": 5000,
"toLocal": 200000000,
"toRemote": 800000000
Expand All @@ -138,17 +128,14 @@
},
"tx": "020000000001012f7c825b61cbbf0e685aef20f8923a8cd28943346e59301b629cc89b4e27cdbd000000000000b77080044a0100000000000022002046672803839d10e21d43eafb532bc37cd21bd97dec7f9b50d45380cd1cce69654a01000000000000220020bbd7f17366848d8f624c28438128ce4dc8c72ea21deb0ccf25bee110920da032400d03000000000022002031dbc67ef6930d0825de6c23bd311eb93d40430d543c0555aa0f15b7aaab0cbc781c0c0000000000220020958bb43c9e6d1b985001c2f4dc38d286d7fde78bb04d7ec5a5ae44d8ebf0c40c040047304402201991b61ae8ef7bf6bd03f6f965552294e7941fce3fc91a024094cbd9b3464dd202206068ef64671e59b5825408e58462613a6ad0edfc7aa23853aea36187298c493901483045022100cca233f9a14605a7adab49f959c5b42260a55156282cbc802397fc934d5e537c02203504b82653044526706d76d3ddf0f083ea77a16f6cc13c93add344069a55cb940147522102b6eaf304d966a6df90f3b3df7af7be6b1625854bbc096cb8b3507b2a37c2bf9c210385cfd7d8850e4cb8fcbed57310911218e5d5e1fd34f92ef5d9db14d56418caa452aede99dc20"
},
"htlcTxsAndSigs": [
]
"htlcTxsAndSigs": []
}
},
"remoteCommit": {
"index": 0,
"spec": {
"htlcsIn": [
],
"htlcsOut": [
],
"htlcsIn": [],
"htlcsOut": [],
"feerate": 5000,
"toLocal": 800000000,
"toRemote": 200000000
Expand All @@ -159,10 +146,8 @@
"nextRemoteCommit": null
}
],
"inactive": [
],
"payments": {
},
"inactive": [],
"payments": {},
"remoteNextCommitInfo": {
"left": null,
"right": "0234ea3e3929ca115acc645d07c40eada7a98d86017614c3fa466d7e19760917e4"
Expand Down
Loading

0 comments on commit 0d85f88

Please sign in to comment.