diff --git a/config/runtime.exs b/config/runtime.exs index 9cd91ed5b..4257ed9e8 100644 --- a/config/runtime.exs +++ b/config/runtime.exs @@ -15,7 +15,7 @@ config :philomena, anonymous_name_salt: System.fetch_env!("ANONYMOUS_NAME_SALT"), hcaptcha_secret_key: System.fetch_env!("HCAPTCHA_SECRET_KEY"), hcaptcha_site_key: System.fetch_env!("HCAPTCHA_SITE_KEY"), - elasticsearch_url: System.get_env("ELASTICSEARCH_URL", "http://localhost:9200"), + opensearch_url: System.get_env("OPENSEARCH_URL", "https://admin:admin@localhost:9200"), advert_file_root: System.fetch_env!("ADVERT_FILE_ROOT"), avatar_file_root: System.fetch_env!("AVATAR_FILE_ROOT"), badge_file_root: System.fetch_env!("BADGE_FILE_ROOT"), @@ -91,6 +91,10 @@ config :philomena, :s3_secondary_options, config :philomena, :s3_secondary_bucket, System.get_env("ALT_S3_BUCKET") +# Don't bail on OpenSearch's self-signed certificate +config :elastix, + httpoison_options: [ssl: [verify: :verify_none]] + config :ex_aws, :hackney_opts, timeout: 180_000, recv_timeout: 180_000, diff --git a/docker-compose.yml b/docker-compose.yml index a5034ca06..b4d57ea21 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -1,7 +1,7 @@ version: '3' volumes: postgres_data: {} - elastic_data: {} + opensearch_data: {} app_cargo_data: {} app_build_data: {} app_deps_data: {} @@ -31,8 +31,8 @@ services: - IMAGE_URL_ROOT=/img - BADGE_URL_ROOT=/badge-img - TAG_URL_ROOT=/tag-img - - ELASTICSEARCH_URL=http://elasticsearch:9200 - - REDIS_HOST=redis + - OPENSEARCH_URL=http://opensearch:9200 + - REDIS_HOST=valkey - DATABASE_URL=ecto://postgres:postgres@postgres/philomena_dev - CDN_HOST=localhost - MAILER_ADDRESS=noreply@philomena.local @@ -54,8 +54,8 @@ services: - app_native_data:/srv/philomena/priv/native depends_on: - postgres - - elasticsearch - - redis + - opensearch + - valkey ports: - '5173:5173' @@ -68,21 +68,20 @@ services: logging: driver: "none" - elasticsearch: - image: elasticsearch:7.9.3 + opensearch: + image: opensearchproject/opensearch:2.14.0 volumes: - - elastic_data:/usr/share/elasticsearch/data + - opensearch_data:/usr/share/opensearch/data + - ./docker/opensearch/opensearch.yml:/usr/share/opensearch/config/opensearch.yml logging: driver: "none" - environment: - - discovery.type=single-node ulimits: nofile: soft: 65536 hard: 65536 - redis: - image: redis:7.2.4-alpine + valkey: + image: valkey/valkey:7.2.5-alpine logging: driver: "none" diff --git a/docker/app/run-development b/docker/app/run-development index 4e03fab90..39900c76c 100755 --- a/docker/app/run-development +++ b/docker/app/run-development @@ -34,11 +34,11 @@ npm install # Always install mix dependencies (cd /srv/philomena && mix deps.get) -# Sleep to allow Elasticsearch to finish initializing +# Sleep to allow OpenSearch to finish initializing # if it's not done doing whatever it does yet -echo -n "Waiting for Elasticsearch" +echo -n "Waiting for OpenSearch" -until wget -qO - elasticsearch:9200; do +until wget --no-check-certificate -qO - http://opensearch:9200; do echo -n "." sleep 2 done diff --git a/docker/app/run-test b/docker/app/run-test index 4c120740a..679a438c0 100755 --- a/docker/app/run-test +++ b/docker/app/run-test @@ -9,7 +9,7 @@ export MIX_ENV=test # if it's not done doing whatever it does yet echo -n "Waiting for Elasticsearch" -until wget -qO - elasticsearch:9200; do +until wget -qO - opensearch:9200; do echo -n "." sleep 2 done diff --git a/docker/opensearch/opensearch.yml b/docker/opensearch/opensearch.yml new file mode 100644 index 000000000..afb4d34ce --- /dev/null +++ b/docker/opensearch/opensearch.yml @@ -0,0 +1,15 @@ +--- +cluster.name: docker-cluster + +# Bind to all interfaces because we don't know what IP address Docker will assign to us. +network.host: 0.0.0.0 + +# Setting network.host to a non-loopback address enables the annoying bootstrap checks. "Single-node" mode disables them again. +discovery.type: single-node + +# Disable security. We don't need it for dev environment. +# Also, whoever thought it's a GREAT IDEA TO ENFORCE SECURITY FEATURES +# BY DEFAULT IN A FREAKING DOCKER CONTAINER should be forced to play +# the password game every time they would like to create a new account +# anywhere whatsoever. +plugins.security.disabled: true diff --git a/lib/philomena/elasticsearch.ex b/lib/philomena/elasticsearch.ex index 68bf92e53..a85bfc506 100644 --- a/lib/philomena/elasticsearch.ex +++ b/lib/philomena/elasticsearch.ex @@ -30,7 +30,7 @@ defmodule Philomena.Elasticsearch do defp index_for(Filter), do: FilterIndex defp elastic_url do - Application.get_env(:philomena, :elasticsearch_url) + Application.get_env(:philomena, :opensearch_url) end def create_index!(module) do diff --git a/lib/philomena/search/parser.ex b/lib/philomena/search/parser.ex index aaba8df7f..b2f5e47ec 100644 --- a/lib/philomena/search/parser.ex +++ b/lib/philomena/search/parser.ex @@ -29,6 +29,8 @@ defmodule Philomena.Search.Parser do __data__: nil ] + @max_clause_count 512 + def parser(options) do parser = struct(Parser, options) @@ -305,14 +307,16 @@ defmodule Philomena.Search.Parser do # Flattens the child of a disjunction or conjunction to improve performance. defp flatten_disjunction_child(this_child, %{bool: %{should: next_child}} = child) - when child == %{bool: %{should: next_child}} and is_list(next_child), + when child == %{bool: %{should: next_child}} and is_list(next_child) and + length(next_child) <= @max_clause_count, do: %{bool: %{should: [this_child | next_child]}} defp flatten_disjunction_child(this_child, next_child), do: %{bool: %{should: [this_child, next_child]}} defp flatten_conjunction_child(this_child, %{bool: %{must: next_child}} = child) - when child == %{bool: %{must: next_child}} and is_list(next_child), + when child == %{bool: %{must: next_child}} and is_list(next_child) and + length(next_child) <= @max_clause_count, do: %{bool: %{must: [this_child | next_child]}} defp flatten_conjunction_child(this_child, next_child),