Skip to content

Commit

Permalink
Merge pull request #225 from turnhub/bugfix/has-phonenumber
Browse files Browse the repository at this point in the history
fix has_phonenumber digit checking
  • Loading branch information
smn authored Sep 26, 2024
2 parents b8bc6a3 + f3240e1 commit d8f8ddf
Showing 1 changed file with 9 additions and 2 deletions.
11 changes: 9 additions & 2 deletions lib/expression/callbacks/standard.ex
Original file line number Diff line number Diff line change
Expand Up @@ -1721,6 +1721,10 @@ defmodule Expression.Callbacks.Standard do
result: %{"__value__" => false, "phonenumber" => nil}
@expression_doc expression: "has_phone(nil, \"US\")",
result: %{"__value__" => false, "phonenumber" => nil}
@expression_doc expression: "has_phone(\"+27\")",
result: %{"__value__" => false, "phonenumber" => nil}
@expression_doc expression: "has_phone(\"+27\", \"ZA\")",
result: %{"__value__" => false, "phonenumber" => nil}
def has_phone(ctx, expression) do
[expression] = eval_args!([expression], ctx)
letters_removed = Regex.replace(~r/[a-z]/i, to_string(expression), "")
Expand All @@ -1737,8 +1741,11 @@ defmodule Expression.Callbacks.Standard do

defp parse_phone_number(string, country_code) do
pn =
case ExPhoneNumber.parse(string, country_code) do
{:ok, pn} -> ExPhoneNumber.format(pn, :e164)
with {:ok, pn} <- ExPhoneNumber.parse(string, country_code),
true <- ExPhoneNumber.is_possible_number?(string, country_code),
true <- ExPhoneNumber.is_valid_number?(pn) do
ExPhoneNumber.format(pn, :e164)
else
_ -> nil
end

Expand Down

0 comments on commit d8f8ddf

Please sign in to comment.