Skip to content

Commit

Permalink
Merge remote-tracking branch 'upstream/master'
Browse files Browse the repository at this point in the history
  • Loading branch information
liamwhite committed Jun 2, 2024
2 parents 8b869b5 + 194b268 commit b0fb7ce
Show file tree
Hide file tree
Showing 7 changed files with 42 additions and 20 deletions.
6 changes: 5 additions & 1 deletion config/runtime.exs
Original file line number Diff line number Diff line change
Expand Up @@ -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"),
Expand Down Expand Up @@ -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,
Expand Down
23 changes: 11 additions & 12 deletions docker-compose.yml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
version: '3'
volumes:
postgres_data: {}
elastic_data: {}
opensearch_data: {}
app_cargo_data: {}
app_build_data: {}
app_deps_data: {}
Expand Down Expand Up @@ -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
- [email protected]
Expand All @@ -54,8 +54,8 @@ services:
- app_native_data:/srv/philomena/priv/native
depends_on:
- postgres
- elasticsearch
- redis
- opensearch
- valkey
ports:
- '5173:5173'

Expand All @@ -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"

Expand Down
6 changes: 3 additions & 3 deletions docker/app/run-development
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down
2 changes: 1 addition & 1 deletion docker/app/run-test
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down
15 changes: 15 additions & 0 deletions docker/opensearch/opensearch.yml
Original file line number Diff line number Diff line change
@@ -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
2 changes: 1 addition & 1 deletion lib/philomena/elasticsearch.ex
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down
8 changes: 6 additions & 2 deletions lib/philomena/search/parser.ex
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,8 @@ defmodule Philomena.Search.Parser do
__data__: nil
]

@max_clause_count 512

def parser(options) do
parser = struct(Parser, options)

Expand Down Expand Up @@ -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),
Expand Down

0 comments on commit b0fb7ce

Please sign in to comment.