-
Notifications
You must be signed in to change notification settings - Fork 1
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: update photo's caption #24
Changes from 9 commits
9627c72
5d0a1fc
8f589d3
7bc2693
6a97220
d268df3
ac0f402
0545ed5
c35c174
bd0b637
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
# 2024-10-25 | ||
|
||
## Req call typesense API alway :timeout, but typesense was updated. | ||
|
||
```elixir | ||
** (MatchError) no match of right hand side value: {:error, %Req.TransportError{reason: :timeout}} | ||
``` |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
# Typesense | ||
|
||
## Typesense API Errors | ||
|
||
``` | ||
# 400 Bad Request - The request could not be understood due to malformed syntax. | ||
# 401 Unauthorized - Your API key is wrong. | ||
# 404 Not Found - The requested resource is not found. | ||
# 409 Conflict - When a resource already exists. | ||
# 422 Unprocessable Entity - Request is well-formed, but cannot be processed. | ||
# 503 Service Unavailable - We’re temporarily offline. Please try again later. | ||
``` | ||
|
||
docs: https://typesense.org/docs/27.1/api/api-errors.html#api-errors |
Original file line number | Diff line number | Diff line change | ||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
@@ -0,0 +1,47 @@ | ||||||||||||||||||||||||||||
defmodule SaveIt.Migration.Typesense do | ||||||||||||||||||||||||||||
alias SmallSdk.Typesense | ||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||
import Tj.UrlHelper, only: [validate_url!: 1] | ||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||
def create_collection!(schema) do | ||||||||||||||||||||||||||||
req = build_request("/collections") | ||||||||||||||||||||||||||||
res = Req.post!(req, json: schema) | ||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||
Typesense.handle_response!(res) | ||||||||||||||||||||||||||||
end | ||||||||||||||||||||||||||||
Comment on lines
+6
to
+11
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Add error handling for HTTP request. The def create_collection!(schema) do
req = build_request("/collections")
- res = Req.post!(req, json: schema)
-
- Typesense.handle_response!(res)
+ case Req.post(req, json: schema) do
+ {:ok, res} -> Typesense.handle_response!(res)
+ {:error, error} -> raise "Failed to create collection: #{inspect(error)}"
+ end
end 📝 Committable suggestion
Suggested change
|
||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||
def update_collection!(collection_name, schema) do | ||||||||||||||||||||||||||||
req = build_request("/collections/#{collection_name}") | ||||||||||||||||||||||||||||
res = Req.patch!(req, json: schema) | ||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||
Typesense.handle_response!(res) | ||||||||||||||||||||||||||||
end | ||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||
def delete_collection!(collection_name) do | ||||||||||||||||||||||||||||
req = build_request("/collections/#{collection_name}") | ||||||||||||||||||||||||||||
res = Req.delete!(req) | ||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||
Typesense.handle_response!(res) | ||||||||||||||||||||||||||||
end | ||||||||||||||||||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Add documentation and typespecs for public functions. Each public function should have + @doc """
+ Creates a new Typesense collection with the given schema.
+
+ ## Parameters
+ * schema - Map containing the collection configuration
+
+ ## Returns
+ * Map with collection details on success
+ * Raises an error if the operation fails
+ """
+ @spec create_collection!(map()) :: map()
def create_collection!(schema) do URI encode collection names in URLs. The collection name should be URI encoded to prevent potential injection attacks and handle special characters correctly. def update_collection!(collection_name, schema) do
- req = build_request("/collections/#{collection_name}")
+ req = build_request("/collections/#{URI.encode(collection_name)}")
|
||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||
defp get_env() do | ||||||||||||||||||||||||||||
url = Application.fetch_env!(:save_it, :typesense_url) |> validate_url!() | ||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||
api_key = Application.fetch_env!(:save_it, :typesense_api_key) | ||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||
{url, api_key} | ||||||||||||||||||||||||||||
end | ||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||
defp build_request(path) do | ||||||||||||||||||||||||||||
{url, api_key} = get_env() | ||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||
Req.new( | ||||||||||||||||||||||||||||
base_url: url, | ||||||||||||||||||||||||||||
url: path, | ||||||||||||||||||||||||||||
headers: [ | ||||||||||||||||||||||||||||
{"Content-Type", "application/json"}, | ||||||||||||||||||||||||||||
{"X-TYPESENSE-API-KEY", api_key} | ||||||||||||||||||||||||||||
] | ||||||||||||||||||||||||||||
) | ||||||||||||||||||||||||||||
end | ||||||||||||||||||||||||||||
end |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🛠️ Refactor suggestion
Consider extracting duplicate photo creation logic.
The photo creation logic is duplicated in two handlers. Consider extracting it into a private function:
Then use it in both handlers:
Also applies to: 188-192