Skip to content
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

_pszQualifiedUserName is giving null for cached users. #5

Open
Mohitkiran opened this issue Oct 9, 2019 · 9 comments
Open

_pszQualifiedUserName is giving null for cached users. #5

Mohitkiran opened this issue Oct 9, 2019 · 9 comments

Comments

@Mohitkiran
Copy link

Mohitkiran commented Oct 9, 2019

Hi, this project regarding credential provider is really great I have took this project as reference and I have been developing a new credential provider so my problem is some times
_pszQualifiedUserName is being returning null in getSerialization method for cached user tiles(user tiles that are displayed on left bottom corner of login UI) when trying to login, how ever if I am trying to login from other user tile every thing is working fine. I am really stuck at this point can you please help me out and point me in the right direction, please let me know if you need to see the code snippet of getSerialization method. Thank you!

@arcadejust
Copy link
Owner

Set
#define DEVELOPING TRUE
and check the log file - look for "no pcpUser!!!" or "_pszQualifiedUserName: "
or uncomment
//if (DEVELOPING) PrintLn(L"Field altered, fieldID: %d", dwFieldID);

@Mohitkiran
Copy link
Author

Mohitkiran commented Oct 11, 2019

Yeah I checked the log and _pszQualifiedUserName is null in log and this null is not coming always but very randomly (Only for cached user tiles it is happening and not when logged from other user). I am new to this windows area and if you think you need to see the code I can attach the file.

@arcadejust
Copy link
Owner

Can you make a new commit in your branch and I will check it. You can make this branch private if you don't want others to see it.

@Mohitkiran
Copy link
Author

Mohitkiran commented Oct 16, 2019

I got where I was doing wrong I didn't specify _fUserNameVisible(false) in userCrendential.cpp constructor so the thread is entering into if(_fUserNameVisible) and then _pszQualifiedUserName memory is getting cleared in that if and later it is returning null. Thanks for taking time to reply @arcadejust .

@Mohitkiran
Copy link
Author

Mohitkiran commented Oct 16, 2019

Can you tell me when does the control enter if(_fLocalUser) and when does it enter into else? My observation is that only for microsoft account login it is going into else block of if(_fLocalUser) and for every other (Local and Domain) accounts the control is going into if(_fLocalUser) Is my observation right?

@arcadejust
Copy link
Owner

Only domain user that has locally stored account after previous logon. Not for domain user that never logged on this PC. It was important for me to detect login from full name because they are stored in the same field (that's how I remember this - you have to double check on this info). Also there were backward compatibility issues for credential provider V1 - so without installing all the virtual machines and debugging I cannot tell for sure why it was needed. I remember there were different scenarios between win 8.0 and win 8.1 and win 10.

@Mohitkiran
Copy link
Author

Mohitkiran commented Oct 21, 2019

Okay thanks and one more thing is I tried adding the machine to azure ad and installed the credential provider and what happens is it is not displaying the credential provider in sign in options for other user tile and displays for all cached user tiles sign in options where as it is showing on other user tile sign in options and for cached user tiles sign in options as well, when joined to local domain. Any thoughts?

@arcadejust
Copy link
Owner

I never tested azure domain, sorry:/

@Mohitkiran
Copy link
Author

No problem, Thank you for sparing time to reply me!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants