Skip to content

Commit

Permalink
fix(cn-browse): Implement Database Structure and Logic for Managing C…
Browse files Browse the repository at this point in the history
…all Numbers

Closes: MSEARCH-862
  • Loading branch information
psmagin committed Nov 28, 2024
1 parent 0bbcc23 commit d7f282c
Show file tree
Hide file tree
Showing 38 changed files with 890 additions and 247 deletions.
1 change: 1 addition & 0 deletions NEWS.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@

### Features
* Move Instance sub-entities population from database trigger to code ([MSEARCH-887](https://folio-org.atlassian.net/browse/MSEARCH-887))
* Call Numbers Browse: Implement Database Structure and Logic for Managing Call Numbers ([MSEARCH-862](https://folio-org.atlassian.net/browse/MSEARCH-862))

### Bug fixes
* Remove shelving order calculation for local call-number types
Expand Down
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -1011,4 +1011,4 @@ and the [Docker image](https://hub.docker.com/r/folioorg/mod-search/)

### Development tips

The development tips are described on the following page: [Development tips](doc/development.md)
The development tips are described on the following page: [Development tips](development.md)
189 changes: 114 additions & 75 deletions doc/development.md → development.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,115 @@
## Local Development Setup Using Docker Compose for mod-search Module

This guide will walk you through setting up your local development environment for the `mod-search` module using Docker Compose.
It includes setting up various services like API mock servers, OpenSearch, Kafka, PostgreSQL, and their respective UIs to aid during development.

### Prerequisites

Before you begin, ensure you have the following installed:
- [Docker](https://docs.docker.com/get-docker/)
- [Docker Compose](https://docs.docker.com/compose/install/)

Make sure your [.env file](docker/.env) includes the necessary variables: `DB_USERNAME`, `DB_PASSWORD`, `DB_DATABASE`, `PGADMIN_PORT`, `PGADMIN_DEFAULT_EMAIL`, and `PGADMIN_DEFAULT_PASSWORD`.

### Setup Environment

1. **Start Services**

Navigate to the docker folder in the project and execute:
```shell
docker compose -f docker/docker-compose.yml up -d
```

2. **Start the mod-search Application**

First of all the application should be packaged:
```shell
mvn clean package
```

To run the `mod-search` application, you have two options:
- **Build and Run the Docker Image:**
```shell
docker build -t dev.folio/mod-search .
docker run -p 8081:8081 -e "DB_HOST=postgres" -e "KAFKA_HOST=kafka" -e "ELASTICSEARCH_URL=http://elasticsearch:9200" dev.folio/mod-search
```
- **Run the Application Directly:** You can also run the application directly if your development environment is set up with the necessary Java runtime. Execute the following command from the root of your project:
```shell
java -jar target/mod-search-fat.jar
```

3. **Initialize Environment**

After starting the services and the mod-search application, invoke the following CURL command to post a tenant which will help in bringing up Kafka listeners and get indices created:
```shell
curl --location --request POST 'http://localhost:8081/_/tenant' \
--header 'Content-Type: application/json' \
--header 'x-okapi-tenant: test_tenant' \
--header 'x-okapi-url: http://localhost:9130' \
--data-raw '{
"module_to": "mod-search"
}'
```
You can check which tenants are enabled by wiremock in the file located at `src/test/resources/mappings/user-tenants.json`.

4. **Consortium Support for Local Environment Testing**

Consortium feature is defined automatically by calling the `/user-tenants` endpoint as outlined in the following CURL requests:
- **To enable the consortium feature:**
```shell
curl --location --request POST 'http://localhost:8081/_/tenant' \
--header 'Content-Type: application/json' \
--header 'x-okapi-tenant: consortium' \
--header 'x-okapi-url: http://localhost:9130' \
--data-raw '{
"module_to": "mod-search",
"parameters": [
{
"key": "centralTenantId",
"value": "consortium"
}
]
}'
```

- **Enable member tenant:**
```shell
curl --location --request POST 'http://localhost:8081/_/tenant' \
--header 'Content-Type: application/json' \
--header 'x-okapi-tenant: member_tenant' \
--header 'x-okapi-url: http://localhost:9130' \
--data-raw '{
"module_to": "mod-search",
"parameters": [
{
"key": "centralTenantId",
"value": "consortium"
}
]
}'
```

### Access Services

- **API Mock Server**: http://localhost:9130
- **OpenSearch Dashboard**: http://localhost:5601
- **Kafka UI**: http://localhost:8080
- **PgAdmin**: http://localhost:5050

### Monitoring and Logs

To monitor the logs for any of the services:
```
docker-compose logs [service_name]
```

### Stopping Services

To stop and remove all containers associated with the compose file:
```shell
docker compose -f docker/docker-compose.yml down
```

## Overview

`mod-search` is based on metadata-driven approach. It means that resource description is specified using JSON file and
Expand Down Expand Up @@ -44,7 +156,7 @@ the [full-text queries](https://www.elastic.co/guide/en/elasticsearch/reference/
|:--------------------|:-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| searchTypes | List of search types that are supported for the current field. Allowed values: `facet`, `filter`, `sort` |
| searchAliases | List of aliases that can be used as a field name in the CQL search query. It can be used to combine several fields together during the search. For example, a query `keyword all title` combines for instance record following fields - `title`, `alternativeTitles.alternativeTitle`, `indexTitle`, `identifiers.value`, `contributors.name`<br/>Other way of using it - is to rename field keeping the backward compatibility without required reindex. |
| index | Reference to the Elasticsearch mappings that are specified in [index-field-types](../src/main/resources/elasticsearch/index-field-types.json) |
| index | Reference to the Elasticsearch mappings that are specified in [index-field-types](src/main/resources/elasticsearch/index-field-types.json) |
| showInResponse | Marks field to be returned during the search operation. `mod-search` adds to the Elasticsearch query all marked field paths. See also: [Source filtering](https://www.elastic.co/guide/en/elasticsearch/reference/master/search-fields.html#source-filtering) |
| searchTermProcessor | Search term processor, which pre-processes incoming value from CQL query for the search request. |
| mappings | Elasticsearch fields mappings. It can contain new field mapping or can enrich referenced mappings, that comes from `index-field-types` |
Expand Down Expand Up @@ -251,77 +363,4 @@ assertThatThrownBy(() -> service.doExceptionalOperation())
### Integration testing

The module uses [Testcontainers](https://www.testcontainers.org/) to run Elasticsearch, Apache Kafka and PostgreSQL
in embedded mode. It is required to have Docker installed and available on the host where the tests are executed.

### Local environment testing
Navigate to the docker folder in the project and run `docker-compose up`.
This will build local mod-search image and bring it up along with all necessary infrastructure:
- elasticsearch along with dashboards (kibana analogue from opensearch)
- kafka along with zookeeper
- postgres
- wiremock server for mocking external api calls (for example authorization)

Then, you should invoke
```shell
curl --location --request POST 'http://localhost:8081/_/tenant' \
--header 'Content-Type: application/json' \
--header 'x-okapi-tenant: test_tenant' \
--header 'x-okapi-url: http://api-mock:8080' \
--data-raw '{
"module_to": "mod-search-$version$",
"purge": "false"
}
```
to post some tenant in order to bring up kafka listeners and get indices created.
You can check which tenants enabled by wiremock in the `src/test/resources/mappings/user-tenants.json`

To rebuild mod-search image you should:
- bring down existing containers by running `docker-compose down`
- run `docker-compose build mod-search` to build new mod-search image
- run `docker-compose up` to bring up infrastructure

Hosts/ports of containers to access functionality:
- `http://localhost:5601/` - dashboards UI for elastic monitoring, data modification through dev console
- `localhost` - host, `5010` - port for remote JVM debug
- `http://localhost:8081` - for calling mod-search REST api. Note that header `x-okapi-url: http://api-mock:8080` should be added to request for apis that take okapi url from headers
- `localhost:29092` - for kafka interaction. If you are sending messages to kafka from java application with `spring-kafka` then this host shoulb be added to `spring.kafka.bootstrap-servers` property of `application.yml`

### Consortium support for Local environment testing
Consortium feature is defined automatically at runtime by calling /user-tenants endpoint.
Consortium feature on module enable is defined by 'centralTenantId' tenant parameter.

Invoke the following
```shell
curl --location --request POST 'http://localhost:8081/_/tenant' \
--header 'Content-Type: application/json' \
--header 'x-okapi-tenant: consortium' \
--header 'x-okapi-url: http://api-mock:8080' \
--data-raw '{
"module_to": "mod-search-$version$",
"parameters": [
{
"key": "centralTenantId",
"value": "consortium"
}
]
}
```

Then execute the following to enable `member tenant`
```shell
curl --location --request POST 'http://localhost:8081/_/tenant' \
--header 'Content-Type: application/json' \
--header 'x-okapi-tenant: member_tenant' \
--header 'x-okapi-url: http://api-mock:8080' \
--data-raw '{
"module_to": "mod-search-$version$",
"parameters": [
{
"key": "centralTenantId",
"value": "consortium"
}
]
}
```
Consider that `tenantParameters` like `loadReference` and `loadSample` won't work because `loadReferenceData`
method is not implemented in the `SearchTenantService` yet.
in embedded mode. It is required to have Docker installed and available on the host where the tests are executed.
16 changes: 4 additions & 12 deletions docker/.env
Original file line number Diff line number Diff line change
@@ -1,18 +1,10 @@
COMPOSE_PROJECT_NAME=folio-mod-search
DB_HOST=postgres
DB_PORT=5432

# Postgres variables
DB_DATABASE=okapi_modules
DB_USERNAME=folio_admin
DB_PASSWORD=folio_admin

# PgAdmin variables
PGADMIN_DEFAULT_EMAIL=[email protected]
PGADMIN_DEFAULT_PASSWORD=admin
PGADMIN_PORT=5050
KAFKA_HOST=kafka
KAFKA_PORT=9092
REPLICATION_FACTOR=1
ENV=folio
DEBUG_PORT=5005
OKAPI_URL=http://api-mock:8080
PGADMIN_DEFAULT_EMAIL=[email protected]
PGADMIN_DEFAULT_PASSWORD=admin
PGADMIN_PORT=5050
5 changes: 0 additions & 5 deletions docker/dashboards/Dockerfile

This file was deleted.

3 changes: 0 additions & 3 deletions docker/dashboards/opensearch_dashboards.yml

This file was deleted.

Loading

0 comments on commit d7f282c

Please sign in to comment.