Sample code for 30+ languages & platforms
Swift

Create a JWS Using ECDSA P-521 SHA-512

See more JSON Web Signatures (JWS) Examples

Creates and verifies a JSON Web Signature (JWS) that uses ECDSA P-521 SHA-512

Chilkat Swift Downloads

Swift

func chilkatTest() {
    var success: Bool = false

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

    // Note: This example requires Chilkat v9.5.0.66 or greater.

    // Use the following ECC key loaded from JWK format.
    let sbJwk = CkoStringBuilder()!
    sbJwk.append(value: "{\"kty\":\"EC\",")
    sbJwk.append(value: "\"crv\":\"P-521\",")
    sbJwk.append(value: "\"x\":\"AekpBQ8ST8a8VcfVOTNl353vSrDCLLJXmPk06wTjxrrjcBpXp5EOnYG_NjFZ6OvLFV1jSfS9tsz4qUxcWceqwQGk\",")
    sbJwk.append(value: "\"y\":\"ADSmRA43Z1DSNx_RvcLI87cdL07l6jQyyBXMoxVg_l2Th-x3S1WDhjDly79ajL4Kkd0AZMaZmh9ubmf63e3kyMj2\",")
    sbJwk.append(value: "\"d\":\"AY5pb7A0UFiB3RELSD64fTLOSV_jazdF7fLYyuTw8lOfRhWg6Y6rUrPAxerEzgdRhajnu0ferB0d53vM9mE15j2C\"")
    sbJwk.append(value: "}")

    let eccKey = CkoPrivateKey()!
    // Note: This example loads the ECDSA key from JWK format.  Any format can be loaded
    // into the private key object. (See the online reference documentation..)
    success = eccKey.loadJwk(jsonStr: sbJwk.getAsString())
    if success == false {
        print("\(eccKey.lastErrorText!)")
        return
    }

    // Create the JWS Protected Header
    let jwsProtHdr = CkoJsonObject()!
    jwsProtHdr.appendString(name: "alg", value: "ES512")

    let jws = CkoJws()!

    // Set the protected header:
    var signatureIndex: Int = 0
    jws.setProtectedHeader(index: signatureIndex, json: jwsProtHdr)

    // Set the ECC key:
    jws.setPrivateKey(index: signatureIndex, privKey: eccKey)

    // Set the payload.
    var bIncludeBom: Bool = false
    var payloadStr: String? = "In our village, folks say God crumbles up the old moon into stars."
    jws.setPayload(payload: payloadStr, charset: "utf-8", includeBom: bIncludeBom)

    // Create the JWS
    // By default, the compact serialization is used.
    var jwsCompact: String? = jws.create()
    if jws.lastMethodSuccess == false {
        print("\(jws.lastErrorText!)")
        return
    }

    print("JWS: \(jwsCompact!)")

    // Note: ECC signatures use random values, so the output will be different each time a signature is produced.
    // sample output:
    // JWS: eyJhbGciOiJFUzUxMiJ9.SW4gb3VyIHZpbGxhZ2UsIGZvbGtzIHNheSBHb2QgY3J1bWJsZXMgdXAgdGhlIG9sZCBtb29uIGludG8gc3RhcnMu.AFOnOtZ8UTp-ed1PfLfXxwGU7zT_jnmGGxew-d1CP6SfKa5RUhav5mF4szhSof22JaoQ742VIa0eZ0s1rhBnj8y6APr6g6vKzIpYZlJsnjzjUwAjDQOLmcsjxrrRfATh-NEv7G0Z9FrjdJasS44tCG2EnG6aT2TW-sPG0dy5o9jUWCzi

    // Now load the JWS, validate, and recover the original text.
    let jws2 = CkoJws()!

    // Load the JWS.
    success = jws2.load(jwsStr: jwsCompact)

    let eccPubKey = CkoPublicKey()!
    eccKey.toPublicKey(pubKey: eccPubKey)

    // Set the ECC public key used for validation.
    signatureIndex = 0
    jws2.setPublicKey(index: signatureIndex, pubKey: eccPubKey)

    // Validate the 1st (and only) signature at index 0..
    var v: Int = jws2.validate(index: signatureIndex).intValue
    if v < 0 {
        // Perhaps Chilkat was not unlocked or the trial expired..
        print("Method call failed for some other reason.")
        print("\(jws2.lastErrorText!)")
        return
    }

    if v == 0 {
        print("Invalid signature.  The ECC key was incorrect, the JWS was invalid, or both.")
        return
    }

    // If we get here, the signature was validated..
    print("Signature validated.")

    // Recover the original content:
    print("\(jws2.getPayload(charset: "utf-8")!)")

    // Examine the protected header:
    let joseHeader = CkoJsonObject()!
    jws2.getProtectedH(index: signatureIndex, json: joseHeader)
    joseHeader.emitCompact = false

    print("Protected (JOSE) header:")
    print("\(joseHeader.emit()!)")

    // Output:
    // 	Signature validated.
    // 	In our village, folks say God crumbles up the old moon into stars.
    // 	Protected (JOSE) header:
    // 	{
    // 	  "alg": "ES512"
    // 	}

}