-
Notifications
You must be signed in to change notification settings - Fork 74
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Feature: custom runtimes to define function #1602
Merged
sobolk
merged 14 commits into
aws-amplify:main
from
MarlonJD:feature/custom-runtimes-to-defineFunction
Jan 7, 2025
Merged
Changes from all commits
Commits
Show all changes
14 commits
Select commit
Hold shift + click to select a range
49abcbd
feature(function): add custom provided function support to defineFunc…
MarlonJD dbdccba
chore: add changeset
MarlonJD 26ea2f2
chore(function): fix e2ee path and changeset
MarlonJD 9f6f2e4
chore(function): add new API.md
MarlonJD cefa084
fix(function): fix e2ee tests for provided function
MarlonJD 53b475f
chore: change changeset
MarlonJD 89b52d4
chore(function): add without docker error message
MarlonJD 497da33
chore(function): add provided function error message
MarlonJD 70db088
chore(function): add missing imports
MarlonJD cbaa8bc
chore(function): fix lint error
MarlonJD 7a79923
Update packages/backend-function/src/provided_function_factory.ts
MarlonJD 10726dd
Update packages/backend-function/src/provided_function_factory.ts
MarlonJD d7cf435
Merge branch 'aws-amplify:main' into feature/custom-runtimes-to-defin…
MarlonJD aa6762e
chore(function): fix lint issue
MarlonJD File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
--- | ||
'@aws-amplify/backend-function': minor | ||
'@aws-amplify/backend': minor | ||
--- | ||
|
||
add custom provided function support to define function |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
import { Construct } from 'constructs'; | ||
import { | ||
BackendOutputStorageStrategy, | ||
FunctionResources, | ||
ResourceAccessAcceptor, | ||
ResourceAccessAcceptorFactory, | ||
ResourceProvider, | ||
} from '@aws-amplify/plugin-types'; | ||
import { Stack } from 'aws-cdk-lib'; | ||
import { | ||
FunctionOutput, | ||
functionOutputKey, | ||
} from '@aws-amplify/backend-output-schemas'; | ||
import { AttributionMetadataStorage } from '@aws-amplify/backend-output-storage'; | ||
import { fileURLToPath } from 'node:url'; | ||
|
||
const functionStackType = 'function-Lambda'; | ||
|
||
/** | ||
* A base class for function constructs. | ||
*/ | ||
export abstract class AmplifyFunctionBase | ||
extends Construct | ||
implements ResourceProvider<FunctionResources>, ResourceAccessAcceptorFactory | ||
{ | ||
readonly stack: Stack; | ||
abstract resources: FunctionResources; | ||
|
||
abstract getResourceAccessAcceptor: () => ResourceAccessAcceptor; | ||
|
||
/** | ||
* Creates base function construct. | ||
*/ | ||
protected constructor( | ||
scope: Construct, | ||
id: string, | ||
private readonly outputStorageStrategy: BackendOutputStorageStrategy<FunctionOutput> | ||
) { | ||
super(scope, id); | ||
|
||
this.stack = Stack.of(scope); | ||
|
||
new AttributionMetadataStorage().storeAttributionMetadata( | ||
Stack.of(this), | ||
functionStackType, | ||
fileURLToPath(new URL('../package.json', import.meta.url)) | ||
); | ||
} | ||
|
||
protected storeOutput = (): void => { | ||
this.outputStorageStrategy.appendToBackendOutputList(functionOutputKey, { | ||
version: '1', | ||
payload: { | ||
definedFunctions: this.resources.lambda.functionName, | ||
}, | ||
}); | ||
}; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1,3 @@ | ||
export * from './factory.js'; | ||
import { ProvidedFunctionProps } from './provided_function_factory.js'; | ||
export { ProvidedFunctionProps }; |
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Following up on my overall comment, I'm not sure how we're going to handle environment variables of type
Record<string, string | BackendSecret>;
. (see line 88 of this file) I see that you can add an environment variable viaaddEnvironment(key: string, value: string, options?: EnvironmentOptions): this;
method ofPythonFunction
. However, thevalue
cannot be of typeBackendSecret
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@MarlonJD @arash2060 I am so excited to see this functionality so close! I am new to Amplify and have been enjoying the ease of development...but got hung up royally today trying to figure out how to add a custom query to my graphql schema via a lambda with python 3_11 runtime. This functionality will be well-used and loved as I build out slew of microservices that use LangChain. I am wondering if you would consider deploying without supporting environment variables for now as a way to get this into our hands. From my understanding, that would require adding a permission for the lambda to access the secret store with boto3 and a warning about the additional cost and latency while the full functionality is being built out. Is this feasible? Curious to hear your thoughts.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hey there! If you want to auto deploy with amplify we should use AWS Secret Manager, it's because
secret('foo')
using this, you can easily use .env file and manuel deploy without this I can give an example for this, if you have another solution or idea please tell me mayne we can build, I'm thinking publish my amplify fork and use this on amplify auto deploy because of limit issue and this python and golang functions, I'll share with you this examples here If you want to use custom functions on auto build in amplify console.