Skip to content
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/s3 init docs #66

Merged
merged 36 commits into from
Aug 14, 2024
Merged
Show file tree
Hide file tree
Changes from 34 commits
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
ba73128
:fire: s3-client rm url override
simonhir Aug 12, 2024
61132f6
:fire: s3-client rm url override
simonhir Aug 12, 2024
aab3dd2
:art: s3-client format
simonhir Aug 12, 2024
b25a63a
:pencil2: s3-integration client starter fix method naming
simonhir Aug 12, 2024
3b2c635
:art: s3-integration format
simonhir Aug 12, 2024
2165c2e
Merge branch 'main' into refactor/s3-client-rm-url-override
simonhir Aug 12, 2024
8914fda
:recycle: s3-integration extract rest
simonhir Aug 12, 2024
d74fef9
:art: s3-integration client fix pom order
simonhir Aug 12, 2024
48c756e
:recycle: s3-integration service to rest-service
simonhir Aug 12, 2024
fdfaab6
:recycle: s3-integration extract rest from client
simonhir Aug 12, 2024
06fd759
:recycle: s3-integration rename client core module
simonhir Aug 12, 2024
1a4fb2d
:recycle: s3-integration client move java doc to interfaces
simonhir Aug 12, 2024
4c77dad
:recycle: s3-integration client move java doc to interfaces format
simonhir Aug 12, 2024
bd38b61
Merge branch 'refs/heads/main' into refactor/s3-extract-rest
simonhir Aug 12, 2024
7896b38
:recycle: s3 rest client refactor interface naming
simonhir Aug 12, 2024
9982561
:art: s3 client core format
simonhir Aug 12, 2024
b110f02
:recycle: s3 mv rest to submodule
simonhir Aug 14, 2024
047d2ab
Merge branch 'refs/heads/main' into refactor/s3-extract-rest
simonhir Aug 14, 2024
4a2ba07
:recycle: s3 client fix reactive return mixed
simonhir Aug 12, 2024
9e859a7
:recycle: s3 client fix reactive return mixed
simonhir Aug 12, 2024
24f3819
:recycle: s3 client simplify duplicate code DocumentStorageFileReposi…
simonhir Aug 12, 2024
ba72ebe
:sparkles: s3 init java client
simonhir Aug 12, 2024
0c82da0
:sparkles: s3 init java client starter
simonhir Aug 12, 2024
e199b65
:recycle: s3 java client refactor interface naming
simonhir Aug 12, 2024
0f29358
:recycle: s3 client rename FileService to FileValidationService
simonhir Aug 12, 2024
9a9a2a9
:fire: s3 java client rm unused properties
simonhir Aug 12, 2024
db08d69
:bug: s3 rest client fix DocumentStorageFileRestRepository naming
simonhir Aug 13, 2024
1507cee
:recycle: s3 mv java to submodule
simonhir Aug 14, 2024
204f3c3
:fire: s3 rm unneeded pom comments
simonhir Aug 14, 2024
e95d504
Merge remote-tracking branch 'refs/remotes/origin/main' into feature/…
simonhir Aug 14, 2024
fa8a7bd
:sparkles: s3 rest client define default oauth client properties
simonhir Aug 14, 2024
7aa9ce8
:recycle: s3 rest service rename sso issuer url property
simonhir Aug 14, 2024
a420c15
:memo: integrations init docs
simonhir Aug 13, 2024
0ea0563
:memo: s3 add usage to README
simonhir Aug 13, 2024
bebde73
Update refarch-integrations/refarch-s3-integration/README.md
simonhir Aug 14, 2024
c93ea64
:memo: s3 README rm muenchen references
simonhir Aug 14, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ As counterpart there are also [refarch-templates](https://github.com/it-at-m/ref
The usage of the different components is described in their corresponding README.md

- [refarch-gateway](./refarch-gateway/README.md)
- [refarch-integrations](./refarch-integrations/README.md)

## Contributing

Expand Down
16 changes: 16 additions & 0 deletions refarch-integrations/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
# RefArch integrations

Collection of different integration which can be used as is in RefArch projects.

## Integrations

- [s3-integration](./refarch-s3-integration/README.md): For CRUD operations on a s3 storage. Also used for file handling
in other integrations.

## Naming conventions

The different submodules of integrations follow following naming conventions:

- `*-core`: Implementation of the base functionality of the integration in hexagonal architecture.
- `*-starter`: Provides Beans of core services.
- `*-service`: A Spring application using the starter. Is provided as container image. Should not be used as dependency.
70 changes: 70 additions & 0 deletions refarch-integrations/refarch-s3-integration/README.md
simonhir marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
# RefArch S3 integration

Integration for CRUD operations on a s3 storage. Also used for file handling in other integrations.

## Modules

The S3 integration follows the [default naming conventions](../README.md#naming-conventions).

Beside the default integration it contains different client libraries for accessing the integration. The client
libraries are especially provided for usage in other integrations.

- REST: The rest client uses the rest endpoints of the s3-rest-service to manage data in s3.
- Java: The Java client directly uses the in ports of the s3-core.

## Usage

```xml

<dependencies>
<!-- REST -->
<!-- requires refarch-s3-integration-rest-service -->
<dependency>
<groupId>de.muenchen.refarch</groupId>
<artifactId>refarch-s3-integration-rest-starter</artifactId>
<version>...</version>
</dependency>
<!-- or Java -->
<dependency>
<groupId>de.muenchen.refarch</groupId>
<artifactId>refarch-s3-integration-java-starter</artifactId>
<version>...</version>
</dependency>
</dependencies>
```

## Configuration

Following are the properties to configure the different modules. Some of them a custom defined and others are synonyms
simonhir marked this conversation as resolved.
Show resolved Hide resolved
for spring package properties.
Whether a property is an alias can be checked in the corresponding `application.yml` of each module.

### s3-integration-rest-service

| Property | Description | Example |
|-----------------------------------|----------------------------------------------------------------|---------------------------------------------------|
| `refarch.s3.url` | Url of s3 endpoint to connect to. | `s3p.muenchen.de` |
| `refarch.s3.bucket-name` | Name of the bucket to connect to. | `refarch-bucket` |
| `refarch.s3.access-key` | Access key to use for connection. | |
| `refarch.s3.secret-key` | Secret key to use for connection. | |
| `refarch.security.sso-issuer-url` | Issuer url of oAuth2 service used for securing rest endpoints. | `https://sso.muenchen.de/auth/realms/muenchen.de` |

### s3-integration-java-client-starter

| Property | Description | Example |
|------------------------------------------------------------|-------------------------------------------------------|--------------------------|
| `refarch.s3.client.max-file-size` (optional) | Single file limit for up- or downloading in byte. | `10MB` |
| `refarch.s3.client.max-batch-size` (optional) | Limit for up- or downloading a list of files in byte. | `100MB` |
| `refarch.s3.client.supported-file-extensions.*` (optional) | Map of allowed file extensions for up- and download. | `pdf: "application/pdf"` |

### s3-integration-rest-client-starter

All properties of [s3-integration-java-client-starter](#s3-integration-rest-client-starter) and following:

| Property | Description | Example |
|------------------------------------------|----------------------------------------------------------------------------|---------------------------------------------------|
| `refarch.s3.client.document-storage-url` | Url to the RefArch S3 integration service. | `http://s3-integration-service:8080` |
| `refarch.s3.client.enable-security` | Switch to enable or disable oAuth2 authentication against s3 service. | `true` |
| `refarch.security.sso-issuer-url` | Issuer url of oAuth2 service to use for authentication against s3 service. | `https://sso.muenchen.de/auth/realms/muenchen.de` |
| `refarch.s3.client.client-id` | Client id to be used for authentication. | `refarch_client` |
| `refarch.s3.client.client-secret` | Client secret to be used for gathering client service account token. | |
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
import de.muenchen.refarch.integration.s3.client.api.FileApiApi;
import de.muenchen.refarch.integration.s3.client.api.FolderApiApi;
import de.muenchen.refarch.integration.s3.client.domain.model.SupportedFileExtensions;
import de.muenchen.refarch.integration.s3.client.factory.YamlPropertySourceFactory;
import de.muenchen.refarch.integration.s3.client.properties.S3IntegrationClientProperties;
import de.muenchen.refarch.integration.s3.client.service.FileValidationService;
import jakarta.annotation.PostConstruct;
Expand All @@ -16,10 +17,12 @@
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;
import org.springframework.security.oauth2.client.AuthorizedClientServiceOAuth2AuthorizedClientManager;
import org.springframework.security.oauth2.client.OAuth2AuthorizedClientService;
import org.springframework.security.oauth2.client.registration.ClientRegistrationRepository;
import org.springframework.security.oauth2.client.web.reactive.function.client.ServletOAuth2AuthorizedClientExchangeFilterFunction;
import org.springframework.util.ResourceUtils;
import org.springframework.web.reactive.function.client.WebClient;

@Configuration
Expand All @@ -30,6 +33,7 @@
)
@RequiredArgsConstructor
@EnableConfigurationProperties(S3IntegrationClientProperties.class)
@PropertySource(value = ResourceUtils.CLASSPATH_URL_PREFIX + "application.yml", factory = YamlPropertySourceFactory.class)
devtobi marked this conversation as resolved.
Show resolved Hide resolved
@Slf4j
public class S3IntegrationClientAutoConfiguration {

Expand Down
devtobi marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
package de.muenchen.refarch.integration.s3.client.factory;

import java.io.IOException;
import java.util.Objects;
import java.util.Properties;
import org.springframework.beans.factory.config.YamlPropertiesFactoryBean;
import org.springframework.core.env.PropertiesPropertySource;
import org.springframework.core.env.PropertySource;
import org.springframework.core.io.support.EncodedResource;
import org.springframework.core.io.support.PropertySourceFactory;
import org.springframework.lang.NonNull;

public class YamlPropertySourceFactory implements PropertySourceFactory {

@Override
@NonNull
public PropertySource<?> createPropertySource(String name, EncodedResource resource) throws IOException {
YamlPropertiesFactoryBean factory = new YamlPropertiesFactoryBean();
factory.setResources(resource.getResource());
Properties properties = factory.getObject();
return new PropertiesPropertySource(
Objects.requireNonNull(resource.getResource().getFilename()),
Objects.requireNonNull(properties));
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
spring:
security:
oauth2:
client:
provider:
keycloak:
issuer-uri: ${refarch.security.sso-issuer-url}
user-info-uri: ${refarch.security.sso-issuer-url}/protocol/openid-connect/userinfo
jwk-set-uri: ${refarch.security.sso-issuer-url}/protocol/openid-connect/certs
user-name-attribute: user_name
registration:
s3:
provider: keycloak
authorization-grant-type: client_credentials
client-id: ${refarch.s3.client.client-id}
client-secret: ${refarch.s3.client.client-secret}
scope: email, profile, openid # needed for userInfo endpoint
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
SSO_ISSUER_URL: http://keycloak:8100/auth/realms/local_realm
refarch:
security:
sso-issuer-url: http://keycloak:8100/auth/realms/local_realm
s3:
bucket-name: test-bucket
access-key: minio
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ spring:
oauth2:
resourceserver:
jwt:
issuer-uri: ${SSO_ISSUER_URL}
issuer-uri: ${refarch.security.sso-issuer-url}

server:
error:
Expand All @@ -36,7 +36,7 @@ management:

security:
oauth2:
resource.user-info-uri: ${SSO_ISSUER_URL}/protocol/openid-connect/userinfo
resource.user-info-uri: ${refarch.security.sso-issuer-url}/protocol/openid-connect/userinfo

refarch:
s3:
Expand Down