Skip to content

Instantly share code, notes, and snippets.

View ghostdogpr's full-sized avatar

Pierre Ricadat ghostdogpr

View GitHub Profile
@ghostdogpr
ghostdogpr / ox.sc
Last active June 28, 2024 06:25
Caliban + Ox demo
//> using dep com.github.ghostdogpr::caliban-tapir:2.8.0
//> using dep com.softwaremill.ox::core:0.2.2
//> using dep com.softwaremill.sttp.tapir::tapir-jsoniter-scala:1.10.10
//> using dep com.softwaremill.sttp.tapir::tapir-netty-server-sync:1.10.10
import caliban.*
import caliban.interop.tapir.*
import caliban.schema.Schema
import _root_.ox.*
import scala.concurrent.duration.*
@ghostdogpr
ghostdogpr / rbac.sc
Last active June 7, 2024 06:47
Role-based access control with Caliban
//> using dep com.github.ghostdogpr::caliban-quick:2.7.1
import caliban.*
import caliban.CalibanError.*
import caliban.Value.StringValue
import caliban.execution.FieldInfo
import caliban.parsing.adt.Directive
import caliban.quick.*
import caliban.schema.Annotations.*
import caliban.schema.Schema
[
{
"jmhVersion" : "1.37",
"benchmark" : "caliban.ComplexQueryBenchmark.runCaliban",
"mode" : "thrpt",
"threads" : 1,
"forks" : 1,
"jvm" : "/Users/pierre/Library/Java/JavaVirtualMachines/temurin-21.0.3/Contents/Home/bin/java",
"jvmArgs" : [
],
//> using dep com.github.ghostdogpr::caliban-quick:2.5.0
// 1. Defining the schema
enum Origin {
case EARTH, MARS, BELT
}
case class Character(name: String, nicknames: List[String], origin: Origin)
@ghostdogpr
ghostdogpr / caliban-cli.sc
Last active May 12, 2023 07:29
Test scala cli
//> using dep com.github.ghostdogpr::caliban:2.2.0
import caliban._
import caliban.schema._
case class Queries(books: List[Book]) derives Schema.SemiAuto
case class Book(id: Int, name: String) derives Schema.SemiAuto
val api = graphQL(RootResolver(Queries(Nil)))
@ghostdogpr
ghostdogpr / Derivation.scala
Created July 10, 2022 01:28
Infinite loop in function body
import scala.deriving.Mirror
import scala.compiletime._
trait Schema[T]
object Schema {
implicit val stringSchema: Schema[String] = new Schema[String] {}
implicit def listSchema[A](implicit ev: Schema[A]): Schema[List[A]] = new Schema[List[A]] {}
implicit def mapSchema[A, B](implicit evA: Schema[A], evB: Schema[B]): Schema[Map[A, B]] =
new Schema[Map[A, B]] {}
package caliban
import caliban.GraphQL._
import zio.ZIO
import zio.console.putStrLn
import zio.zquery._
object Test2 extends zio.App {
case class User(firstName: UQuery[String], lastName: UQuery[String], age: UQuery[Int])
package caliban
import caliban.GraphQL._
import zio.console.putStrLn
import zio.ZIO
import zio.zquery._
object Test extends zio.App {
case class User(firstName: UQuery[String], lastName: UQuery[String], age: UQuery[Int])
import scala.deriving._
import scala.quoted._
import scala.quoted.matching._
import scala.compiletime._
trait Show[T] {
def show(x: T): String
}
object Show {
@ghostdogpr
ghostdogpr / caliban-client.scala
Last active February 8, 2020 00:06
Early draft for caliban-client. Feedback welcome!
// Step 1:
// Code generation creates helpers from a GraphQL schema
// Character.* and Queries.* here are auto-generated
// Step 2:
// Build your own queries combining those helpers
val character =
(Character.name ~
Character.nicknames ~
Character.origin).mapN(CharacterView)