-
Riabokon Stanislav(EPAM)[GCP] authoredRiabokon Stanislav(EPAM)[GCP] authored
Storage Service
Storage service is a Spring Boot service that provides a set of APIs to manage the entire metadata life-cycle such as ingestion (persistence), modification, deletion, versioning and data schema.
Table of Contents
- Getting started
- Settings and Configuration
- Run service
- Testing
- Deployment
- Tutorial
- Entitlements groups
- Licence
Getting started
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes. See deployment for notes on how to deploy the project on a live system.
Settings and Configuration
Requirements:
- Mandatory
- JDK 17
- Lombok 1.28 or later
- Maven
- For Google Cloud only
- GCloud SDK with java (latest version)
Google Cloud Service Configuration:
Google Cloud service configuration
Run service
Run Locally
Check that maven is installed:
$ mvn --version
Apache Maven 3.6.0
Maven home: /usr/share/maven
Java version: 17.0.7
...
You may need to configure access to the remote maven repository that holds the OSDU dependencies. This file should live
within ~/.mvn/community-maven.settings.xml
:
$ cat ~/.m2/settings.xml
<?xml version="1.0" encoding="UTF-8"?>
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd">
<servers>
<server>
<id>community-maven-via-private-token</id>
<!-- Treat this auth token like a password. Do not share it with anyone, including Microsoft support. -->
<!-- The generated token expires on or before 11/14/2019 -->
<configuration>
<httpHeaders>
<property>
<name>Private-Token</name>
<value>${env.COMMUNITY_MAVEN_TOKEN}</value>
</property>
</httpHeaders>
</configuration>
</server>
</servers>
</settings>
- Update the Google cloud SDK to the latest version:
gcloud components update
- Set Google Project Id:
gcloud config set project <YOUR-PROJECT-ID>
- Perform a basic authentication in the selected project:
gcloud auth application-default login
- Navigate to storage service's root folder and run:
mvn clean install
-
If you wish to see the coverage report then go to target\site\jacoco\index.html and open index.html
-
If you wish to build the project without running tests
mvn clean install -DskipTests
After configuring your environment as specified above, you can follow these steps to build and run the application. These steps should be invoked from the repository root.
cd provider/storage-gc/ && mvn spring-boot:run
Testing
Running E2E Tests
This section describes how to run cloud OSDU E2E tests.
Google Cloud test configuration:
Google Cloud service configuration
Deployment
Storage Service is compatible with App Engine Flexible Environment and Cloud Run.
-
To deploy into Cloud run, please, use this documentation: https://cloud.google.com/run/docs/quickstarts/build-and-deploy
-
To deploy into GKE, please, use this documentation: https://cloud.google.com/kubernetes-engine/docs/deploy-app-cluster
Tutorial
Entitlements groups
Storage service account should have entitlements groups listed below:
- service.entitlements.user
- service.legal.user
- users
License
Copyright © Google LLC
Copyright © EPAM Systems
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.