Chilkat Online Tools

DescribeCertificate Swift Example

AWS Certificate Manager

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

    let rest = CkoRest()
    var success: Bool

    let authAws = CkoAuthAws()
    authAws.AccessKey = "AWS_ACCESS_KEY"
    authAws.SecretKey = "AWS_SECRET_KEY"

    // Don't forget to change the region to your particular region. (Also make the same change in the call to Connect below.)
    authAws.Region = "us-west-2"
    authAws.ServiceName = "acm"
    // SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
    rest.SetAuthAws(authAws)

    // URL: https://acm.us-west-2.amazonaws.com/
    // Use the same region as specified above.
    success = rest.Connect("acm.us-west-2.amazonaws.com", port: 443, tls: true, autoReconnect: true)
    if success != true {
        print("ConnectFailReason: \(rest.ConnectFailReason.intValue)")
        print("\(rest.LastErrorText)")
        return
    }

    // The following code creates the JSON request body.
    // The JSON created by this code is shown below.

    // Use this online tool to generate code from sample JSON:
    // Generate Code to Create JSON

    let json = CkoJsonObject()
    json.UpdateString("CertificateArn", value: "string")

    // The JSON request body created by the above code:

    // {
    //   "CertificateArn": "string"
    // }

    rest.AddHeader("Content-Type", value: "application/x-amz-json-1.1")
    rest.AddHeader("X-Amz-Target", value: "CertificateManager.DescribeCertificate")

    let sbRequestBody = CkoStringBuilder()
    json.EmitSb(sbRequestBody)
    let sbResponseBody = CkoStringBuilder()
    success = rest.FullRequestSb("POST", uriPath: "/", requestBody: sbRequestBody, responseBody: sbResponseBody)
    if success != true {
        print("\(rest.LastErrorText)")
        return
    }

    var respStatusCode: Int = rest.ResponseStatusCode.intValue
    print("response status code = \(respStatusCode)")
    if respStatusCode != 200 {
        print("Response Header:")
        print("\(rest.ResponseHeader)")
        print("Response Body:")
        print("\(sbResponseBody.GetAsString())")
        return
    }

    let jResp = CkoJsonObject()
    jResp.LoadSb(sbResponseBody)

    // The following code parses the JSON response.
    // A sample JSON response is shown below the sample code.

    // Use this online tool to generate parsing code from sample JSON:
    // Generate Parsing Code from JSON

    var Name: String?
    var ResourceRecordType: String?
    var Value: String?
    var ValidationDomain: String?
    var ValidationMethod: String?
    var ValidationStatus: String?
    var j: Int
    var count_j: Int
    var strVal: String?
    var OID: String?
    var ResourceRecordName: String?
    var ResourceRecordValue: String?

    var CertificateArn: String? = jResp.StringOf("Certificate.CertificateArn")
    var CertificateAuthorityArn: String? = jResp.StringOf("Certificate.CertificateAuthorityArn")
    var CreatedAt: Int = jResp.IntOf("Certificate.CreatedAt").intValue
    var DomainName: String? = jResp.StringOf("Certificate.DomainName")
    var FailureReason: String? = jResp.StringOf("Certificate.FailureReason")
    var ImportedAt: Int = jResp.IntOf("Certificate.ImportedAt").intValue
    var IssuedAt: Int = jResp.IntOf("Certificate.IssuedAt").intValue
    var Issuer: String? = jResp.StringOf("Certificate.Issuer")
    var KeyAlgorithm: String? = jResp.StringOf("Certificate.KeyAlgorithm")
    var NotAfter: Int = jResp.IntOf("Certificate.NotAfter").intValue
    var NotBefore: Int = jResp.IntOf("Certificate.NotBefore").intValue
    var CertificateTransparencyLoggingPreference: String? = jResp.StringOf("Certificate.Options.CertificateTransparencyLoggingPreference")
    var RenewalEligibility: String? = jResp.StringOf("Certificate.RenewalEligibility")
    var RenewalStatus: String? = jResp.StringOf("Certificate.RenewalSummary.RenewalStatus")
    var RenewalStatusReason: String? = jResp.StringOf("Certificate.RenewalSummary.RenewalStatusReason")
    var UpdatedAt: Int = jResp.IntOf("Certificate.RenewalSummary.UpdatedAt").intValue
    var RevocationReason: String? = jResp.StringOf("Certificate.RevocationReason")
    var RevokedAt: Int = jResp.IntOf("Certificate.RevokedAt").intValue
    var Serial: String? = jResp.StringOf("Certificate.Serial")
    var SignatureAlgorithm: String? = jResp.StringOf("Certificate.SignatureAlgorithm")
    var Status: String? = jResp.StringOf("Certificate.Status")
    var Subject: String? = jResp.StringOf("Certificate.Subject")
    var v_Type: String? = jResp.StringOf("Certificate.Type")
    var i: Int = 0
    var count_i: Int = jResp.SizeOfArray("Certificate.DomainValidationOptions").intValue
    while i < count_i {
        jResp.I = i
        DomainName = jResp.StringOf("Certificate.DomainValidationOptions[i].DomainName")
        Name = jResp.StringOf("Certificate.DomainValidationOptions[i].ResourceRecord.Name")
        ResourceRecordType = jResp.StringOf("Certificate.DomainValidationOptions[i].ResourceRecord.Type")
        Value = jResp.StringOf("Certificate.DomainValidationOptions[i].ResourceRecord.Value")
        ValidationDomain = jResp.StringOf("Certificate.DomainValidationOptions[i].ValidationDomain")
        ValidationMethod = jResp.StringOf("Certificate.DomainValidationOptions[i].ValidationMethod")
        ValidationStatus = jResp.StringOf("Certificate.DomainValidationOptions[i].ValidationStatus")
        j = 0
        count_j = jResp.SizeOfArray("Certificate.DomainValidationOptions[i].ValidationEmails").intValue
        while j < count_j {
            jResp.J = j
            strVal = jResp.StringOf("Certificate.DomainValidationOptions[i].ValidationEmails[j]")
            j = j + 1
        }

        i = i + 1
    }

    i = 0
    count_i = jResp.SizeOfArray("Certificate.ExtendedKeyUsages").intValue
    while i < count_i {
        jResp.I = i
        Name = jResp.StringOf("Certificate.ExtendedKeyUsages[i].Name")
        OID = jResp.StringOf("Certificate.ExtendedKeyUsages[i].OID")
        i = i + 1
    }

    i = 0
    count_i = jResp.SizeOfArray("Certificate.InUseBy").intValue
    while i < count_i {
        jResp.I = i
        strVal = jResp.StringOf("Certificate.InUseBy[i]")
        i = i + 1
    }

    i = 0
    count_i = jResp.SizeOfArray("Certificate.KeyUsages").intValue
    while i < count_i {
        jResp.I = i
        Name = jResp.StringOf("Certificate.KeyUsages[i].Name")
        i = i + 1
    }

    i = 0
    count_i = jResp.SizeOfArray("Certificate.RenewalSummary.DomainValidationOptions").intValue
    while i < count_i {
        jResp.I = i
        DomainName = jResp.StringOf("Certificate.RenewalSummary.DomainValidationOptions[i].DomainName")
        ResourceRecordName = jResp.StringOf("Certificate.RenewalSummary.DomainValidationOptions[i].ResourceRecord.Name")
        ResourceRecordType = jResp.StringOf("Certificate.RenewalSummary.DomainValidationOptions[i].ResourceRecord.Type")
        ResourceRecordValue = jResp.StringOf("Certificate.RenewalSummary.DomainValidationOptions[i].ResourceRecord.Value")
        ValidationDomain = jResp.StringOf("Certificate.RenewalSummary.DomainValidationOptions[i].ValidationDomain")
        ValidationMethod = jResp.StringOf("Certificate.RenewalSummary.DomainValidationOptions[i].ValidationMethod")
        ValidationStatus = jResp.StringOf("Certificate.RenewalSummary.DomainValidationOptions[i].ValidationStatus")
        j = 0
        count_j = jResp.SizeOfArray("Certificate.RenewalSummary.DomainValidationOptions[i].ValidationEmails").intValue
        while j < count_j {
            jResp.J = j
            strVal = jResp.StringOf("Certificate.RenewalSummary.DomainValidationOptions[i].ValidationEmails[j]")
            j = j + 1
        }

        i = i + 1
    }

    i = 0
    count_i = jResp.SizeOfArray("Certificate.SubjectAlternativeNames").intValue
    while i < count_i {
        jResp.I = i
        strVal = jResp.StringOf("Certificate.SubjectAlternativeNames[i]")
        i = i + 1
    }

    // A sample JSON response body parsed by the above code:

    // {
    //   "Certificate": {
    //     "CertificateArn": "string",
    //     "CertificateAuthorityArn": "string",
    //     "CreatedAt": number,
    //     "DomainName": "string",
    //     "DomainValidationOptions": [
    //       {
    //         "DomainName": "string",
    //         "ResourceRecord": {
    //           "Name": "string",
    //           "Type": "string",
    //           "Value": "string"
    //         },
    //         "ValidationDomain": "string",
    //         "ValidationEmails": [
    //           "string"
    //         ],
    //         "ValidationMethod": "string",
    //         "ValidationStatus": "string"
    //       }
    //     ],
    //     "ExtendedKeyUsages": [
    //       {
    //         "Name": "string",
    //         "OID": "string"
    //       }
    //     ],
    //     "FailureReason": "string",
    //     "ImportedAt": number,
    //     "InUseBy": [
    //       "string"
    //     ],
    //     "IssuedAt": number,
    //     "Issuer": "string",
    //     "KeyAlgorithm": "string",
    //     "KeyUsages": [
    //       {
    //         "Name": "string"
    //       }
    //     ],
    //     "NotAfter": number,
    //     "NotBefore": number,
    //     "Options": {
    //       "CertificateTransparencyLoggingPreference": "string"
    //     },
    //     "RenewalEligibility": "string",
    //     "RenewalSummary": {
    //       "DomainValidationOptions": [
    //         {
    //           "DomainName": "string",
    //           "ResourceRecord": {
    //             "Name": "string",
    //             "Type": "string",
    //             "Value": "string"
    //           },
    //           "ValidationDomain": "string",
    //           "ValidationEmails": [
    //             "string"
    //           ],
    //           "ValidationMethod": "string",
    //           "ValidationStatus": "string"
    //         }
    //       ],
    //       "RenewalStatus": "string",
    //       "RenewalStatusReason": "string",
    //       "UpdatedAt": number
    //     },
    //     "RevocationReason": "string",
    //     "RevokedAt": number,
    //     "Serial": "string",
    //     "SignatureAlgorithm": "string",
    //     "Status": "string",
    //     "Subject": "string",
    //     "SubjectAlternativeNames": [
    //       "string"
    //     ],
    //     "Type": "string"
    //   }
    // }

}