Chilkat Online Tools

DescribeCertificateAuthority Swift Example

AWS Private CA

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-pca"
    // SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
    rest.SetAuthAws(authAws)

    // URL: https://acm-pca.us-west-2.amazonaws.com/
    // Use the same region as specified above.
    success = rest.Connect("acm-pca.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("CertificateAuthorityArn", value: "string")

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

    // {
    //   "CertificateAuthorityArn": "string"
    // }

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

    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 DirectoryNameCommonName: String?
    var DirectoryNameCountry: String?
    var DirectoryNameDistinguishedNameQualifier: String?
    var DirectoryNameGenerationQualifier: String?
    var DirectoryNameGivenName: String?
    var DirectoryNameInitials: String?
    var DirectoryNameLocality: String?
    var DirectoryNameOrganization: String?
    var DirectoryNameOrganizationalUnit: String?
    var DirectoryNamePseudonym: String?
    var DirectoryNameSerialNumber: String?
    var DirectoryNameState: String?
    var DirectoryNameSurname: String?
    var DirectoryNameTitle: String?
    var DnsName: String?
    var NameAssigner: String?
    var PartyName: String?
    var IpAddress: String?
    var TypeId: String?
    var Value: String?
    var RegisteredId: String?
    var Rfc822Name: String?
    var UniformResourceIdentifier: String?
    var AccessMethodType: String?
    var CustomObjectIdentifier: String?

    var Arn: String? = jResp.StringOf("CertificateAuthority.Arn")
    var CRLSign: Int = jResp.IntOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.KeyUsage.CRLSign").intValue
    var DataEncipherment: Int = jResp.IntOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.KeyUsage.DataEncipherment").intValue
    var DecipherOnly: Int = jResp.IntOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.KeyUsage.DecipherOnly").intValue
    var DigitalSignature: Int = jResp.IntOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.KeyUsage.DigitalSignature").intValue
    var EncipherOnly: Int = jResp.IntOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.KeyUsage.EncipherOnly").intValue
    var KeyAgreement: Int = jResp.IntOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.KeyUsage.KeyAgreement").intValue
    var KeyCertSign: Int = jResp.IntOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.KeyUsage.KeyCertSign").intValue
    var KeyEncipherment: Int = jResp.IntOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.KeyUsage.KeyEncipherment").intValue
    var NonRepudiation: Int = jResp.IntOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.KeyUsage.NonRepudiation").intValue
    var KeyAlgorithm: String? = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.KeyAlgorithm")
    var SigningAlgorithm: String? = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.SigningAlgorithm")
    var CommonName: String? = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.Subject.CommonName")
    var Country: String? = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.Subject.Country")
    var DistinguishedNameQualifier: String? = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.Subject.DistinguishedNameQualifier")
    var GenerationQualifier: String? = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.Subject.GenerationQualifier")
    var GivenName: String? = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.Subject.GivenName")
    var Initials: String? = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.Subject.Initials")
    var Locality: String? = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.Subject.Locality")
    var Organization: String? = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.Subject.Organization")
    var OrganizationalUnit: String? = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.Subject.OrganizationalUnit")
    var Pseudonym: String? = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.Subject.Pseudonym")
    var SerialNumber: String? = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.Subject.SerialNumber")
    var State: String? = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.Subject.State")
    var Surname: String? = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.Subject.Surname")
    var Title: String? = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.Subject.Title")
    var CreatedAt: Int = jResp.IntOf("CertificateAuthority.CreatedAt").intValue
    var FailureReason: String? = jResp.StringOf("CertificateAuthority.FailureReason")
    var KeyStorageSecurityStandard: String? = jResp.StringOf("CertificateAuthority.KeyStorageSecurityStandard")
    var LastStateChangeAt: Int = jResp.IntOf("CertificateAuthority.LastStateChangeAt").intValue
    var NotAfter: Int = jResp.IntOf("CertificateAuthority.NotAfter").intValue
    var NotBefore: Int = jResp.IntOf("CertificateAuthority.NotBefore").intValue
    var OwnerAccount: String? = jResp.StringOf("CertificateAuthority.OwnerAccount")
    var RestorableUntil: Int = jResp.IntOf("CertificateAuthority.RestorableUntil").intValue
    var CustomCname: String? = jResp.StringOf("CertificateAuthority.RevocationConfiguration.CrlConfiguration.CustomCname")
    var Enabled: Int = jResp.IntOf("CertificateAuthority.RevocationConfiguration.CrlConfiguration.Enabled").intValue
    var ExpirationInDays: Int = jResp.IntOf("CertificateAuthority.RevocationConfiguration.CrlConfiguration.ExpirationInDays").intValue
    var S3BucketName: String? = jResp.StringOf("CertificateAuthority.RevocationConfiguration.CrlConfiguration.S3BucketName")
    var S3ObjectAcl: String? = jResp.StringOf("CertificateAuthority.RevocationConfiguration.CrlConfiguration.S3ObjectAcl")
    var OcspConfigurationEnabled: Int = jResp.IntOf("CertificateAuthority.RevocationConfiguration.OcspConfiguration.Enabled").intValue
    var OcspCustomCname: String? = jResp.StringOf("CertificateAuthority.RevocationConfiguration.OcspConfiguration.OcspCustomCname")
    var Serial: String? = jResp.StringOf("CertificateAuthority.Serial")
    var Status: String? = jResp.StringOf("CertificateAuthority.Status")
    var v_Type: String? = jResp.StringOf("CertificateAuthority.Type")
    var i: Int = 0
    var count_i: Int = jResp.SizeOfArray("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess").intValue
    while i < count_i {
        jResp.I = i
        DirectoryNameCommonName = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.DirectoryName.CommonName")
        DirectoryNameCountry = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.DirectoryName.Country")
        DirectoryNameDistinguishedNameQualifier = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.DirectoryName.DistinguishedNameQualifier")
        DirectoryNameGenerationQualifier = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.DirectoryName.GenerationQualifier")
        DirectoryNameGivenName = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.DirectoryName.GivenName")
        DirectoryNameInitials = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.DirectoryName.Initials")
        DirectoryNameLocality = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.DirectoryName.Locality")
        DirectoryNameOrganization = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.DirectoryName.Organization")
        DirectoryNameOrganizationalUnit = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.DirectoryName.OrganizationalUnit")
        DirectoryNamePseudonym = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.DirectoryName.Pseudonym")
        DirectoryNameSerialNumber = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.DirectoryName.SerialNumber")
        DirectoryNameState = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.DirectoryName.State")
        DirectoryNameSurname = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.DirectoryName.Surname")
        DirectoryNameTitle = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.DirectoryName.Title")
        DnsName = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.DnsName")
        NameAssigner = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.EdiPartyName.NameAssigner")
        PartyName = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.EdiPartyName.PartyName")
        IpAddress = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.IpAddress")
        TypeId = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.OtherName.TypeId")
        Value = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.OtherName.Value")
        RegisteredId = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.RegisteredId")
        Rfc822Name = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.Rfc822Name")
        UniformResourceIdentifier = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessLocation.UniformResourceIdentifier")
        AccessMethodType = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessMethod.AccessMethodType")
        CustomObjectIdentifier = jResp.StringOf("CertificateAuthority.CertificateAuthorityConfiguration.CsrExtensions.SubjectInformationAccess[i].AccessMethod.CustomObjectIdentifier")
        i = i + 1
    }

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

    // {
    //   "CertificateAuthority": {
    //     "Arn": "string",
    //     "CertificateAuthorityConfiguration": {
    //       "CsrExtensions": {
    //         "KeyUsage": {
    //           "CRLSign": boolean,
    //           "DataEncipherment": boolean,
    //           "DecipherOnly": boolean,
    //           "DigitalSignature": boolean,
    //           "EncipherOnly": boolean,
    //           "KeyAgreement": boolean,
    //           "KeyCertSign": boolean,
    //           "KeyEncipherment": boolean,
    //           "NonRepudiation": boolean
    //         },
    //         "SubjectInformationAccess": [
    //           {
    //             "AccessLocation": {
    //               "DirectoryName": {
    //                 "CommonName": "string",
    //                 "Country": "string",
    //                 "DistinguishedNameQualifier": "string",
    //                 "GenerationQualifier": "string",
    //                 "GivenName": "string",
    //                 "Initials": "string",
    //                 "Locality": "string",
    //                 "Organization": "string",
    //                 "OrganizationalUnit": "string",
    //                 "Pseudonym": "string",
    //                 "SerialNumber": "string",
    //                 "State": "string",
    //                 "Surname": "string",
    //                 "Title": "string"
    //               },
    //               "DnsName": "string",
    //               "EdiPartyName": {
    //                 "NameAssigner": "string",
    //                 "PartyName": "string"
    //               },
    //               "IpAddress": "string",
    //               "OtherName": {
    //                 "TypeId": "string",
    //                 "Value": "string"
    //               },
    //               "RegisteredId": "string",
    //               "Rfc822Name": "string",
    //               "UniformResourceIdentifier": "string"
    //             },
    //             "AccessMethod": {
    //               "AccessMethodType": "string",
    //               "CustomObjectIdentifier": "string"
    //             }
    //           }
    //         ]
    //       },
    //       "KeyAlgorithm": "string",
    //       "SigningAlgorithm": "string",
    //       "Subject": {
    //         "CommonName": "string",
    //         "Country": "string",
    //         "DistinguishedNameQualifier": "string",
    //         "GenerationQualifier": "string",
    //         "GivenName": "string",
    //         "Initials": "string",
    //         "Locality": "string",
    //         "Organization": "string",
    //         "OrganizationalUnit": "string",
    //         "Pseudonym": "string",
    //         "SerialNumber": "string",
    //         "State": "string",
    //         "Surname": "string",
    //         "Title": "string"
    //       }
    //     },
    //     "CreatedAt": number,
    //     "FailureReason": "string",
    //     "KeyStorageSecurityStandard": "string",
    //     "LastStateChangeAt": number,
    //     "NotAfter": number,
    //     "NotBefore": number,
    //     "OwnerAccount": "string",
    //     "RestorableUntil": number,
    //     "RevocationConfiguration": {
    //       "CrlConfiguration": {
    //         "CustomCname": "string",
    //         "Enabled": boolean,
    //         "ExpirationInDays": number,
    //         "S3BucketName": "string",
    //         "S3ObjectAcl": "string"
    //       },
    //       "OcspConfiguration": {
    //         "Enabled": boolean,
    //         "OcspCustomCname": "string"
    //       }
    //     },
    //     "Serial": "string",
    //     "Status": "string",
    //     "Type": "string"
    //   }
    // }

}