Skip to main content
Connect Amazon S3 buckets or S3-compatible storage services (MinIO, DigitalOcean Spaces, Cloudflare R2) to sync files into your Supermemory knowledge base.
The S3 connector requires a Scale Plan or higher. You can also create S3 connections directly from the Supermemory Console.

Quick Setup

import Supermemory from 'supermemory';

const client = new Supermemory({
  apiKey: process.env.SUPERMEMORY_API_KEY!
});

const connection = await client.connections.create('s3', {
  accessKeyId: process.env.AWS_ACCESS_KEY_ID!,
  secretAccessKey: process.env.AWS_SECRET_ACCESS_KEY!,
  bucket: 'my-documents-bucket',
  region: 'us-east-1',
  containerTags: ['org-123']
});

Configuration Options

ParameterRequiredDescription
accessKeyIdYesAWS access key ID or S3-compatible service key
secretAccessKeyYesAWS secret access key
bucketYesS3 bucket name
regionYesAWS region (e.g., us-east-1)
endpointNoCustom endpoint for S3-compatible services
prefixNoKey prefix filter (e.g., documents/)
containerTagRegexNoRegex to extract container tags from file paths
containerTagsNoTags for organizing connections
documentLimitNoMaximum documents to sync (default: 10,000)

S3-Compatible Services

Use a custom endpoint to connect to S3-compatible storage:
// MinIO
const connection = await client.connections.create('s3', {
  accessKeyId: 'minio-key',
  secretAccessKey: 'minio-secret',
  bucket: 'my-bucket',
  region: 'us-east-1',
  endpoint: 'https://minio.example.com',
  containerTags: ['minio-sync']
});

// DigitalOcean Spaces
endpoint: 'https://nyc3.digitaloceanspaces.com'

// Cloudflare R2
endpoint: 'https://ACCOUNT_ID.r2.cloudflarestorage.com'

Prefix Filtering

Sync only files within a specific path:
const connection = await client.connections.create('s3', {
  // ... credentials
  bucket: 'company-data',
  region: 'us-east-1',
  prefix: 'documents/engineering/',  // Only syncs files under this path
  containerTags: ['engineering-docs']
});

Dynamic Container Tags

Extract container tags from S3 key paths for multi-tenant setups:
const connection = await client.connections.create('s3', {
  // ... credentials
  bucket: 'user-files',
  region: 'us-east-1',
  containerTagRegex: 'users/(?<userId>[^/]+)/',
  containerTags: ['user-files']
});

// File: users/user-123/documents/notes.md → container tag: user-123
// File: users/user-456/reports/q4.pdf → container tag: user-456
The regex must contain a named capture group (?<userId>...) and be less than 200 characters.

Connection Management

Delete Connection

await client.connections.deleteByID('conn_s3_abc123');
Deleting a connection removes all synced documents from Supermemory.

Manual Sync

await client.connections.import('s3', {
  containerTags: ['org-123']
});

Sync Behavior

FeatureBehavior
Initial syncFetches all files matching prefix filter
Incremental syncOnly files modified since last sync
Sync scheduleEvery 4 hours + manual triggers
Document limit10,000 files per connection (default)

IAM Permissions

Minimum required permissions:
{
  "Version": "2012-10-17",
  "Statement": [
    {
      "Effect": "Allow",
      "Action": ["s3:GetObject", "s3:ListBucket"],
      "Resource": [
        "arn:aws:s3:::your-bucket-name",
        "arn:aws:s3:::your-bucket-name/*"
      ]
    }
  ]
}

Error Codes

CodeMessageSolution
401Authentication failedVerify access key and secret
403Access deniedCheck IAM permissions and bucket policy
404Bucket not foundVerify bucket name and region