MarginaliaSearch/code/services-application/search-service
2025-01-10 15:52:02 +01:00
..
java/nu/marginalia/search Revert experimental changes 2025-01-10 15:52:02 +01:00
resources (search) Reduce the number of db queries a bit by caching data that doesn't change too often 2025-01-10 13:53:56 +01:00
tailwind (search) Add proper tailwind build and host fontawesome locally 2024-12-07 14:11:22 +01:00
test/nu/marginalia (search-service) Begin replacement of the crawl queue mechanism with node_affinity flagging 2025-01-08 13:25:56 +01:00
.gitignore (search) Add proper tailwind build and host fontawesome locally 2024-12-07 14:11:22 +01:00
build.gradle (search) Dark Mode 2024-12-13 21:47:07 +01:00
readme.md (search-service) Clean up readme 2025-01-08 13:04:39 +01:00

Search Service

This service handles search traffic and is the service you're most directly interacting with when visiting marginalia-search.com.

It interprets a "human" query and translates it into a request that gets passed into to the index service, which finds related documents, which this service then ranks and returns to the user.

The UI is built using JTE templates and the Jooby framework, primarily using its MVC facilities.

When developing, it's possible to set up a mock version of the UI by running the gradle command

$ ./gradlew paperDoll -i

The UI will be available at http://localhost:9999/, and has hot reloading of JTE classes and static resources.

image

Central classes

  • SearchService receives requests and delegates to the appropriate services.

  • CommandEvaluator interprets a user query and acts upon it, dealing with special operations like browse: or site:.

  • SearchQueryIndexService passes a parsed search query to the index service, and then decorates the search results so that they can be rendered.

See Also