Skip to content

OSGP/gxf-java-utilities

Repository files navigation

GXF Java utilities

This repository contains utility libraries for GXF java applications.

kafka-azure-oauth

The library makes it possible to configure OAUTH Kafka authentication using environment variables

OAuth is enabled by setting the kafka-oauth profile. The following environment variables are required:

  • AZURE_CLIENT_ID: client id of the oauth server
  • AZURE_AUTHORITY_HOST: url of the oauth server (ex: http://oauth-server.com/)
  • AZURE_TENANT_ID: Tenant id of the oauth resource
  • AZURE_FEDERATED_TOKEN_FILE: File containing the oauth token.
  • OAUTH_SCOPE: Scope of the oauth client

kafka-avro

Library containing a Kafka serializer and deserializer for avro objects.

It can be configured with the encoder / decoder of a specific object using:

new DefaultKafkaConsumerFactory(
        kafkaProperties.buildConsumerProperties(),
        ErrorHandlingDeserializer(AvroSerializer(AvroMessage.getEncoder())),
        ErrorHandlingDeserializer(AvroDeserializer(AvroMessage.getDecoder()))
)

kafka-message-signing

Library for signing Kafka messages and for verification of signed Kafka messages.

Two variations are supported:

  • The signature is set on the message, via SignableMessageWrapper's signature field;
  • The signature is set as a signature header on the Kafka ProducerRecord.

The MessageSigner class is used for both signing and verifying a signature.

To sign a message, use one of MessageSigner's sign methods:

  • signUsingField(...) using the SignableMessageWrapper to wrap your Avro object;
  • signUsingHeader(...) to add the signature to the Avro object's header.

To verify a signature, use one of MessageSigner's verify methods:

  • verifyUsingField(...) using the SignableMessageWrapper to wrap your Avro object;
  • verifyUsingHeader(...) to read the signature from the Avro object's header.

Spring Auto Configuration

You can configure the settings in your application.yaml (or properties), for example:

message-signing:
  signing-enabled: true
  strip-avro-header: true
  signature-algorithm: SHA256withRSA
  signature-provider: SunRsaSign
  key-algorithm: RSA
  private-key-file: classpath:rsa-private.pem
  public-key-file: classpath:rsa-public.pem

Custom or multiple certificates configuration

You can create your own MessageSigningProperties object and use MessageSigner.newMessageSigner(props). Spring Boot users can extend the MessageSigningProperties to add @ConfigurationProperties capabilities and/or to support multiple configurations.

If you want to support multiple keys, you also have to instantiate multiple MessageSigner beans.

Auto configuration (see above) will see when you defined your own MessageSigner or MessageSigningProperties bean and will not auto-create one.

@ConfigurationProperties(prefix = "your-app.your-message-signing")
class YourMessageSigningProperties extends MessageSigningProperties {
}

@Configuration
class MessageSigningConfiguration {
    @Bean
    public MessageSigner yourMessageSigner(YourMessageSigningProperties yourMessageSigningProperties) {
        return new MessageSigner(yourMessageSigningProperties);
    }
}

Creating a public/private key for signing

To generate a public/private keypair, use these two commands:

openssl genrsa -out rsa-private.pem 2048
openssl rsa -in rsa-private.pem -pubout -out rsa-public.pem

The private key (PKCS#8) and public key can then be set in the configuration as shown above. To view the generated files, you can use

openssl rsa -noout -text -in rsa-private.pem
openssl rsa -noout -text -pubin -in rsa-public.pem

oauth-token-client

Library that easily configures the msal4j oauth token provider.

The client requires the following properties:

# If not set to true no other configuration is required
oauth.client.enabled=true
oauth.client.token-endpoint=https://localhost:56788/token
oauth.client.client-id=client-id
oauth.client.scope=client-scope
# Resources
oauth.client.private-key=classpath:keys/private-key.key
oauth.client.certificate=classpath:keys/certificate.crt