Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
48 changes: 33 additions & 15 deletions Sources/AWSLambdaRuntimeCore/ControlPlaneRequest.swift
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
//
// This source file is part of the SwiftAWSLambdaRuntime open source project
//
// Copyright (c) 2017-2021 Apple Inc. and the SwiftAWSLambdaRuntime project authors
// Copyright (c) 2021-2022 Apple Inc. and the SwiftAWSLambdaRuntime project authors
// Licensed under Apache License v2.0
//
// See LICENSE.txt for license information
Expand All @@ -17,8 +17,8 @@ import NIOHTTP1

enum ControlPlaneRequest: Hashable {
case next
case invocationResponse(String, ByteBuffer?)
case invocationError(String, ErrorResponse)
case invocationResponse(LambdaRequestID, ByteBuffer?)
case invocationError(LambdaRequestID, ErrorResponse)
case initializationError(ErrorResponse)
}

Expand All @@ -29,12 +29,26 @@ enum ControlPlaneResponse: Hashable {
}

struct Invocation: Hashable {
let requestID: String
let deadlineInMillisSinceEpoch: Int64
let invokedFunctionARN: String
let traceID: String
let clientContext: String?
let cognitoIdentity: String?
var requestID: String
var deadlineInMillisSinceEpoch: Int64
var invokedFunctionARN: String
var traceID: String
var clientContext: String?
var cognitoIdentity: String?

init(requestID: String,
deadlineInMillisSinceEpoch: Int64,
invokedFunctionARN: String,
traceID: String,
clientContext: String?,
cognitoIdentity: String?) {
self.requestID = requestID
self.deadlineInMillisSinceEpoch = deadlineInMillisSinceEpoch
self.invokedFunctionARN = invokedFunctionARN
self.traceID = traceID
self.clientContext = clientContext
self.cognitoIdentity = cognitoIdentity
}

init(headers: HTTPHeaders) throws {
guard let requestID = headers.first(name: AmazonHeaders.requestID), !requestID.isEmpty else {
Expand All @@ -51,12 +65,16 @@ struct Invocation: Hashable {
throw Lambda.RuntimeError.invocationMissingHeader(AmazonHeaders.invokedFunctionARN)
}

self.requestID = requestID
self.deadlineInMillisSinceEpoch = unixTimeInMilliseconds
self.invokedFunctionARN = invokedFunctionARN
self.traceID = headers.first(name: AmazonHeaders.traceID) ?? "Root=\(AmazonHeaders.generateXRayTraceID());Sampled=0"
self.clientContext = headers["Lambda-Runtime-Client-Context"].first
self.cognitoIdentity = headers["Lambda-Runtime-Cognito-Identity"].first
let traceID = headers.first(name: AmazonHeaders.traceID) ?? "Root=\(AmazonHeaders.generateXRayTraceID());Sampled=0"

self.init(
requestID: requestID,
deadlineInMillisSinceEpoch: unixTimeInMilliseconds,
invokedFunctionARN: invokedFunctionARN,
traceID: traceID,
clientContext: headers["Lambda-Runtime-Client-Context"].first,
cognitoIdentity: headers["Lambda-Runtime-Cognito-Identity"].first
)
}
}

Expand Down
8 changes: 4 additions & 4 deletions Sources/AWSLambdaRuntimeCore/ControlPlaneRequestEncoder.swift
Original file line number Diff line number Diff line change
Expand Up @@ -100,15 +100,15 @@ extension String {
}

extension ByteBuffer {
fileprivate mutating func writeInvocationResultRequestLine(_ requestID: String) {
fileprivate mutating func writeInvocationResultRequestLine(_ requestID: LambdaRequestID) {
self.writeString("POST /2018-06-01/runtime/invocation/")
self.writeString(requestID)
self.writeRequestID(requestID)
self.writeString("/response HTTP/1.1\r\n")
}

fileprivate mutating func writeInvocationErrorRequestLine(_ requestID: String) {
fileprivate mutating func writeInvocationErrorRequestLine(_ requestID: LambdaRequestID) {
self.writeString("POST /2018-06-01/runtime/invocation/")
self.writeString(requestID)
self.writeRequestID(requestID)
self.writeString("/error HTTP/1.1\r\n")
}

Expand Down
Loading