Skip to content
This repository has been archived by the owner on Mar 9, 2020. It is now read-only.

Latest commit

 

History

History
67 lines (59 loc) · 3.23 KB

README.md

File metadata and controls

67 lines (59 loc) · 3.23 KB

hwsc-document-svc

Purpose

Provides services to hwsc-app-gateway-svc for CRUD document, and indexing file metadata in MongoDB and ElasticSearch.

Contract

The proto file and compiled proto buffers are located in hwsc-api-blocks and hwsc-api-blocks lib.

GetStatus

  • Gets the current status of the service.

CreateDocument

  • Creates a document in MongoDB.
  • Returns the Document.

ListUserDocumentCollection

  • Retrieves all the MongoDB documents for a specific user with the given UUID.
  • Returns a collection of Documents.

UpdateDocument

  • (completely) Updates a MongoDB document using DUID and UUID.
  • Returns the updated Document.

DeleteDocument

  • Deletes a MongoDB document using DUID.
  • Returns the deleted Document.

AddFileMetadata

  • Adds a new FileMetadata in a MongoDB document using a given url, DUID.
  • Returns the updated Document.

DeleteFileMetadata

  • Deletes a FileMetadata in a MongoDB document using a given FUID, DUID.
  • Returns the updated Document.

ListDistinctFieldValues

  • Retrieves all the unique fields values required for the front-end drop-down filter.
  • Returns the QueryTransaction

QueryDocument

  • Queries the MongoDB server with the given query parameters.
  • Returns a collection of Documents.

Prerequisites

  • GoLang version go 1.12
  • GoLang Modules go mod
  • Go Source Code Linter golint
  • mongo-go-driver beta 1.0.0-rc1
  • Docker
  • [Optional] If a new proto file and compiled proto buffer exists in hwsc-api-blocks, update dependency $ go get -u <package name>

How to Run without Docker Container

  1. Refer to hwsc-dev-ops to run DB locally
  2. Grab prod/dev/test config file from Slack
  3. Run main $ go run main.go

How to Run with Docker Container

  1. Refer to hwsc-dev-ops to run DB locally
  2. $ generate_container.sh
  3. Find your image $ docker images
  4. Acquire env.list configuration
  5. $ docker run --env-file ./env.list -it -p 50051:50051 <imagename>
  6. Optional: run $ docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' <container id> to find the proper address, and update env.list

How to Run Unit Test

  1. Place DB migration source codes to be tested in test_fixtures/mongodb/
  2. $ cd service
  3. The unit test will programmatically run the test container and DB migration as required
  4. For command-line summary, $ go test -cover -v -failfast -race
  5. For comprehensive summary, $ bash unit_test.sh
  6. If applicable, copy and push the new DB migration source codes in hwsc-dev-ops under test for integration testing

How to Run Integration Test

  • Refer to hwsc-dev-ops for running integration test
  • Ensure the service is tested using the built container in DockerHub