AWS Request Signer alternatives and similar packages
Based on the "Authentication" category.
Alternatively, view AWS Request Signer alternatives based on common mentions on social networks and blogs.
Silhouette is an authentication library for Play Framework applications that supports several authentication methods, including OAuth1, OAuth2, OpenID, CAS, 2FA, TOTP, Credentials, Basic Authentication or custom authentication schemes.
OAuth 2.0 server-side implementation written in Scala
Web & mobile client-side akka-http sessions, with optional JWT support
6.4 7.7 L5 AWS Request Signer VS play-pac4jSecurity library for Play framework 2 in Java and Scala: OAuth, CAS, SAML, OpenID Connect, LDAP, JWT...
Simple play module for authenticating against Google
An implementation of an OAuth2 server designed for mocking/testing
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of AWS Request Signer or a related project?
NOTE: this project is deprecated in favor of a broader library for this and other AWS features. See here: https://github.com/aws4s/aws4s
AWS Request Signer
Helper to evaluate the signing headers for HTTP requests to Amazon Web Services. This is a Scala port of (part of) the Java aws-signing-request-interceptor.
I originally needed this library to support AWS' Elasticsearch Service, but this library is 'AWS service agnostic'.
Import via SBT
Currently available for scala 2.10, 2.11 and 2.12. In your build.sbt file,
resolvers += Resolver.jcenterRepo libraryDependencies += "io.ticofab" %% "aws-request-signer" % "0.5.2"
The procedure to sign AWS Api requests is described on the official documentation. The idea is that each request must be signed through the evaluation of a hash which depends on the very request itself. The resulting string can then be added to the request either as a header or as a query param. This library focuses on the header way.
You first need to instantiate the signer, for example:
val awsCredentialProvider = new StaticCredentialsProvider(new BasicAWSCredentials("YOUR-ID", "YOUR-SECRET")) val service = "es" val region = "eu-central-1" def clock(): LocalDateTime = LocalDateTime.now(ZoneId.of("UTC")) val signer = io.ticofab.AwsSigner(awsCredentialProvider, region, service, clock)
Then use it for each request, via
def getSignedHeaders(uri: String, method: String, queryParams: Map[String, String], headers: Map[String, String], payload: Option[Array[Byte]]): Map[String, String]
Check the examples in the test folder of this project. Once you have the headers, add them to your HTTP request and fire it.
Copyright 2016, 2017 Fabio Tiriticco - Fabway Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
*Note that all licence references and agreements mentioned in the AWS Request Signer README section above are relevant to that project's source code only.