From 2005f5a6bcfc2b503cee260b6e9c03dbe4e27a14 Mon Sep 17 00:00:00 2001 From: Massimo Siani Date: Sat, 3 Jun 2023 15:00:34 +0200 Subject: [PATCH 01/28] add grant completion --- .../shared/src/main/scala/data/Completion.scala | 1 + .../scala/net/message/CommandComplete.scala | 1 + .../shared/src/test/scala/CommandTest.scala | 17 +++++++++++++++++ 3 files changed, 19 insertions(+) diff --git a/modules/core/shared/src/main/scala/data/Completion.scala b/modules/core/shared/src/main/scala/data/Completion.scala index d5d70094d..0052099e9 100644 --- a/modules/core/shared/src/main/scala/data/Completion.scala +++ b/modules/core/shared/src/main/scala/data/Completion.scala @@ -61,6 +61,7 @@ object Completion { case object DropTrigger extends Completion case object SetConstraints extends Completion case object Explain extends Completion + case object Grant extends Completion // more ... /** diff --git a/modules/core/shared/src/main/scala/net/message/CommandComplete.scala b/modules/core/shared/src/main/scala/net/message/CommandComplete.scala index 6e9d36816..88079099e 100644 --- a/modules/core/shared/src/main/scala/net/message/CommandComplete.scala +++ b/modules/core/shared/src/main/scala/net/message/CommandComplete.scala @@ -99,6 +99,7 @@ object CommandComplete { case Patterns.Copy(s) => apply(Completion.Copy(s.toInt)) case "SET CONSTRAINTS" => apply(Completion.SetConstraints) case "EXPLAIN" => apply(Completion.Explain) + case "GRANT" => apply(Completion.Grant) // more .. fill in as we hit them case s => apply(Completion.Unknown(s)) diff --git a/modules/tests/shared/src/test/scala/CommandTest.scala b/modules/tests/shared/src/test/scala/CommandTest.scala index 5358e7a2c..2ab70e424 100644 --- a/modules/tests/shared/src/test/scala/CommandTest.scala +++ b/modules/tests/shared/src/test/scala/CommandTest.scala @@ -305,6 +305,13 @@ class CommandTest extends SkunkTest { ON city; """.command + val grant: Command[Void] = + sql""" + GRANT ALL PRIVILEGES + ON ALL TABLES IN SCHEMA public + TO skunk_role + """.command + sessionTest("create table, create index, drop index, alter table and drop table") { s => for { c <- s.execute(createTable) @@ -528,4 +535,14 @@ class CommandTest extends SkunkTest { .as("ok") } + sessionTest("grant") { s => + for{ + _ <- s.execute(createRole) + c <- s.execute(grant) + _ <- assert("completion", c == Completion.Grant) + _ <- s.execute(dropRole) + _ <- s.assertHealthy + } yield "ok" + } + } From 1f5877f510c3dc0bbde2209954a162490c6bcef2 Mon Sep 17 00:00:00 2001 From: Massimo Siani Date: Sat, 3 Jun 2023 15:19:20 +0200 Subject: [PATCH 02/28] add revoke --- .../core/shared/src/main/scala/data/Completion.scala | 1 + .../src/main/scala/net/message/CommandComplete.scala | 1 + modules/tests/shared/src/test/scala/CommandTest.scala | 11 ++++++++++- 3 files changed, 12 insertions(+), 1 deletion(-) diff --git a/modules/core/shared/src/main/scala/data/Completion.scala b/modules/core/shared/src/main/scala/data/Completion.scala index 0052099e9..d8d8f629a 100644 --- a/modules/core/shared/src/main/scala/data/Completion.scala +++ b/modules/core/shared/src/main/scala/data/Completion.scala @@ -62,6 +62,7 @@ object Completion { case object SetConstraints extends Completion case object Explain extends Completion case object Grant extends Completion + case object Revoke extends Completion // more ... /** diff --git a/modules/core/shared/src/main/scala/net/message/CommandComplete.scala b/modules/core/shared/src/main/scala/net/message/CommandComplete.scala index 88079099e..30a597475 100644 --- a/modules/core/shared/src/main/scala/net/message/CommandComplete.scala +++ b/modules/core/shared/src/main/scala/net/message/CommandComplete.scala @@ -100,6 +100,7 @@ object CommandComplete { case "SET CONSTRAINTS" => apply(Completion.SetConstraints) case "EXPLAIN" => apply(Completion.Explain) case "GRANT" => apply(Completion.Grant) + case "REVOKE" => apply(Completion.Revoke) // more .. fill in as we hit them case s => apply(Completion.Unknown(s)) diff --git a/modules/tests/shared/src/test/scala/CommandTest.scala b/modules/tests/shared/src/test/scala/CommandTest.scala index 2ab70e424..e9e737dd0 100644 --- a/modules/tests/shared/src/test/scala/CommandTest.scala +++ b/modules/tests/shared/src/test/scala/CommandTest.scala @@ -312,6 +312,13 @@ class CommandTest extends SkunkTest { TO skunk_role """.command + val revoke: Command[Void] = + sql""" + REVOKE ALL PRIVILEGES + ON ALL TABLES IN SCHEMA public + FROM skunk_role + """.command + sessionTest("create table, create index, drop index, alter table and drop table") { s => for { c <- s.execute(createTable) @@ -535,11 +542,13 @@ class CommandTest extends SkunkTest { .as("ok") } - sessionTest("grant") { s => + sessionTest("grant, revoke") { s => for{ _ <- s.execute(createRole) c <- s.execute(grant) _ <- assert("completion", c == Completion.Grant) + c <- s.execute(revoke) + _ <- assert("completion", c == Completion.Revoke) _ <- s.execute(dropRole) _ <- s.assertHealthy } yield "ok" From b7b83a6d29ed2ab394e0694401e3ec2dbfecc047 Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Wed, 23 Aug 2023 00:45:28 +0000 Subject: [PATCH 03/28] Update sbt-typelevel, sbt-typelevel-site to 0.5.0 in series/0.6.x --- project/plugins.sbt | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/project/plugins.sbt b/project/plugins.sbt index 7586e1485..8f14a0ebc 100644 --- a/project/plugins.sbt +++ b/project/plugins.sbt @@ -3,8 +3,8 @@ ThisBuild / libraryDependencySchemes ++= Seq( "org.scala-lang.modules" %% "scala-xml" % VersionScheme.Always ) -addSbtPlugin("org.typelevel" % "sbt-typelevel" % "0.5.0-RC12") -addSbtPlugin("org.typelevel" % "sbt-typelevel-site" % "0.5.0-RC12") +addSbtPlugin("org.typelevel" % "sbt-typelevel" % "0.5.0") +addSbtPlugin("org.typelevel" % "sbt-typelevel-site" % "0.5.0") addSbtPlugin("com.timushev.sbt" % "sbt-updates" % "0.6.4") addSbtPlugin("org.scalameta" % "sbt-mdoc" % "2.3.7") addSbtPlugin("org.scoverage" % "sbt-scoverage" % "2.0.8") From 547faf03f7397aed12f268901b9b0d44118d3f09 Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Fri, 25 Aug 2023 00:39:08 +0000 Subject: [PATCH 04/28] Update sbt to 1.9.4 in series/0.6.x --- project/build.properties | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/project/build.properties b/project/build.properties index 52413ab79..304098715 100644 --- a/project/build.properties +++ b/project/build.properties @@ -1 +1 @@ -sbt.version=1.9.3 +sbt.version=1.9.4 From 2f58a9adb1b18d3c9f153f488dd7f7c96d973a51 Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Mon, 28 Aug 2023 00:17:42 +0000 Subject: [PATCH 05/28] Update epollcat to 0.1.6 in series/0.6.x --- build.sbt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/build.sbt b/build.sbt index 4a8b0cf9c..f5434657a 100644 --- a/build.sbt +++ b/build.sbt @@ -191,7 +191,7 @@ lazy val tests = crossProject(JVMPlatform, JSPlatform, NativePlatform) ) .nativeEnablePlugins(ScalaNativeBrewedConfigPlugin) .nativeSettings( - libraryDependencies += "com.armanbilge" %%% "epollcat" % "0.1.5", + libraryDependencies += "com.armanbilge" %%% "epollcat" % "0.1.6", Test / nativeBrewFormulas ++= Set("s2n", "utf8proc"), Test / envVars ++= Map("S2N_DONT_MLOCK" -> "1") ) From 5eee908b596c4f4e999971598ad275125d472a69 Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Mon, 28 Aug 2023 20:17:45 +0000 Subject: [PATCH 06/28] Update scalafmt-core to 3.7.13 in series/0.6.x --- .scalafmt.conf | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.scalafmt.conf b/.scalafmt.conf index ea53a263b..b5429888e 100644 --- a/.scalafmt.conf +++ b/.scalafmt.conf @@ -1,3 +1,3 @@ -version = "3.7.12" +version = "3.7.13" runner.dialect = Scala213Source3 project.includePaths = [] # disables formatting From 219e6d60b4eeac2615a9a56cee89e28bf7cac647 Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Wed, 30 Aug 2023 04:09:04 +0000 Subject: [PATCH 07/28] Update fs2-core, fs2-io to 3.9.0 in series/0.6.x --- build.sbt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/build.sbt b/build.sbt index f5434657a..458519aca 100644 --- a/build.sbt +++ b/build.sbt @@ -59,7 +59,7 @@ ThisBuild / mimaBinaryIssueFilters ++= List( ) // This is used in a couple places -lazy val fs2Version = "3.8.0" +lazy val fs2Version = "3.9.0" lazy val natchezVersion = "0.3.3" // Global Settings From 0b3ee9e5465ecb567797e00b8b36908e4566354c Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Wed, 30 Aug 2023 04:57:49 +0000 Subject: [PATCH 08/28] Fix deprecation --- modules/core/shared/src/main/scala/PreparedQuery.scala | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/core/shared/src/main/scala/PreparedQuery.scala b/modules/core/shared/src/main/scala/PreparedQuery.scala index ca422e62f..4893cb6cb 100644 --- a/modules/core/shared/src/main/scala/PreparedQuery.scala +++ b/modules/core/shared/src/main/scala/PreparedQuery.scala @@ -74,7 +74,7 @@ object PreparedQuery { Stream.resource(proto.bind(args, or)).flatMap { cursor => def chunks: Stream[F, B] = Stream.eval(cursor.execute(chunkSize)).flatMap { case (bs, more) => - val s = Stream.chunk(Chunk.seq(bs)) + val s = Stream.chunk(Chunk.from(bs)) if (more) s ++ chunks else s } From 5a35c7b2a94b80a940c00458dbc3230f5be3d0b3 Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Thu, 31 Aug 2023 00:21:35 +0000 Subject: [PATCH 09/28] Update fs2-core, fs2-io to 3.9.1 in series/0.6.x --- build.sbt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/build.sbt b/build.sbt index 458519aca..e0fb6a1c5 100644 --- a/build.sbt +++ b/build.sbt @@ -59,7 +59,7 @@ ThisBuild / mimaBinaryIssueFilters ++= List( ) // This is used in a couple places -lazy val fs2Version = "3.9.0" +lazy val fs2Version = "3.9.1" lazy val natchezVersion = "0.3.3" // Global Settings From 71f210b3e50cb1b58bf98e627b232aff6745c81a Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Thu, 31 Aug 2023 00:21:38 +0000 Subject: [PATCH 10/28] Update circe-core, circe-parser to 0.14.6 in series/0.6.x --- build.sbt | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/build.sbt b/build.sbt index 458519aca..9dd0ae820 100644 --- a/build.sbt +++ b/build.sbt @@ -155,8 +155,8 @@ lazy val circe = crossProject(JVMPlatform, JSPlatform, NativePlatform) .settings( name := "skunk-circe", libraryDependencies ++= Seq( - "io.circe" %%% "circe-core" % "0.14.5", - "io.circe" %%% "circe-parser" % "0.14.5" + "io.circe" %%% "circe-core" % "0.14.6", + "io.circe" %%% "circe-parser" % "0.14.6" ) ) From bda635abbeb5f38d1c2512095a7d22d2175b5059 Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Fri, 1 Sep 2023 20:19:15 +0000 Subject: [PATCH 11/28] Update scalafmt-core to 3.7.14 in series/0.6.x --- .scalafmt.conf | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.scalafmt.conf b/.scalafmt.conf index b5429888e..4588696a3 100644 --- a/.scalafmt.conf +++ b/.scalafmt.conf @@ -1,3 +1,3 @@ -version = "3.7.13" +version = "3.7.14" runner.dialect = Scala213Source3 project.includePaths = [] # disables formatting From 1853da62b7a1ba90493483460dcd9e6dc92f9308 Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Tue, 5 Sep 2023 12:13:09 +0000 Subject: [PATCH 12/28] Update nscplugin, sbt-scala-native, ... to 0.4.15 in series/0.6.x --- project/plugins.sbt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/project/plugins.sbt b/project/plugins.sbt index 8f14a0ebc..03123c0f3 100644 --- a/project/plugins.sbt +++ b/project/plugins.sbt @@ -9,5 +9,5 @@ addSbtPlugin("com.timushev.sbt" % "sbt-updates" % "0.6.4") addSbtPlugin("org.scalameta" % "sbt-mdoc" % "2.3.7") addSbtPlugin("org.scoverage" % "sbt-scoverage" % "2.0.8") addSbtPlugin("org.scala-js" % "sbt-scalajs" % "1.13.2") -addSbtPlugin("org.scala-native" % "sbt-scala-native" % "0.4.14") +addSbtPlugin("org.scala-native" % "sbt-scala-native" % "0.4.15") addSbtPlugin("com.armanbilge" % "sbt-scala-native-config-brew-github-actions" % "0.2.0-RC1") From f0511ae2a9211ea4d176d1020a88935f94013ab9 Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Tue, 5 Sep 2023 13:10:14 +0000 Subject: [PATCH 13/28] Use `atUnsafe` --- .../scala/net/message/PasswordMessagePlatform.scala | 12 ++++++------ .../src/main/scala/net/message/ScramPlatform.scala | 8 ++++---- 2 files changed, 10 insertions(+), 10 deletions(-) diff --git a/modules/core/native/src/main/scala/net/message/PasswordMessagePlatform.scala b/modules/core/native/src/main/scala/net/message/PasswordMessagePlatform.scala index 08ad3a012..e39dc47ec 100644 --- a/modules/core/native/src/main/scala/net/message/PasswordMessagePlatform.scala +++ b/modules/core/native/src/main/scala/net/message/PasswordMessagePlatform.scala @@ -32,11 +32,11 @@ private[message] trait PasswordMessagePlatform { // First round if (EVP_DigestInit_ex(ctx, `type`, null) != 1) throw new RuntimeException("EVP_DigestInit_ex") - if (EVP_DigestUpdate(ctx, password.getBytes.at(0), password.length.toULong) != 1) + if (EVP_DigestUpdate(ctx, password.getBytes.atUnsafe(0), password.length.toULong) != 1) throw new RuntimeException("EVP_DigestUpdate") - if (EVP_DigestUpdate(ctx, user.getBytes.at(0), user.length.toULong) != 1) + if (EVP_DigestUpdate(ctx, user.getBytes.atUnsafe(0), user.length.toULong) != 1) throw new RuntimeException("EVP_DigestUpdate") - if (EVP_DigestFinal_ex(ctx, md.at(0), size) != 1) + if (EVP_DigestFinal_ex(ctx, md.atUnsafe(0), size) != 1) throw new RuntimeException("EVP_DigestFinal_ex") var hex = BigInt(1, md.take((!size).toInt)).toString(16) while (hex.length < 32) @@ -48,11 +48,11 @@ private[message] trait PasswordMessagePlatform { // Second round if (EVP_DigestInit_ex(ctx, `type`, null) != 1) throw new RuntimeException("EVP_DigestInit_ex") - if (EVP_DigestUpdate(ctx, hex.getBytes.at(0), 32.toULong) != 1) + if (EVP_DigestUpdate(ctx, hex.getBytes.atUnsafe(0), 32.toULong) != 1) throw new RuntimeException("EVP_DigestUpdate") - if (EVP_DigestUpdate(ctx, salt.at(0), salt.length.toULong) != 1) + if (EVP_DigestUpdate(ctx, salt.atUnsafe(0), salt.length.toULong) != 1) throw new RuntimeException("EVP_DigestUpdate") - if (EVP_DigestFinal_ex(ctx, md.at(0), size) != 1) + if (EVP_DigestFinal_ex(ctx, md.atUnsafe(0), size) != 1) throw new RuntimeException("EVP_DigestFinal_ex") hex = BigInt(1, md.take((!size).toInt)).toString(16) while (hex.length < 32) diff --git a/modules/core/native/src/main/scala/net/message/ScramPlatform.scala b/modules/core/native/src/main/scala/net/message/ScramPlatform.scala index 1de037737..2f0d22388 100644 --- a/modules/core/native/src/main/scala/net/message/ScramPlatform.scala +++ b/modules/core/native/src/main/scala/net/message/ScramPlatform.scala @@ -15,7 +15,7 @@ private[message] trait ScramPlatform { this: Scram.type => def clientFirstBareWithRandomNonce: ByteVector = { val buf = new Array[Byte](32) - if (RAND_bytes(buf.at(0), 32) != 1) + if (RAND_bytes(buf.atUnsafe(0), 32) != 1) throw new RuntimeException("RAND_bytes") val nonce = ByteVector.view(buf).toBase64 clientFirstBareWithNonce(nonce) @@ -27,7 +27,7 @@ private[message] trait ScramPlatform { this: Scram.type => throw new RuntimeException("EVP_get_digestbyname") val md = new Array[Byte](EVP_MAX_MD_SIZE) val mdLen = stackalloc[CUnsignedInt]() - if (openssl.HMAC(evpMd, key.toArrayUnsafe.at(0), key.size.toInt, str.toArrayUnsafe.at(0), str.size.toULong, md.at(0), mdLen) == null) + if (openssl.HMAC(evpMd, key.toArrayUnsafe.atUnsafe(0), key.size.toInt, str.toArrayUnsafe.atUnsafe(0), str.size.toULong, md.atUnsafe(0), mdLen) == null) throw new RuntimeException("HMAC") ByteVector.view(md, 0, (!mdLen).toInt) } @@ -38,7 +38,7 @@ private[message] trait ScramPlatform { this: Scram.type => val `type` = EVP_get_digestbyname(c"SHA256") if (`type` == null) throw new RuntimeException("EVP_get_digestbyname") - if (EVP_Digest(input.toArrayUnsafe.at(0), input.size.toULong, md.at(0), size, `type`, null) != 1) + if (EVP_Digest(input.toArrayUnsafe.atUnsafe(0), input.size.toULong, md.atUnsafe(0), size, `type`, null) != 1) throw new RuntimeException("EVP_Digest") ByteVector.view(md, 0, (!size).toInt) } @@ -48,7 +48,7 @@ private[message] trait ScramPlatform { this: Scram.type => if (digest == null) throw new RuntimeException("EVP_get_digestbyname") val out = new Array[Byte](32) - if (PKCS5_PBKDF2_HMAC(str.getBytes.at(0), str.length, salt.toArrayUnsafe.at(0), salt.size.toInt, iterations, digest, 32, out.at(0)) != 1) + if (PKCS5_PBKDF2_HMAC(str.getBytes.atUnsafe(0), str.length, salt.toArrayUnsafe.atUnsafe(0), salt.size.toInt, iterations, digest, 32, out.atUnsafe(0)) != 1) throw new RuntimeException("PKCS5_PBKDF2_HMAC") ByteVector.view(out) } From 7fa51d1082014618dfd9554a2d4c0da4d44b04d1 Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Thu, 7 Sep 2023 20:29:44 +0000 Subject: [PATCH 14/28] Update scala3-library, ... to 3.3.1 in series/0.6.x --- build.sbt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/build.sbt b/build.sbt index 24514500c..7292a7cb5 100644 --- a/build.sbt +++ b/build.sbt @@ -3,7 +3,7 @@ ThisBuild / tlBaseVersion := "0.6" // Our Scala versions. lazy val `scala-2.12` = "2.12.18" lazy val `scala-2.13` = "2.13.11" -lazy val `scala-3.0` = "3.3.0" +lazy val `scala-3.0` = "3.3.1" ThisBuild / scalaVersion := `scala-2.13` ThisBuild / crossScalaVersions := From 6a623a6c361a49f61bd76f5486c0ee68533b2fe2 Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Fri, 8 Sep 2023 12:11:13 +0000 Subject: [PATCH 15/28] Update sbt-scoverage to 2.0.9 in series/0.6.x --- project/plugins.sbt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/project/plugins.sbt b/project/plugins.sbt index 03123c0f3..cc72eebd4 100644 --- a/project/plugins.sbt +++ b/project/plugins.sbt @@ -7,7 +7,7 @@ addSbtPlugin("org.typelevel" % "sbt-typelevel" % "0.5.0") addSbtPlugin("org.typelevel" % "sbt-typelevel-site" % "0.5.0") addSbtPlugin("com.timushev.sbt" % "sbt-updates" % "0.6.4") addSbtPlugin("org.scalameta" % "sbt-mdoc" % "2.3.7") -addSbtPlugin("org.scoverage" % "sbt-scoverage" % "2.0.8") +addSbtPlugin("org.scoverage" % "sbt-scoverage" % "2.0.9") addSbtPlugin("org.scala-js" % "sbt-scalajs" % "1.13.2") addSbtPlugin("org.scala-native" % "sbt-scala-native" % "0.4.15") addSbtPlugin("com.armanbilge" % "sbt-scala-native-config-brew-github-actions" % "0.2.0-RC1") From 1db8aeeeae7ac497ce102b84f69da8ef6afccd9e Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Mon, 11 Sep 2023 04:20:18 +0000 Subject: [PATCH 16/28] Update sbt-typelevel, sbt-typelevel-site to 0.5.1 in series/0.6.x --- project/plugins.sbt | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/project/plugins.sbt b/project/plugins.sbt index cc72eebd4..fd979d0df 100644 --- a/project/plugins.sbt +++ b/project/plugins.sbt @@ -3,8 +3,8 @@ ThisBuild / libraryDependencySchemes ++= Seq( "org.scala-lang.modules" %% "scala-xml" % VersionScheme.Always ) -addSbtPlugin("org.typelevel" % "sbt-typelevel" % "0.5.0") -addSbtPlugin("org.typelevel" % "sbt-typelevel-site" % "0.5.0") +addSbtPlugin("org.typelevel" % "sbt-typelevel" % "0.5.1") +addSbtPlugin("org.typelevel" % "sbt-typelevel-site" % "0.5.1") addSbtPlugin("com.timushev.sbt" % "sbt-updates" % "0.6.4") addSbtPlugin("org.scalameta" % "sbt-mdoc" % "2.3.7") addSbtPlugin("org.scoverage" % "sbt-scoverage" % "2.0.9") From 58c01b7ad48bdf04ae09468b9b71d7517527828f Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Mon, 11 Sep 2023 04:20:59 +0000 Subject: [PATCH 17/28] Run prePR with sbt-typelevel Executed command: sbt tlPrePrBotHook --- .github/workflows/ci.yml | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index b7870aa28..afb89599c 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -35,7 +35,7 @@ jobs: timeout-minutes: 60 steps: - name: Checkout current branch (full) - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: fetch-depth: 0 @@ -114,7 +114,7 @@ jobs: runs-on: ${{ matrix.os }} steps: - name: Checkout current branch (full) - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: fetch-depth: 0 @@ -261,7 +261,7 @@ jobs: runs-on: ${{ matrix.os }} steps: - name: Checkout current branch (full) - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: fetch-depth: 0 @@ -299,7 +299,7 @@ jobs: runs-on: ${{ matrix.os }} steps: - name: Checkout current branch (fast) - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Setup Java (temurin@11) id: setup-java-temurin-11 @@ -324,7 +324,7 @@ jobs: runs-on: ${{ matrix.os }} steps: - name: Checkout current branch (full) - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: fetch-depth: 0 @@ -368,7 +368,7 @@ jobs: runs-on: ${{ matrix.os }} steps: - name: Checkout current branch (full) - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: fetch-depth: 0 From e0a49178fa94d1d5b48b7dc30518c4ab9c1f1a13 Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Mon, 11 Sep 2023 12:44:16 +0000 Subject: [PATCH 18/28] Update scala-library to 2.13.12 in series/0.6.x --- .github/workflows/ci.yml | 2 +- build.sbt | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index afb89599c..64c2bb82a 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -363,7 +363,7 @@ jobs: strategy: matrix: os: [ubuntu-latest] - scala: [2.13.11] + scala: [2.13.12] java: [temurin@11] runs-on: ${{ matrix.os }} steps: diff --git a/build.sbt b/build.sbt index 7292a7cb5..4f73814a4 100644 --- a/build.sbt +++ b/build.sbt @@ -2,7 +2,7 @@ ThisBuild / tlBaseVersion := "0.6" // Our Scala versions. lazy val `scala-2.12` = "2.12.18" -lazy val `scala-2.13` = "2.13.11" +lazy val `scala-2.13` = "2.13.12" lazy val `scala-3.0` = "3.3.1" ThisBuild / scalaVersion := `scala-2.13` From e61b971cb70bf9e8a091b638c7335084b8a14fd3 Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Mon, 11 Sep 2023 14:48:08 +0000 Subject: [PATCH 19/28] Add explicit types --- modules/core/shared/src/main/scala/util/Typer.scala | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/modules/core/shared/src/main/scala/util/Typer.scala b/modules/core/shared/src/main/scala/util/Typer.scala index 91461b327..ab2212de8 100644 --- a/modules/core/shared/src/main/scala/util/Typer.scala +++ b/modules/core/shared/src/main/scala/util/Typer.scala @@ -62,7 +62,7 @@ object Typer { val Static: Typer = new Typer { import Type._ - val strategy = Strategy.BuiltinsOnly + val strategy: Strategy = Strategy.BuiltinsOnly val staticByOid: Map[Int, Type] = Map( @@ -232,7 +232,7 @@ object Typer { (p.typeInfoMap, p.relInfoMap).mapN { (tim, rim) => Static orElse new Typer { - val strategy = Strategy.SearchPath + val strategy: Strategy = Strategy.SearchPath val nameToOid: Map[String, Int] = tim.map { case (k, v) => v.name -> k } From 40f2c66c25693e39082049b31801399727082166 Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Mon, 11 Sep 2023 21:04:33 +0000 Subject: [PATCH 20/28] Update sbt-typelevel, sbt-typelevel-site to 0.5.2 in series/0.6.x --- project/plugins.sbt | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/project/plugins.sbt b/project/plugins.sbt index fd979d0df..f336999e7 100644 --- a/project/plugins.sbt +++ b/project/plugins.sbt @@ -3,8 +3,8 @@ ThisBuild / libraryDependencySchemes ++= Seq( "org.scala-lang.modules" %% "scala-xml" % VersionScheme.Always ) -addSbtPlugin("org.typelevel" % "sbt-typelevel" % "0.5.1") -addSbtPlugin("org.typelevel" % "sbt-typelevel-site" % "0.5.1") +addSbtPlugin("org.typelevel" % "sbt-typelevel" % "0.5.2") +addSbtPlugin("org.typelevel" % "sbt-typelevel-site" % "0.5.2") addSbtPlugin("com.timushev.sbt" % "sbt-updates" % "0.6.4") addSbtPlugin("org.scalameta" % "sbt-mdoc" % "2.3.7") addSbtPlugin("org.scoverage" % "sbt-scoverage" % "2.0.9") From 03bee84eb08bcf3136407bcd5b7d26297645f85f Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Mon, 11 Sep 2023 21:09:17 +0000 Subject: [PATCH 21/28] Restore package object --- modules/core/shared/src/main/scala/package.scala | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/modules/core/shared/src/main/scala/package.scala b/modules/core/shared/src/main/scala/package.scala index c23e2129b..b108714dd 100644 --- a/modules/core/shared/src/main/scala/package.scala +++ b/modules/core/shared/src/main/scala/package.scala @@ -2,8 +2,6 @@ // This software is licensed under the MIT License (MIT). // For more information see LICENSE or https://opensource.org/licenses/MIT -package skunk - import cats.effect.Resource import org.typelevel.scalaccompat.annotation._ import org.typelevel.twiddles.TwiddleCompat @@ -126,8 +124,7 @@ import org.typelevel.twiddles.TwiddleCompat * @groupname Companions Companion Objects * @groupprio Companions 999 */ -@nowarn213("msg=package object inheritance is deprecated") -object `package` extends TwiddleCompat { // aka package object skunk, yes this actually works ... +package object skunk extends TwiddleCompat { // we can use this to defeat value discarding warnings for erasable proof terms private[skunk] def void(a: Any*): Unit = (a, ())._2 From eeb39e37bc6c26d91afe21bfc596c8f4df969fd5 Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Mon, 11 Sep 2023 21:12:47 +0000 Subject: [PATCH 22/28] Unused import --- modules/core/shared/src/main/scala/package.scala | 1 - 1 file changed, 1 deletion(-) diff --git a/modules/core/shared/src/main/scala/package.scala b/modules/core/shared/src/main/scala/package.scala index b108714dd..649b2ff29 100644 --- a/modules/core/shared/src/main/scala/package.scala +++ b/modules/core/shared/src/main/scala/package.scala @@ -3,7 +3,6 @@ // For more information see LICENSE or https://opensource.org/licenses/MIT import cats.effect.Resource -import org.typelevel.scalaccompat.annotation._ import org.typelevel.twiddles.TwiddleCompat /** From 621384aed687a21b3346725090dab59dc76891d1 Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Tue, 12 Sep 2023 19:21:08 +0000 Subject: [PATCH 23/28] Update fs2-core, fs2-io to 3.9.2 in series/0.6.x --- build.sbt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/build.sbt b/build.sbt index 4f73814a4..4cc2a32f0 100644 --- a/build.sbt +++ b/build.sbt @@ -59,7 +59,7 @@ ThisBuild / mimaBinaryIssueFilters ++= List( ) // This is used in a couple places -lazy val fs2Version = "3.9.1" +lazy val fs2Version = "3.9.2" lazy val natchezVersion = "0.3.3" // Global Settings From e303d94f26a7cf72ad3d3d1a2d0217f345ebfc7b Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Fri, 15 Sep 2023 16:27:07 +0000 Subject: [PATCH 24/28] Update sbt to 1.9.6 in series/0.6.x --- project/build.properties | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/project/build.properties b/project/build.properties index 304098715..27430827b 100644 --- a/project/build.properties +++ b/project/build.properties @@ -1 +1 @@ -sbt.version=1.9.4 +sbt.version=1.9.6 From 28145883cadfc06e8c55bf9d10dc65d5a0457407 Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Fri, 15 Sep 2023 20:55:35 +0000 Subject: [PATCH 25/28] Update junit-interface, munit to 1.0.0-M10 in series/0.6.x --- build.sbt | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/build.sbt b/build.sbt index 4cc2a32f0..1bf3378dc 100644 --- a/build.sbt +++ b/build.sbt @@ -169,8 +169,8 @@ lazy val tests = crossProject(JVMPlatform, JSPlatform, NativePlatform) .settings( tlFatalWarnings := false, libraryDependencies ++= Seq( - "org.scalameta" %%% "munit" % "1.0.0-M8", - "org.scalameta" % "junit-interface" % "1.0.0-M8", + "org.scalameta" %%% "munit" % "1.0.0-M10", + "org.scalameta" % "junit-interface" % "1.0.0-M10", "org.typelevel" %%% "scalacheck-effect-munit" % "2.0.0-M2", "org.typelevel" %%% "munit-cats-effect" % "2.0.0-M3", "org.typelevel" %%% "cats-free" % "2.10.0", From fca5abadc22abcd13c462cfaed0a4185f743cc0d Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Fri, 15 Sep 2023 20:55:41 +0000 Subject: [PATCH 26/28] Update sbt-typelevel, sbt-typelevel-site to 0.5.3 in series/0.6.x --- project/plugins.sbt | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/project/plugins.sbt b/project/plugins.sbt index f336999e7..3b2aa6ade 100644 --- a/project/plugins.sbt +++ b/project/plugins.sbt @@ -3,8 +3,8 @@ ThisBuild / libraryDependencySchemes ++= Seq( "org.scala-lang.modules" %% "scala-xml" % VersionScheme.Always ) -addSbtPlugin("org.typelevel" % "sbt-typelevel" % "0.5.2") -addSbtPlugin("org.typelevel" % "sbt-typelevel-site" % "0.5.2") +addSbtPlugin("org.typelevel" % "sbt-typelevel" % "0.5.3") +addSbtPlugin("org.typelevel" % "sbt-typelevel-site" % "0.5.3") addSbtPlugin("com.timushev.sbt" % "sbt-updates" % "0.6.4") addSbtPlugin("org.scalameta" % "sbt-mdoc" % "2.3.7") addSbtPlugin("org.scoverage" % "sbt-scoverage" % "2.0.9") From 65c169befc7b01999d9fb075748f32e1a811c042 Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Tue, 26 Sep 2023 17:34:35 +0000 Subject: [PATCH 27/28] Update sbt-scalajs, scalajs-compiler, ... to 1.14.0 in series/0.6.x --- project/plugins.sbt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/project/plugins.sbt b/project/plugins.sbt index f336999e7..c03d0adb3 100644 --- a/project/plugins.sbt +++ b/project/plugins.sbt @@ -8,6 +8,6 @@ addSbtPlugin("org.typelevel" % "sbt-typelevel-site" % "0.5.2") addSbtPlugin("com.timushev.sbt" % "sbt-updates" % "0.6.4") addSbtPlugin("org.scalameta" % "sbt-mdoc" % "2.3.7") addSbtPlugin("org.scoverage" % "sbt-scoverage" % "2.0.9") -addSbtPlugin("org.scala-js" % "sbt-scalajs" % "1.13.2") +addSbtPlugin("org.scala-js" % "sbt-scalajs" % "1.14.0") addSbtPlugin("org.scala-native" % "sbt-scala-native" % "0.4.15") addSbtPlugin("com.armanbilge" % "sbt-scala-native-config-brew-github-actions" % "0.2.0-RC1") From 6b8f2a687d2872f69372fd53897fe6f2a9c92aca Mon Sep 17 00:00:00 2001 From: "typelevel-steward[bot]" <106827141+typelevel-steward[bot]@users.noreply.github.com> Date: Thu, 28 Sep 2023 00:20:17 +0000 Subject: [PATCH 28/28] Update cats-effect to 3.5.2 in series/0.6.x --- build.sbt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/build.sbt b/build.sbt index 4cc2a32f0..5a633c6d5 100644 --- a/build.sbt +++ b/build.sbt @@ -110,7 +110,7 @@ lazy val core = crossProject(JVMPlatform, JSPlatform, NativePlatform) description := "Tagless, non-blocking data access library for Postgres.", libraryDependencies ++= Seq( "org.typelevel" %%% "cats-core" % "2.10.0", - "org.typelevel" %%% "cats-effect" % "3.5.1", + "org.typelevel" %%% "cats-effect" % "3.5.2", "co.fs2" %%% "fs2-core" % fs2Version, "co.fs2" %%% "fs2-io" % fs2Version, "org.scodec" %%% "scodec-bits" % "1.1.37",