Skip to content

Latest commit

 

History

History
45 lines (32 loc) · 2.07 KB

core.md

File metadata and controls

45 lines (32 loc) · 2.07 KB
title description
Core
Access invocation meta data for your application requests.

The core interface provides access to underlying invocation meta data on every request. This information can be used for debugging, correlating requests, etc.

Using the core interface

The core interface can be imported from the @ampt/sdk and returns three getters:

  • requestId: The AWS reqId that can be correlated with log entries.
  • event: The raw AWS event object passed from the event source mapping.
  • context: The AWS context object of the invocation.

!!! note The structure of the event and context objects depend on the underlying compute platform (Lambda, Fargate, App Runner). The requestId will always return a string. !!!

The getter must be accessed from within a handler (e.g. task, events.on(), data.on()) or an HTTP framework's route/middleware.

import { core, events } from "@ampt/sdk";

events.on("user.created", async (evt) => {
  console.log("Event Details:", evt);
  console.log({
    reqId: core.requestId,
    event: core.event,
    context: core.context,
  });
});

Setting Timeouts

The context getter will return a setTimeout function that lets you dynamically override the current handler's timeout.

Ampt interfaces that define handlers like tasks, events, and storage, provide a context object as part of the handler signature (e.g. task("my-task", async (event, context) => { })). Other handlers, such as those defined by Fetch-based frameworks and Ampt Data listeners, don't provide a native way to adjust the timeout.

Instead, you can use core.context.setTimeout() (e.g. core.context.setTimeout(10000)) to dynamically set the timeout of any handler. Timeouts are in milliseconds and cannot exceed 5 minutes.

!!! caution setTimeout() can be executed anywhere within the handler, but should be run before any other processes that could caused the handler to exceed the default timeout. !!!