roby
04/16/2023, 11:18 PMval url = "<https://steamcommunity.com/openid/login>?\n" +
        "openid.claimed_id=<http://specs.openid.net/auth/2.0/identifier_select&>\n" +
        "openid.identity=<http://specs.openid.net/auth/2.0/identifier_select&>\n" +
        "openid.mode=checkid_setup&\n" +
        "openid.ns=<http://specs.openid.net/auth/2.0&>\n" +
        "openid.realm=<http://localhost:8082>&\n" +
        "openid.return_to=<http://localhost:8082/callback>"
val steamOAuthServerSettings = OAuthServerSettings.OAuth2ServerSettings(
    name = "steam-oauth",
    authorizeUrl = url,
    accessTokenUrl = url,
    clientId = "xxx",
    clientSecret = "xxx",
    defaultScopes = listOf("openid"),
    requestMethod = HttpMethod.Get,
    accessTokenRequiresBasicAuth = false,
)
fun main() {
    embeddedServer(Netty, port = 8082, host = "0.0.0.0", module = Application::module)
        .start(wait = true)
}
fun Application.module() {
    install(Authentication) {
        oauth("steam-oauth") {
            client = HttpClient()
            providerLookup = { steamOAuthServerSettings }
            urlProvider = { "<http://localhost:8082/callback>" }
        }
    }
    install(Sessions) {
        cookie<String>("user_session")
    }
    routing {
        authenticate("steam-oauth") {
            get("/login") {
                // Redirects to 'authorizeUrl' automatically
            }
            get("/callback") {
                val principal: OAuthAccessTokenResponse.OAuth2? = call.principal()
                call.sessions.set("somecookie")
                println("principal state ${principal?.state}")
                call.respondRedirect("<http://localhost:8082/oi>")
            }
        }
        get("/") {
            call.respondHtml {
                body {
                    p {
                        a("/login") { +"Login with Steam" }
                    }
                }
            }
        }
        get("/{path}") {
            val userSession: String? = call.sessions.get()
            println("USER SESSH = $userSession")
            if (userSession != null) {
                call.respondText("Hello, ${userSession}!")
            } else {
                val redirectUrl = URLBuilder("<http://0.0.0.0:8082/login>").run {
                    parameters.append("redirectUrl", call.request.uri)
                    build()
                }
                call.respondRedirect(redirectUrl)
            }
        }
    }
}Andrew O'Hara
04/16/2023, 11:49 PM