Allow vertx applications to retrieve configuration from S3 object storage. The library is an extension to the Vertx ConfigStoreFactory to allow configuration to be retrieved from a file kept in an S3 object store. For more information, see the vertx-config documentation.
<dependency>
<groupId>com.github.mikelee2082</groupId>
<artifactId>vertx-config-s3</artifactId>
<version>0.1.0</version>
</dependency>
Then run:
mvn install
Pass "s3" to the setType method when creating ConfigStoreOptions. The configuration store also requires standard S3 parameters to be passed, including:
- the object key
- the bucket where the object can be found
- the region
- an AWS access key (optional)
- an AWS secret access key (optional)
If AWS access key and secret access key are not provided, the DefaultCredentialsProvider will look for credentials in this order:
- Java System Properties - aws.accessKeyId and aws.secretAccessKey
- Environment Variables - AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY
- Credential profiles file at the default location (~/.aws/credentials) shared by all AWS SDKs and the AWS CLI
- Credentials delivered through the Amazon EC2 container service if AWS_CONTAINER_CREDENTIALS_RELATIVE_URI" environment variable is set and security manager has permission to access the variable,
- Instance profile credentials delivered through the Amazon EC2 metadata service
ConfigStoreOptions s3 = new ConfigStoreOptions()
.setType("s3")
.setFormat("json")
.setConfig(new JsonObject()
.put("key", "object_key")
.put("bucket", "bucketName")
.put("region", "us-west-2")
.put("access_key", "my_aws_access_key")
.put("secret_access_key", "my_aws_secret_access_key"));
ConfigRetriever retriever = ConfigRetriever.create(vertx, new ConfigRetrieverOptions().addStore(s3));
retriever.getConfig(responseHandler -> {
if (responseHandler.succeeeded()) {
JsonObject config = responseHandler.result();
}
});
Optionally, the endpoint URL can be overridden to point at another S3 interface, such as one provided by a locally-hosted Ceph cluster or Minio cluster.
ConfigStoreOptions s3 = new ConfigStoreOptions()
.setType("s3")
.setFormat("json")
.setConfig(new JsonObject()
.put("key", "object_key")
.put("bucket", "bucketName")
.put("region", "us-west-2")
.put("access_key", "my_aws_access_key")
.put("secret_access_key", "my_aws_secret_access_key")
.put("endpoint_url", "https://my-minio-cluster:9000"));