
Security News
/Research
Popular node-ipc npm Package Infected with Credential Stealer
Socket detected malicious node-ipc versions with obfuscated stealer/backdoor behavior in a developing npm supply chain attack.
@ttoss/appsync-api
Advanced tools
This package provides a opinionated way to create an AppSync API using @ttoss/graphql-api API.
pnpm add @ttoss/appsync-api @ttoss/graphql-api graphql
You can create and deploy an AppSync API in four steps:
Create a schemaComposer object using graphql-compose, that the next steps will use to create the API.
Create a cloudformation.ts file that exports a CloudFormation template using createApiTemplate. Use importValueFromParameter from @ttoss/cloudformation to import cross-stack values whose export names come from template parameters:
import { importValueFromParameter } from '@ttoss/cloudformation';
import { createApiTemplate } from '@ttoss/appsync-api';
import { schemaComposer } from './schemaComposer';
const template = createApiTemplate({
schemaComposer,
dataSource: {
roleArn: importValueFromParameter('AppSyncLambdaDataSourceIAMRoleArn'),
},
lambdaFunction: {
roleArn: importValueFromParameter('AppSyncLambdaFunctionIAMRoleArn'),
environment: {
variables: {
TABLE_NAME: { Ref: 'DynamoTableName' },
SHARED_SECRET: importValueFromParameter('SharedSecretExportedName'),
},
},
},
});
export default template;
lambda.ts file that exports a Lambda handler function using createAppSyncResolverHandler:import { createAppSyncResolverHandler } from '@ttoss/appsync-api';
import { schemaComposer } from './schemaComposer';
export const handler = createAppSyncResolverHandler({ schemaComposer });
graphql to the lambdaExternals array on carlin.yml:lambdaExternals:
- graphql
Now you can deploy your API using carlin deploy:
carlin deploy
The createAppSyncResolverHandler function adds the context object to the resolvers. This object contains the following properties:
handler - AWS Lambda context object.request - AppSync request object (see Request section).identity - AppSync identity object (see Identity section).Use createContext to enrich the resolver context once per request. Its return value is shallow-merged into the base context, making it available to every resolver. This is the recommended way to resolve per-request values like a userId from Cognito:
import { createAppSyncResolverHandler } from '@ttoss/appsync-api';
import { schemaComposer } from './schemaComposer';
import { getUserIdFromCognitoSub } from './auth';
export const handler = createAppSyncResolverHandler({
schemaComposer,
createContext: async ({ identity }) => ({
userId: await getUserIdFromCognitoSub(identity?.sub),
}),
});
Every resolver then receives context.userId without having to derive it individually.
You can use graphql-middleware-compatible middlewares via the middlewares option. Each middleware wraps the resolver — code before resolve() runs before the resolver, code after runs after.
In AppSync, each Lambda invocation handles a single field, so a middleware runs exactly once per request.
Use middlewares for authorization rules or cross-cutting logic (logging, tracing). Combine with createContext for per-request context enrichment:
createContext | middlewares | |
|---|---|---|
| Runs | Once per request | Once per resolver call |
| Purpose | Enrich context (e.g. userId) | Auth rules, logging, before/after logic |
| Can block execution | On error (request fails if createContext rejects/throws) | Yes (can conditionally block by not calling resolve or throwing) |
Use GraphQL Shield to add authorization rules:
import { allow, deny, shield } from '@ttoss/graphql-api/shield';
const permissions = shield(
{
Query: { '*': deny, me: allow },
},
{ fallbackRule: deny }
);
export const handler = createAppSyncResolverHandler({
schemaComposer,
middlewares: [permissions],
});
You can add a custom domain name to your API using the customDomain option.
import { createApiTemplate } from '@ttoss/appsync-api';
export const handler = createApiTemplate({
schemaComposer,
customDomain: {
domainName: 'api.example.com', // required
certificateArn: {
'Fn::ImportValue': 'AppSyncDomainCertificateArn',
}, // required
},
});
If your domain is on Route53, you can use the option customDomain.hostedZoneName to create the required DNS records.
import { createApiTemplate } from '@ttoss/appsync-api';
export const template = createApiTemplate({
schemaComposer,
customDomain: {
domainName: 'api.example.com', // required
certificateArn: {
'Fn::ImportValue': 'AppSyncDomainCertificateArn',
}, // required
hostedZoneName: 'example.com.', // optional
},
});
FAQs
A library for building GraphQL APIs for AWS AppSync.
We found that @ttoss/appsync-api demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
/Research
Socket detected malicious node-ipc versions with obfuscated stealer/backdoor behavior in a developing npm supply chain attack.

Security News
TeamPCP and BreachForums are promoting a Shai-Hulud supply chain attack contest with a $1,000 prize for the biggest package compromise.

Security News
Packagist urges PHP projects to update Composer after a GitHub token format change exposed some GitHub Actions tokens in CI logs.