Sample code for 30+ languages & platforms
Go

Isabel Connect Revoke Access Token

See more Ibanity Examples

Revokes an access token.

Chilkat Go Downloads

Go
    success := false

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

    http := chilkat.NewHttp()

    // // Implements the following CURL command:
    // 
    // curl -X POST https://api.ibanity.com/isabel-connect/oauth2/revoke \
    // --cert certificate.pem:qwertyuiop1 \
    // --key private_key.pem  \
    // -H "Content-Type: application/x-www-form-urlencoded" \
    // -H "Accept: application/vnd.api+json"  \
    // -d token=8787 \
    // -d client_id=valid_client_id \
    // -d client_secret=valid_client_secret 

    // Ibanity provides the certificate + private key in PFX format.  This example will use the .pfx instead of the pair of PEM files.
    // (It is also possible to implement using Chilkat with the PEM files, but PFX is easier.)
    cert := chilkat.NewCert()
    success = cert.LoadPfxFile("qa_data/pfx/my_ibanity_certificate.pfx","my_pfx_password")
    if success == false {
        fmt.Println(cert.LastErrorText())
        http.DisposeHttp()
        cert.DisposeCert()
        return
    }

    success = http.SetSslClientCert(cert)
    if success == false {
        fmt.Println(http.LastErrorText())
        http.DisposeHttp()
        cert.DisposeCert()
        return
    }

    req := chilkat.NewHttpRequest()
    req.SetHttpVerb("POST")
    req.SetPath("/isabel-connect/oauth2/revoke")
    req.SetContentType("application/x-www-form-urlencoded")

    // Load the previously obtained access token.
    jsonToken := chilkat.NewJsonObject()
    success = jsonToken.LoadFile("qa_data/tokens/isabel_access_token.json")
    if success == false {
        fmt.Println("No existing access token.")
        http.DisposeHttp()
        cert.DisposeCert()
        req.DisposeHttpRequest()
        jsonToken.DisposeJsonObject()
        return
    }

    req.AddParam("token",*jsonToken.StringOf("access_token"))

    // Note: For sandbox testing, we literally want to use the strings
    // "valid_client_id", and "valid_client_secret".
    // For the live app, you would replace these with actual values.
    req.AddParam("client_id","valid_client_id")
    req.AddParam("client_secret","valid_client_secret")

    req.AddHeader("Accept","application/vnd.api+json")

    resp := chilkat.NewHttpResponse()
    success = http.HttpReq("https://api.ibanity.com/isabel-connect/oauth2/revoke",req,resp)
    if success == false {
        fmt.Println(http.LastErrorText())
        http.DisposeHttp()
        cert.DisposeCert()
        req.DisposeHttpRequest()
        jsonToken.DisposeJsonObject()
        resp.DisposeHttpResponse()
        return
    }

    sbResponseBody := chilkat.NewStringBuilder()
    resp.GetBodySb(sbResponseBody)

    respStatusCode := resp.StatusCode()
    fmt.Println("Response Status Code = ", respStatusCode)
    if respStatusCode >= 400 {
        fmt.Println("Response Header:")
        fmt.Println(resp.Header())
        fmt.Println("Failed.")
        http.DisposeHttp()
        cert.DisposeCert()
        req.DisposeHttpRequest()
        jsonToken.DisposeJsonObject()
        resp.DisposeHttpResponse()
        sbResponseBody.DisposeStringBuilder()
        return
    }

    fmt.Println("Response Body:")
    fmt.Println(*sbResponseBody.GetAsString())

    // If successful, the response status code = 200, and the response body is "{}"

    http.DisposeHttp()
    cert.DisposeCert()
    req.DisposeHttpRequest()
    jsonToken.DisposeJsonObject()
    resp.DisposeHttpResponse()
    sbResponseBody.DisposeStringBuilder()