Comments (8)
Glad to hear it's now fixed. I will close this issue now. I have made a few changes to the UPGRADE guide to make things a little clearer.
from phauxth.
Version 2.1 of Phauxth is now using version 5 of Comeonin, and the main change, as far as Phauxth is concerned, is that Comeonin is now not called directly.
The changes you will need to make are:
- change
Comeonin.Argon2
in the config file toArgon2
- change
Comeonin.Argon2.add_hash
toArgon2.add_hash
I added a note about this to the Gitter channel and updated the UPGRADE_v2 guide, but it's not always easy to let everyone know when there is a change.
from phauxth.
Thanks David, I missed that. Probably because I was already on 2.0.0 so, must have totally missed it.
Ok, I fixed as you have mentioned and now I'm being hit with this:
Request: POST /api/core
** (exit) an exception was raised:
** (FunctionClauseError) no function clause matching in MyAppWeb.Auth.Login.report/2
(myapp) lib/myapp_web/auth/login.ex:7: MyAppWeb.Auth.Login.report(:ok, [])
Inside my auth/login.ex
:
defmodule MyAppWeb.Auth.Login do
@moduledoc """
Custom login module that checks if the user is confirmed before
allowing the user to log in.
"""
use Phauxth.Login.Base
alias Comeonin.Argon2
alias MyApp.IAM
@impl true
def authenticate(%{"password" => password} = params, _, opts) do
case IAM.get_by(params) do
nil -> {:error, "no user found"}
%{confirmed_at: nil} -> {:error, "account unconfirmed"}
user -> Argon2.check_pass(user, password, opts)
end
end
end
Seems like a struct mismatch within the report
function. I can probably override it, but not sure it is a bug..
from phauxth.
Ok, I found out the issue. In this callback:
@impl true
def authenticate(%{"password" => password} = params, _, opts) do
case IAM.get_by(params) do
nil -> {:error, "no user found"}
%{confirmed_at: nil} -> {:error, "account unconfirmed"}
user -> Argon2.check_pass(user, password, opts)
end
end
The success case returns just :ok
, instead of the tuple {:ok, user}
that the report function is expecting.
@impl true
def authenticate(%{"password" => password} = params, _, opts) do
case IAM.get_by(params) do
nil -> {:error, "no user found"}
%{confirmed_at: nil} -> {:error, "account unconfirmed"}
user -> {Argon2.check_pass(user, password, opts), user} # <--- Changing it to this solved it
end
end
Since it's a callback implementation, I don't think it's a bug per se, but then again, I'm upgrading from Phauxth 2.0.0 to 2.1.0, so my implementation hasn't changed, but seems like, as you have mentioned, the Argon function has changed.
from phauxth.
You need to remove the alias Comeonin.Argon2
line
from phauxth.
This commit shows the changes that I made to the example app to upgrade it to 2.1
from phauxth.
You need to remove the
alias Comeonin.Argon2
line
That was it! I can confirm this was the issue. Thanks David. Should I close this issue now?
from phauxth.
Thank you David!
from phauxth.
Related Issues (20)
- Error with absinthe (Phoenix 1.4 and Phaux 2.0) HOT 1
- [FEATURE] Customizable max_age in tokens used by Remember HOT 5
- [BUG] Token generated later to same user can't work properly HOT 5
- Thanks for your hard work for 2.0 HOT 4
- [FEATURE] Add refresh token support HOT 2
- seeds.exs from wiki HOT 3
- [FEATURE] phauxth for umbrella apps HOT 6
- [BUG] Sessions are never validated by default HOT 6
- [FEATURE] Allow specifying domain for remember cookie HOT 4
- [BUG] Remember cookie doesn't last full time HOT 6
- Confusion over Phauxth.Remember :max_age HOT 1
- authenticate callback arity for token cookie module is incorrect HOT 2
- Working on Phoenix Liveview HOT 4
- [FEATURE] Create 'Phauxth.Remember.Base' module HOT 2
- [FEATURE] Too Many Login Attempts HOT 1
- [BUG] Can't download archive install HOT 4
- Wiki documentation update proposition HOT 1
- Generate both API and HTML
- change http://localhost:4000/sessions/new from text_input to password_input HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from phauxth.