Chilkat Online Tools

MergePullRequestByThreeWay Swift Example

AWS CodeCommit

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

    // URL: https://codecommit.us-west-2.amazonaws.com/
    // Use the same region as specified above.
    success = rest.Connect("codecommit.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("authorName", value: "string")
    json.UpdateString("commitMessage", value: "string")
    json.UpdateString("conflictDetailLevel", value: "string")
    json.UpdateString("conflictResolution.deleteFiles[0].filePath", value: "string")
    json.UpdateInt("conflictResolution.replaceContents[0].content", value: 123)
    json.UpdateString("conflictResolution.replaceContents[0].fileMode", value: "string")
    json.UpdateString("conflictResolution.replaceContents[0].filePath", value: "string")
    json.UpdateString("conflictResolution.replaceContents[0].replacementType", value: "string")
    json.UpdateString("conflictResolution.setFileModes[0].fileMode", value: "string")
    json.UpdateString("conflictResolution.setFileModes[0].filePath", value: "string")
    json.UpdateString("conflictResolutionStrategy", value: "string")
    json.UpdateString("email", value: "string")
    json.UpdateInt("keepEmptyFolders", value: 123)
    json.UpdateString("pullRequestId", value: "string")
    json.UpdateString("repositoryName", value: "string")
    json.UpdateString("sourceCommitId", value: "string")

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

    // {
    //   "authorName": "string",
    //   "commitMessage": "string",
    //   "conflictDetailLevel": "string",
    //   "conflictResolution": {
    //     "deleteFiles": [
    //       {
    //         "filePath": "string"
    //       }
    //     ],
    //     "replaceContents": [
    //       {
    //         "content": blob,
    //         "fileMode": "string",
    //         "filePath": "string",
    //         "replacementType": "string"
    //       }
    //     ],
    //     "setFileModes": [
    //       {
    //         "fileMode": "string",
    //         "filePath": "string"
    //       }
    //     ]
    //   },
    //   "conflictResolutionStrategy": "string",
    //   "email": "string",
    //   "keepEmptyFolders": boolean,
    //   "pullRequestId": "string",
    //   "repositoryName": "string",
    //   "sourceCommitId": "string"
    // }

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

    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 approvalRuleContent: String?
    var approvalRuleId: String?
    var approvalRuleName: String?
    var creationDate: Int
    var lastModifiedDate: Int
    var lastModifiedUser: String?
    var ApprovalRuleTemplateId: String?
    var ApprovalRuleTemplateName: String?
    var ruleContentSha256: String?
    var destinationCommit: String?
    var destinationReference: String?
    var mergeBase: String?
    var IsMerged: Int
    var MergeCommitId: String?
    var MergedBy: String?
    var MergeOption: String?
    var repositoryName: String?
    var sourceCommit: String?
    var sourceReference: String?

    var AuthorArn: String? = jResp.StringOf("pullRequest.authorArn")
    var ClientRequestToken: String? = jResp.StringOf("pullRequest.clientRequestToken")
    var CreationDate: Int = jResp.IntOf("pullRequest.creationDate").intValue
    var Description: String? = jResp.StringOf("pullRequest.description")
    var LastActivityDate: Int = jResp.IntOf("pullRequest.lastActivityDate").intValue
    var PullRequestId: String? = jResp.StringOf("pullRequest.pullRequestId")
    var PullRequestStatus: String? = jResp.StringOf("pullRequest.pullRequestStatus")
    var RevisionId: String? = jResp.StringOf("pullRequest.revisionId")
    var Title: String? = jResp.StringOf("pullRequest.title")
    var i: Int = 0
    var count_i: Int = jResp.SizeOfArray("pullRequest.approvalRules").intValue
    while i < count_i {
        jResp.I = i
        approvalRuleContent = jResp.StringOf("pullRequest.approvalRules[i].approvalRuleContent")
        approvalRuleId = jResp.StringOf("pullRequest.approvalRules[i].approvalRuleId")
        approvalRuleName = jResp.StringOf("pullRequest.approvalRules[i].approvalRuleName")
        creationDate = jResp.IntOf("pullRequest.approvalRules[i].creationDate").intValue
        lastModifiedDate = jResp.IntOf("pullRequest.approvalRules[i].lastModifiedDate").intValue
        lastModifiedUser = jResp.StringOf("pullRequest.approvalRules[i].lastModifiedUser")
        ApprovalRuleTemplateId = jResp.StringOf("pullRequest.approvalRules[i].originApprovalRuleTemplate.approvalRuleTemplateId")
        ApprovalRuleTemplateName = jResp.StringOf("pullRequest.approvalRules[i].originApprovalRuleTemplate.approvalRuleTemplateName")
        ruleContentSha256 = jResp.StringOf("pullRequest.approvalRules[i].ruleContentSha256")
        i = i + 1
    }

    i = 0
    count_i = jResp.SizeOfArray("pullRequest.pullRequestTargets").intValue
    while i < count_i {
        jResp.I = i
        destinationCommit = jResp.StringOf("pullRequest.pullRequestTargets[i].destinationCommit")
        destinationReference = jResp.StringOf("pullRequest.pullRequestTargets[i].destinationReference")
        mergeBase = jResp.StringOf("pullRequest.pullRequestTargets[i].mergeBase")
        IsMerged = jResp.IntOf("pullRequest.pullRequestTargets[i].mergeMetadata.isMerged").intValue
        MergeCommitId = jResp.StringOf("pullRequest.pullRequestTargets[i].mergeMetadata.mergeCommitId")
        MergedBy = jResp.StringOf("pullRequest.pullRequestTargets[i].mergeMetadata.mergedBy")
        MergeOption = jResp.StringOf("pullRequest.pullRequestTargets[i].mergeMetadata.mergeOption")
        repositoryName = jResp.StringOf("pullRequest.pullRequestTargets[i].repositoryName")
        sourceCommit = jResp.StringOf("pullRequest.pullRequestTargets[i].sourceCommit")
        sourceReference = jResp.StringOf("pullRequest.pullRequestTargets[i].sourceReference")
        i = i + 1
    }

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

    // {
    //   "pullRequest": {
    //     "approvalRules": [
    //       {
    //         "approvalRuleContent": "string",
    //         "approvalRuleId": "string",
    //         "approvalRuleName": "string",
    //         "creationDate": number,
    //         "lastModifiedDate": number,
    //         "lastModifiedUser": "string",
    //         "originApprovalRuleTemplate": {
    //           "approvalRuleTemplateId": "string",
    //           "approvalRuleTemplateName": "string"
    //         },
    //         "ruleContentSha256": "string"
    //       }
    //     ],
    //     "authorArn": "string",
    //     "clientRequestToken": "string",
    //     "creationDate": number,
    //     "description": "string",
    //     "lastActivityDate": number,
    //     "pullRequestId": "string",
    //     "pullRequestStatus": "string",
    //     "pullRequestTargets": [
    //       {
    //         "destinationCommit": "string",
    //         "destinationReference": "string",
    //         "mergeBase": "string",
    //         "mergeMetadata": {
    //           "isMerged": boolean,
    //           "mergeCommitId": "string",
    //           "mergedBy": "string",
    //           "mergeOption": "string"
    //         },
    //         "repositoryName": "string",
    //         "sourceCommit": "string",
    //         "sourceReference": "string"
    //       }
    //     ],
    //     "revisionId": "string",
    //     "title": "string"
    //   }
    // }

}