-
Notifications
You must be signed in to change notification settings - Fork 124
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] Add support for OpenSearch Serverless #356
Comments
I swapped
So far, it allows me to create and query indices via |
Request signatures continue to be the biggest pain point for us. The decision to disallow
The AWS Javascript v3 sdk has a standalone signature v4 package ( Perhaps a PR to |
cc: @shwetathareja ^ I'll bring this up with the serverless team, the same problem with this zero content length came up in acm19/aws-request-signing-apache-interceptor#90. |
We're having the same experience, unable to get a connection to work. Aside from a fix on the aws4 signer, is there any other way to possibly use the serverless API ? |
Same. I tried to use the example in https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-clients.html#serverless-javascript as is and it didn't work. I'll sort it out, stay tuned. |
Update: manually commenting out content-length signing in https://github.com/mhart/aws4/blob/a413aadd9e4b4e58842937a9ad53354be41ef4a1/aws4.js#L148-L149 works. This is mhart/aws4#37. As a workaround you can include a local aws4.js as I did in https://github.com/dblock/opensearch-node-client-demo/tree/opensearch-serverless-aws-sdk2, for now. https://github.com/dblock/opensearch-node-client-demo/tree/opensearch-serverless-aws-sdk2 |
Thanks for bringing this to my attention. This is now supported in v1.12.0 of Eg: aws4.sign({
host: '07tjusf2h91cunochc.us-east-1.aoss.amazonaws.com',
method: 'PUT',
path: '/my-index',
body: '{"mappings":{}}',
headers: {
'Content-Type': 'application/json',
'X-Amz-Content-Sha256': 'UNSIGNED-PAYLOAD'
},
extraHeadersToIgnore: {
'content-length': true
}
}) |
Thanks @mhart. Doesn't seem like that was necessary after all (although it's a good feature). In dblock/opensearch-node-client-demo@9290669 I deleted the body before singing it and putting it back and everything seems to work. @bwg I think that's the workaround for preview. We need to modify opensearch-js to do that for now I imagine (want to try it?). I'm aking the serverless folks to make Sigv4 work the same way as for the managed service, so I expect the above to change before it's officially launched out of preview. |
@dblock I prefer the explicitness of the hopefully you'll have a better chance convincing the serverless team to change the signature requirements than I did. |
After way to much hacking about with every combination I can think of, I am unable to get serverless to accept a request signed with The only way I am able to get the sdk/aws4 to generate a signature that serverless will accept is to Serverless does not provide an expected "string to sign" on failure, so its like punching in the dark to figure out what it doesn't like about the signature. As luck would have it, the serverless team reached out the other day and they said they would update their guidance on how to use serverless with the opensearch-js sdk. We'll see what they come back with. |
@bwg that's super annoying. The fact that you have to delete the body is even more annoying. Just to double check, you are providing the |
I'm actively working with the serverless team on this. We have the goal that no changes in clients is required other than the signing service name, and that serverless behaves exactly as the Amazon Managed OpenSearch service. I expect the whole Btw, if you find any other API change vs. the managed service, please speak up and we'll take a look. Easy to fix before it launches while it's in preview. |
Really appreciate your work @dblock! Following this closely. |
#367 -- I have a sample PR here that computes the hash in the header but there is an invalid signature mismatch. Does anyone have a clue why this is failing? |
OpenSearch serverless aligned itself to the managed service, but signing the body is required. Works the same on both managed and serverless with that. Ruby client from HEAD working here. |
The types weren't updated, so I've added a new PR #374. |
Is your feature request related to a problem?
With #333 one can supply
aoss
. I believeclient.info()
will be broken because that doesn't exist in serverless. What else?What solution would you like?
Document support for OpenSearch Serverless in the compatibility matrix, add integration tests.
Do you have any additional context?
Coming from opensearch-project/opensearch-clients#44
The text was updated successfully, but these errors were encountered: