I'd like to update the user data object in the UI. I know I can do it via the API: https://fusionauth.io/docs/v1/tech/apis/users
dan
@dan
Principal Product Engineer at FusionAuth.
Enjoys ruby, java, php. Finds golang challenging.
Likes the authorization code grant, automation, stories and clear documentation.
Hiker, camper, gardener. Used to have chickens, now just tomatos.
Best posts made by dan
-
Is there a way to update user data in the UI?posted in Q&A
-
Can I configure the inactivity timeout of the FusionAuth Session cookie?posted in Q&A
I have a quick question about FusionAuth and configuring the inactivity timeout of the session cookie it creates. Specifically... Is it possible?
-
Terraform provider for FusionAuth releasedposted in Release
There's now an open source terraform provider available: https://github.com/gpsinsight/terraform-provider-fusionauth
It's also on the registry: https://registry.terraform.io/providers/gpsinsight/fusionauth/latest
-
RE: Block authentication until user is verified?posted in Q&A
Is modifying the JWT via a lambda equivalent to accessing the verified property of the user profile?
Within a lambda, you have access to the user and registration properties. So you'd pull the
verifiedproperty from wherever you wanted and put it into the JWT as a custom claim. Here's a blog post about how that might work.So yes, it is the same data. It's the tradeoff between a bigger JWT and having to make the additional call from your API.
Don't forget that the JWT will live for a while, so if this sequence happens and you use the JWT, you might have a user with a verified email prevented from using the API.
- user registers
- JWT issued, with
verifiedset tofalsebecause the user isn't verified. - User verifies their email
- User visits API, but is denied because the JWT has stale data.
I don't know timelines and how long your JWTs live for, but this is something to consider. Does that answer your question?
-
RE: My JWKS are always emptyposted in Q&A
Symmetric keys are not returned on the JWKS endpoint, as they don't have a public key. Per the docs this api:
returns public keys generated by FusionAuth, used to cryptographically verify JWTs using the JSON Web Key format
If you create an RSA or EC key which is an asymmetric key pair - the public key will be returned on the JWKS endpoint. If you don’t have any key pairs configured , it will be empty. Out of the box, you’ll only have one HMAC key which we don’t publish in JWKS.
-
RE: Implementing a Role-Based Access System for Authorizationposted in Q&A
Ah, I just tested this out and if you don't need it in the JWT, you should be able to see it in the registrations object returned after login.
Here's a response I get after logging in:
{ "token": "ey...", "user": { "active": true, "connectorId": "e3306678-a53a-4964-9040-1c96f36dda72", "email": "email@example.com", "id": "2df13f18-01cc-48a4-b97a-2ab04f98d006", "insertInstant": 1592857899119, "lastLoginInstant": 1596819645662, "lastUpdateInstant": 0, "passwordChangeRequired": false, "passwordLastUpdateInstant": 1592857899145, "registrations": [ { "applicationId": "78bd26e9-51de-4af8-baf4-914ea5825355", "id": "73d2317b-d196-4315-aba2-3c205ed3ccae", "insertInstant": 1592857899151, "lastLoginInstant": 1592857899153, "lastUpdateInstant": 1596813810104, "roles": [ "Role1" ], "usernameStatus": "ACTIVE", "verified": true } ], "tenantId": "1de156c2-2daa-a285-0c59-b52f9106d4e4", "twoFactorDelivery": "None", "twoFactorEnabled": false, "usernameStatus": "ACTIVE", "verified": true } }So
user.applicationId.rolesis what you want. Note that roles are applied on an application by application basis. If a user is in a group which has a role 'roleA' which is created in 'applicationA', but is not registered for 'applicationA', they won't receive that role. More on that here: https://fusionauth.io/docs/v1/tech/core-concepts/groups -
RE: Trouble getting the user object post loginposted in Q&A
OK, we just released 1.18.8 and that is the version you want to use:
In
requirements.txt:fusionauth-client==1.18.8And then this is the call you want to make (with
client_idbeforeredirect_uri) :resp = client.exchange_o_auth_code_for_access_token(request.args.get("code"), client_id, "http://localhost:5000/oauth-callback", client_secret) -
RE: Specifying password during user registration.posted in Q&A
Hiya,
First off, we'd recommend having all the flow you outline be over TLS. That's good enough for most major ecommerce systems and so shouldn't be insecure. If you aren't serving your application over TLS, then I'd advise doing so. And note that the flow is actually:
My Frontend-->My Backend-->FusionAuth APIThere's no password returned from the registration API call.
If you are concerned about a new user's password being insecurely transmitted through your application, you could use the FusionAuth hosted login pages and theme them to be like your application. (More docs.)
The other option, which takes encrypted passwords, is the Import Users API, but that's probably not a fit for one off registrations. There are no plans to accept encrypted passwords for one off user registrations. Here's a related issue you can weigh in on/vote up if you'd like. Or feel free to open a new issue if that one doesn't capture the essence of your idea.
Are there specific security concerns you have around your front end/back end systems that I might be missing?
Latest posts made by dan
-
RE: Send custom query param to identity provider (screen_hint)posted in Q&A
@elliotdickison I'd probably try with two Identity Providers configurations in FusionAuth both pointing to the same remote IDP.
One can have
screen_hint=abcon the authorization URL and the other can havescreen_hint=def, but both will have all the other parameters the same.Then you can use an
idp_hinton your create or login buttons.I think that will work, but please let us know.
-
RE: Feedback: Tailwindposted in Comments & Feedback
@elliotdickison Thanks for the feedback.
I'd love to chat a bit more to understand the problem.
Will send you an email.
-
RE: Getting changes from theme updatesposted in Q&A
Because advanced themes are so customizable, they can be hard to upgrade. Here's some ways to make it easier.
- When you create a new theme, start from the default version. Commit it to git before you change anything.
- Use the FusionAuth CLI to download/upload your theme during development and CI/CD.
- When a new theme comes out, clone or pull the latest from the theme history repo.
- Run this command to see what has changed:
git format-patch 1.61.0..1.64.1 --stdout > update-themes.patch(this shows the changes between 1.61.0 and 1.64.1; adjust as needed for your installed version and the target version). - Go to your theme git repo and apply the changes:
git am --3way update-themes.patchwhich will attempt to automatically merge the changes. If there are conflicts, you can resolve them manually and then rungit am --continue.
You can also use a 3 way diffing tool like diff3 or kdiff3 to visualize the changes.
These upgrade notes also provide detailed human friendly instructions on the changes.
-
Getting changes from theme updatesposted in Q&A
I am using advanced themes and wanted to know how to find out what had changed in the themed pages when a new release happens.
-
RE: Application is blank on the login recordsposted in Q&A
There are a couple different scenarios where a login record could have a blank application Id. Usually it is #1 or #2. It occurs in scenarios where the user can have a JWT/access token that does not have the application Id in it.
- If a user is not registered for the Application they are logging into
- FusionAuth makes a login record when a user is created since FA makes a JWT upon user creation
- If you use the Login API, you can log in without an App ID because you don't have to provide an application on the API call.
-
Application is blank on the login recordsposted in Q&A
We have a user who has logged in repeatedly, but the application is blank.
https://fusionauth.io/docs/apis/login#search-login-records doesn't mention anything about this.
What gives?
-
RE: Importing users over timeposted in Q&A
I think the way I'd approach this is:
- import all users into FusionAuth
At cutover time:
- look at local database to see which password hashes had changed
- pull the user data from FusionAuth for each of these users
- delete the user
- re-import the user with the new password hash and the FusionAuth data, maintaining the same userId (if you provide the UUID, we'll use that)
I get that is an additional complexity, but hopefully that helps.
-
Importing users over timeposted in Q&A
I have a large number of users. I want to import them into FusionAuth with their password hashes and the accompanying data like the factor.
But my cutover is going to be slow, so I expect some percentage of people to change their password hashes after the import.
So I'd like synchronize any password hashes that changed in the meantime, and then roll out FusionAuth.
I can't re-import password hashes for an existing user, and the User API doesn't let me update passwords hashes, per this closed issue: https://github.com/FusionAuth/fusionauth-issues/issues/348
What would you recommend?
-
RE: Wanted to add a passkey prompt in my applicationposted in Q&A
This is totally possible.
You want to start by understanding FusionAuth passkey setup and the normal flow.
Then, in your application, probably using one of the client libraries, you want to do the following for a user:
- see if a user has a passkey set up, using the "retrieve a passkey" API. If this returns 0 passkeys, show the prompt.
- for the prompt, you have two options:
- use the API/client library to start the passkey registration process from within your application directly
- send them to the user management page to add a passkey (requires a paid license)
The right way to do the latter depends on your application needs (are you okay with a redirect) and whether or not you have at least a starter license.
For reporting on the number of users that have set up passkeys, unfortunately you have to query all your users and then pull the passkey data individually. There's no way to use the elasticsearch syntax to do the query as of yet. There's an open github issue to add that functionality.
-
Wanted to add a passkey prompt in my applicationposted in Q&A
I have an application using FusionAuth, and I want to prompt my end users to set up passkeys. Having this authentication method will improve their security and ease their future logins.
I know I can enable passkeys for FusionAuth using the community edition license, but how can I add a prompt in my application code/UI to have them set it up?