Sample code for 30+ languages & platforms
Swift

bitzlato.com whoami

See more JSON Web Token (JWT) Examples

Demonstrates sending a request to the bitzlato.com whoami endpoint using an ES256 JWT token for authentication.

Chilkat Swift Downloads

Swift

func chilkatTest() {
    var success: Bool = false

    // This example requires the Chilkat API to have been previously unlocked.
    // See Global Unlock Sample for sample code.

    //  Use the following ECC key loaded from JWK format.
    let jwk = CkoJsonObject()!
    success = jwk.updateString(jsonPath: "kty", value: "EC")
    success = jwk.updateString(jsonPath: "crv", value: "P-256")
    success = jwk.updateString(jsonPath: "x", value: "...")
    success = jwk.updateString(jsonPath: "y", value: "...")
    success = jwk.updateString(jsonPath: "d", value: "...")

    let eccKey = CkoPrivateKey()!
    success = eccKey.loadJwk(jsonStr: jwk.emit())
    if success == false {
        print("\(eccKey.lastErrorText!)")
        return
    }

    let jwt = CkoJwt()!

    // Build the JOSE header
    let jose = CkoJsonObject()!
    success = jose.appendString(name: "format", value: "compact")
    success = jose.appendString(name: "alg", value: "ES256")

    // Now build the JWT claims (also known as the payload)

    // Our JWT claims will contain members as shown here:

    // 	{
    // 	  "email":"your_email@example.com",
    // 	  "aud":"usr",
    // 	  "iat":"1588286154",
    // 	  "jti":"555D9123"
    // 	}

    let claims = CkoJsonObject()!
    claims.appendString(name: "jti", value: "555D9123")
    claims.appendString(name: "email", value: "your_email@example.com")

    // Set the timestamp of when the JWT was created to now minus 60 seconds
    var curDateTime: Int = jwt.genNumericDate(numSecOffset: -60).intValue
    success = claims.addInt(at: -1, name: "iat", value: curDateTime)

    // Set the "not process before" timestamp to now minus 60 seconds
    success = claims.addInt(at: -1, name: "nbf", value: curDateTime)

    // Set the timestamp defining an expiration time (end time) for the token
    // to be now + 1 hour (3600 seconds)
    success = claims.addInt(at: -1, name: "exp", value: curDateTime + 3600)

    claims.appendString(name: "aud", value: "usr")

    // Produce the smallest possible JWT:
    jwt.autoCompact = true

    // Create the JWT token.  This is where the RSA signature is created.
    var jwt_token: String? = jwt.createPk(header: jose.emit(), payload: claims.emit(), key: eccKey)

    print("\(jwt_token!)")

    // Send the HTTPS GET with the jwt_token used for Authorization.
    let http = CkoHttp()!
    http.authToken = jwt_token
    var responseStr: String? = http.quickGetStr(url: "https://bitzlato.com/api/auth/whoami")
    if http.lastMethodSuccess == false {
        print("\(http.lastErrorText!)")
        return
    }

    print("status code = \(http.lastStatus.intValue)")
    print("\(responseStr!)")

}