Skip to content

Commit

Permalink
feat: Migrate S3 Client from AWS SDK v2 (deprecated) to v3 (#221)
Browse files Browse the repository at this point in the history
  • Loading branch information
vahidalizad authored Jan 1, 2025
1 parent 1f74921 commit bc32fd2
Show file tree
Hide file tree
Showing 14 changed files with 6,297 additions and 3,296 deletions.
2 changes: 1 addition & 1 deletion .eslintrc.json
Original file line number Diff line number Diff line change
Expand Up @@ -28,4 +28,4 @@
"globals": {
"Parse": true
}
}
}
3 changes: 0 additions & 3 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -34,9 +34,6 @@ jobs:
- name: Parse Server 7, Node.js 22
NODE_VERSION: 22.4.1
PARSE_SERVER_VERSION: 7
- name: Parse Server 6
NODE_VERSION: 18
PARSE_SERVER_VERSION: 6
fail-fast: false
name: ${{ matrix.name }}
timeout-minutes: 15
Expand Down
2 changes: 1 addition & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -177,4 +177,4 @@ ___



\* *This Change Log was automatically generated by [github_changelog_generator](https://github.com/skywinder/Github-Changelog-Generator)*
\* *This Change Log was automatically generated by [github_changelog_generator](https://github.com/skywinder/Github-Changelog-Generator)*
109 changes: 96 additions & 13 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,9 @@
[![Coverage](https://img.shields.io/codecov/c/github/parse-community/parse-server-s3-adapter/master.svg)](https://codecov.io/github/parse-community/parse-server-s3-adapter?branch=master)
[![auto-release](https://img.shields.io/badge/%F0%9F%9A%80-auto--release-9e34eb.svg)](https://github.com/parse-community/parse-server-s3-adapter/releases)

[![Parse Server](https://img.shields.io/badge/Parse_Server-7.0-169CEE.svg?style=flat&logo=)](https://github.com/parse-community/parse-server/releases)
[![Node Version](https://img.shields.io/badge/nodejs-18,_20,_22-green.svg?logo=node.js&style=flat)](https://nodejs.org)

[![npm latest version](https://img.shields.io/npm/v/@parse/s3-files-adapter.svg)](https://www.npmjs.com/package/@parse/s3-files-adapter)

---
Expand All @@ -28,6 +31,9 @@ The official AWS S3 file storage adapter for Parse Server. See [Parse Server S3
- [Adding Metadata and Tags](#adding-metadata-and-tags)
- [Compatibility with other Storage Providers](#compatibility-with-other-storage-providers)
- [Digital Ocean Spaces](#digital-ocean-spaces)
- [Breaking Changes From v2 to v3](#breaking-changes-from-v2-to-v3)
- [Best Practices](#best-practices)
- [Why the Change](#why-the-change)


# Getting Started
Expand All @@ -40,21 +46,24 @@ The official AWS S3 file storage adapter for Parse Server. See [Parse Server S3

### Parse Server

| Version | End-of-Life | Compatible |
|---------|---------------|------------|
| <=5 | December 2023 | ✅ Yes |
| 6 | December 2024 | ✅ Yes |
| 7 | December 2025 | ✅ Yes |
Parse Server S3 Adapter is compatible with the following versions of Parse Server.

| Parse Server Version | End-of-Life | Compatible |
|----------------------|---------------|------------|
| <=5 | December 2023 | ❌ No |
| 6 | December 2024 | ❌ No |
| <7.3.0 | December 2025 | ❌ No |
| >=7.3.0 | December 2025 | ✅ Yes |

### Node.js

This product is continuously tested with the most recent releases of Node.js to ensure compatibility. We follow the [Node.js Long Term Support plan](https://github.com/nodejs/Release) and only test against versions that are officially supported and have not reached their end-of-life date.
Parse Server S3 Adapter is continuously tested with the most recent releases of Node.js to ensure compatibility. We follow the [Node.js Long Term Support plan](https://github.com/nodejs/Release) and only test against versions that are officially supported and have not reached their end-of-life date.

| Version | Latest Version | End-of-Life | Compatible |
|------------|----------------|-------------|------------|
| Node.js 18 | 18.20.4 | April 2025 | ✅ Yes |
| Node.js 20 | 20.15.1 | April 2026 | ✅ Yes |
| Node.js 22 | 22.4.1 | April 2027 | ✅ Yes |
| Node.js Version | End-of-Life | Compatible |
|-----------------|-------------|------------|
| 18 | April 2025 | ✅ Yes |
| 20 | April 2026 | ✅ Yes |
| 22 | April 2027 | ✅ Yes |

## AWS Credentials

Expand Down Expand Up @@ -277,7 +286,6 @@ var S3Adapter = require("@parse/s3-files-adapter");
var AWS = require("aws-sdk");

//Configure Digital Ocean Spaces EndPoint
const spacesEndpoint = new AWS.Endpoint(process.env.SPACES_ENDPOINT);
var s3Options = {
bucket: process.env.SPACES_BUCKET_NAME,
baseUrl: process.env.SPACES_BASE_URL,
Expand All @@ -290,7 +298,7 @@ var s3Options = {
s3overrides: {
accessKeyId: process.env.SPACES_ACCESS_KEY,
secretAccessKey: process.env.SPACES_SECRET_KEY,
endpoint: spacesEndpoint
endpoint: process.env.SPACES_ENDPOINT
}
};

Expand All @@ -307,3 +315,78 @@ var api = new ParseServer({
filesAdapter: s3Adapter
});
```


# Breaking Changes from v2 to v3

1. **Old Method (No Longer Supported)**:
```javascript
const options = {
bucket: 'bucket-1',
s3overrides: {
accessKeyId: 'access-key',
secretAccessKey: 'secret-key'
}
};
```

2. **New Methods (Required)**:
Credentials must now be passed either:

- **Inside the `s3overrides.credentials` key**:
```javascript
const options = {
bucket: 'bucket-1',
s3overrides: {
credentials: {
accessKeyId: 'access-key',
secretAccessKey: 'secret-key'
}
}
};
```

- **Directly in the root object**:
```javascript
const options = {
bucket: 'bucket-1',
credentials: {
accessKeyId: 'access-key',
secretAccessKey: 'secret-key'
}
};
```

## Best Practices

1. **Use Environment Variables for Credentials**:
Storing credentials directly in code can be insecure. Instead, use environment variables with the AWS SDK's built-in support for credential resolution:
```javascript
const options = {
bucket: 'bucket-1',
s3overrides: {
// The SDK will automatically load credentials from the environment
}
};
```
2. **Prefer AWS IAM Roles (for EC2, ECS, or Lambda)**:
If running in AWS-managed environments, use IAM roles to automatically provide temporary credentials:
- No need to pass `credentials` manually; the SDK resolves them automatically.
3. **Use the AWS Credential Provider Chain**:
Leverage the SDK's support for multiple credential sources:
```javascript
import { fromIni } from '`aws-sdk/credential-providers';
const options = {
bucket: 'bucket-1',
s3overrides: {
credentials: fromIni({ profile: 'your-profile-name' })
}
};
```
## Why the Change
The updated approach adheres to AWS SDK v3's modular and secure design, improving compatibility with advanced credential management techniques and security best practices.
Loading

0 comments on commit bc32fd2

Please sign in to comment.