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

MXD Backend Service API #172

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
47 commits
Select commit Hold shift + click to select a range
6925a39
backend-service-changes
ravinderkumarsap Dec 3, 2023
3b0b512
feedback changes completed
ravinderkumarsap Dec 4, 2023
dd29d45
feedback changes completed
ravinderkumarsap Dec 4, 2023
f28be31
feedback changes
ravinderkumarsap Dec 4, 2023
30cc021
feedback changes
ravinderkumarsap Dec 6, 2023
728d7bb
feedback changes
ravinderkumarsap Dec 6, 2023
bdef4fa
feedback changes
ravinderkumarsap Dec 8, 2023
ae38a3e
feedback changes
ravinderkumarsap Dec 11, 2023
090e8f2
feedback changes
ravinderkumarsap Dec 11, 2023
e23e9f9
Merge branch 'main' of https://github.com/sap-contributions/eclipse-t…
ravinderkumarsap Dec 28, 2023
3c83912
Merge branch 'main' of https://github.com/sap-contributions/eclipse-t…
ravinderkumarsap Jan 3, 2024
e4702eb
Implemented EDC Modules for Rest API
ravinderkumarsap Jan 3, 2024
2b10726
Pipelines changes
ravinderkumarsap Jan 3, 2024
ec30769
pipeline changes
ravinderkumarsap Jan 3, 2024
3789aa0
feedback changes
ravinderkumarsap Jan 4, 2024
2000f24
updated readme file
ravinderkumarsap Jan 8, 2024
558932c
terraform file update
ravinderkumarsap Jan 8, 2024
3737ac8
terraform file update header license
ravinderkumarsap Jan 8, 2024
e050747
dockerize backend-service
ravinderkumarsap Jan 8, 2024
36ee14d
dockerize backend-service readme update file
ravinderkumarsap Jan 8, 2024
e3f4701
dockerize cmd run using run-terraform
ravinderkumarsap Jan 9, 2024
db0c147
permission change for gradlew file
ravinderkumarsap Jan 9, 2024
6fb2837
included java for backend-service build in run-terraform
ravinderkumarsap Jan 9, 2024
ec6c29d
update clusters name : run-terraform
ravinderkumarsap Jan 9, 2024
0026ac2
terraform null warning removed module
ravinderkumarsap Jan 9, 2024
54889f5
E2E tests validation in postman completed
ravinderkumarsap Jan 16, 2024
39adc04
E2E tests validation in postman completed reverted
ravinderkumarsap Jan 16, 2024
2b3f9e1
Merge branch 'main' of https://github.com/sap-contributions/eclipse-t…
ravinderkumarsap Feb 17, 2024
eb93830
Merge branch 'fix/231_private_key' of https://github.com/sap-contribu…
ravinderkumarsap Feb 21, 2024
a44050c
Merge branch 'main' of https://github.com/sap-contributions/eclipse-t…
ravinderkumarsap Feb 27, 2024
79dacbe
add JAVA_TOOL_OPTIONS debug and add url to ingress
ravinderkumarsap Feb 27, 2024
817c573
remove hardcoded secrets
ravinderkumarsap Feb 27, 2024
8da6e83
Merge branch 'main' of https://github.com/sap-contributions/eclipse-t…
ravinderkumarsap Mar 8, 2024
67fe2ae
feedback changes
ravinderkumarsap Mar 8, 2024
19573f8
Added e2e tests, refactored code
May 13, 2024
5501e56
Updated readme file
May 14, 2024
ffa16bf
Removed hardcoded URL
May 16, 2024
d0d5b1b
Merge pull request #41 from sap-contributions/backend-service
ieuna May 17, 2024
9d802c9
Updated workflow, fixed issue with db name
May 27, 2024
09dfcd8
Removed braces
May 27, 2024
5ea9e95
Merge pull request #45 from sap-contributions/backend-service
ieuna May 28, 2024
103be8a
Removed redundant codes, Updated EDC version
Jun 18, 2024
1053ab7
Merge pull request #60 from sap-contributions/feat/backend-service
ieuna Jun 18, 2024
3401262
Merged branch main into backend-service
Jun 20, 2024
13e3443
Updated backend service terraform config
Jun 21, 2024
6561a72
Merge pull request #67 from sap-contributions/feat/backend-service
ieuna Jun 24, 2024
07b807b
Fixed terraform file format
Jun 24, 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
12 changes: 10 additions & 2 deletions .github/workflows/run-terraform.yml
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ jobs:
uses: helm/kind-action@v1.10.0
with:
config: mxd/kind.config.yaml

cluster_name: mxd
- name: "Install nginx ingress controller"
run: |-
echo "::notice title=nginx ingress on KinD::For details how to run nginx ingress on KinD check https://kind.sigs.k8s.io/docs/user/ingress/#ingress-nginx"
Expand All @@ -53,7 +53,15 @@ jobs:
--for=condition=ready pod \
--selector=app.kubernetes.io/component=controller \
--timeout=90s

- name: Setup JDK 21
uses: actions/setup-java@v3.13.0
with:
java-version: '21'
distribution: 'temurin'
- name: "Backend-Service Build"
working-directory: mxd/backend-service
run: |-
./gradlew clean dockerize
- name: "Terraform init"
working-directory: mxd
run: |-
Expand Down
47 changes: 47 additions & 0 deletions .github/workflows/verify-backend-service.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
#
# Copyright (c) 2024 SAP SE
#
# This program and the accompanying materials are made available under the
# terms of the Apache License, Version 2.0 which is available at
# https://www.apache.org/licenses/LICENSE-2.0
#
# SPDX-License-Identifier: Apache-2.0
#
# Contributors:
# SAP SE - initial API and implementation

---
name: "Run Tests"

on:
push:
branches:
- main

pull_request:
branches:
- main
paths:
- 'mxd/backend-service/**'

# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:

concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true

jobs:

End-To-End-Tests:
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4
- uses: actions/setup-java@v3
with:
distribution: 'temurin'
java-version: '21'

- run: ./gradlew test
working-directory: mxd/backend-service
9 changes: 8 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -35,4 +35,11 @@ override.tf.json
terraform.rc

.idea/
mxd/.terraform.lock.hcl
mxd/.terraform.lock.hcl
#Ignore Java Classes and Gradle Build Files
.class.*
mxd/backend-service/.gradle
.lock
.bin
mxd/backend-service/build
*.log
3 changes: 3 additions & 0 deletions mxd/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,8 @@ once and are accessible by all participants.
For the most bare-bones installation of the dataspace, execute the following commands in a shell:

```shell
cd <path/of/mxd/backend-service>
./gradlew clean dockerize
# firstly go to the folder containing the config files
cd <path/of/mxd>
kind create cluster -n mxd --config kind.config.yaml
Expand All @@ -41,6 +43,7 @@ kubectl wait --namespace ingress-nginx \
--for=condition=ready pod \
--selector=app.kubernetes.io/component=controller \
--timeout=90s
kind load docker-image --name mxd backend-service:1.0.0
terraform init
terraform apply
# type "yes" and press enter when prompted to do so
Expand Down
93 changes: 93 additions & 0 deletions mxd/backend-service.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,93 @@
#
# Copyright (c) 2023 Contributors to the Eclipse Foundation
#
# See the NOTICE file(s) distributed with this work for additional
# information regarding copyright ownership.
#
# This program and the accompanying materials are made available under the
# terms of the Apache License, Version 2.0 which is available at
# https://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.
#
# SPDX-License-Identifier: Apache-2.0
#

resource "kubernetes_deployment" "backend-service" {

metadata {
name = "backend-service"
labels = {
App = "backend-service"
}
}

spec {
replicas = 1
selector {
match_labels = {
App = "backend-service"
}
}
template {
metadata {
labels = {
App = "backend-service"
}
}
spec {
container {
name = "backend-service"
image = "backend-service:1.0.0"
image_pull_policy = "Never"

port {
container_port = 8080
name = "backend-port"
}
env {
name = "edc.datasource.backendservice.url"
value = "jdbc:postgresql://${local.backendservice-postgres.database-url}/${local.databases.backendservice.database-name}"
}

env {
name = "edc.datasource.backendservice.user"
value = local.databases.backendservice.database-username
}
env {
name = "edc.datasource.backendservice.password"
value = local.databases.backendservice.database-password
}
env {
name = "web.http.port"
value = 8080
}
env {
name = "JAVA_TOOL_OPTIONS"
value = "-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=1044"
}
}
}
}
}
}

resource "kubernetes_service" "backend-service" {
metadata {
name = "backend-service"
}
spec {
selector = {
App = "backend-service"
}
port {
port = 8080
name = "backend-port"
}
}
}

23 changes: 23 additions & 0 deletions mxd/backend-service/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
#
# Copyright (c) 2024 SAP SE
#
# This program and the accompanying materials are made available under the
# terms of the Apache License, Version 2.0 which is available at
# https://www.apache.org/licenses/LICENSE-2.0
#
# SPDX-License-Identifier: Apache-2.0
#
# Contributors:
# SAP SE - initial API and implementation
#
#

FROM eclipse-temurin:21.0.2_13-jre-alpine

WORKDIR /app

COPY backend-service.jar /app/backend-service.jar

EXPOSE 8080

CMD java -jar backend-service.jar
134 changes: 134 additions & 0 deletions mxd/backend-service/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,134 @@
# Tractus-X Backend Service

## API Details Summary

The Backend Service is used to simulate a data source or sink enabling the transfer of data and supporting the validation of the end-to-end process. It has the following APIs:
- [Contents API](#contents-api)
- [Transfer API](#transfer-api)

## Contents API

### Generate a random content

- Method: GET
- URL: http://localhost/backend-service/api/v1/contents/random
- Sample response:

```json
{
"userId": 718895412,
"title": "tmnx",
"text": "ivj"
}
```

### Save the generated content

- Method: POST
- URL: http://localhost/backend-service/api/v1/contents
- Request body:

```json
{
"userId": 718895412,
"title": "tmnx",
"text": "ivj"
}
```

- Sample response containing content id and URL:

```json
{
"id": "3b777103-5e06-461b-90c6-1f99e597f60d",
"url": "http://localhost:8080/api/v1/contents/3b777103-5e06-461b-90c6-1f99e597f60d"
}
```
This URL will be used as an endpoint in the transfer API.

### Fetch a content

- Method: GET
- URL: http://localhost/backend-service/api/v1/contents/{content-id}
- Sample response:

```json
{
"userId": 718895412,
"title": "tmnx",
"text": "ivj"
}
```

### Fetch all contents

- Method: GET
- URL: http://localhost/backend-service/api/v1/contents
- Sample response:

```json
[
{
"userId": 1,
"id": 1,
"title": "delectus aut autem",
"completed": false
},
{
"userId": 1,
"id": 2,
"title": "quis ut nam facilis et officia qui",
"completed": false
}
]
```

## Transfer API

### Accept transfer data

- Method: POST
- URL: http://localhost/backend-service/api/v1/transfers
- Request/response:

```json
{
"id": "123456789011",
"endpoint": "http://localhost:8080/api/v1/contents/3b777103-5e06-461b-90c6-1f99e597f60d",
"authKey": "Authorization",
"authCode": "100000",
"properties": {}
}
```

### Get transfer data with ID

- Method: GET
- URL: http://localhost/backend-service/api/v1/transfers/{id}
- Sample response:

```json
{
"id": "123456789011",
"endpoint": "http://localhost:8080/api/v1/contents/3b777103-5e06-461b-90c6-1f99e597f60d",
"authKey": "Authorization",
"authCode": "100000",
"properties": {}
}
```

### Get transfer content
Get the content which is stored at the above endpoint:
- Method: GET
- URL: http://localhost/backend-service/api/v1/transfers/{id}/contents
- Sample response:

```json
{
"userId": 718895412,
"title": "tmnx",
"text": "ivj"
}
```

Alternatively, please check out the [Postman collections here](./assets/postman)
Loading
Loading