Unable to complete code signing process due to 'tenant' account error?

SForSW 20 Reputation points
2024-08-25T23:40:27.4933333+00:00

Hello,

I've completed the steps necessary to create the profiles (including certificate) and identity validation necessary to utilize the 'trusted' code signing process (with the 'signtool.exe' option). I've configured the json file as instructed and everything seems to be working right up until 'Submitting digest for signing' step as reported by signtool.

At that point, my web browser (Edge) opens and I am prompted to log in with my username and password. I had set up my account with the various parameters specified in the help documentation, so I enter in the same values I have used for the Azure/Entra systems and the standard Microsoft account log in. I am then presented with this error message:

"Selected user account does not exist in tenant 'Microsoft Services' and cannot access the application '[number omitted]' in that tenant. The account needs to be added as an external user in the tenant first. Please use a different account."

I have searched extensively and could find no steps or instructions in any Microsoft help documentation, StackOverflow, or other discussion forums that solved this problem. I appear to have every permission applied, account linked, and 'tenant' condition available to me. So I'd simply like to know what I need to do in order to make my account an 'external user' in the tenant 'Microsoft Services' so I can code sign using SignTool. Thank you for any assistance you can offer.

Azure Trusted Signing
Azure Trusted Signing
Trusted Signing is a Microsoft fully managed, end-to-end signing solution that simplifies the certificate signing process and helps partner developers more easily build and distribute applications.
75 questions
{count} votes

Accepted answer
  1. Sandeep G-MSFT 18,766 Reputation points Microsoft Employee
    2024-08-27T04:09:24.9033333+00:00

    @SForSW

    I'm glad that you were able to resolve your issue and thank you for posting your solution so that others experiencing the same thing can easily reference this! Since the Microsoft Q&A community has a policy that "[The question author cannot accept their own answer. They can only accept answers by others] (https://docs.microsoft.com/en-us/answers/support/accepted-answers#why-only-one-accepted-answer)**)", I'll repost your solution in case you'd like to "[Accept] (https://docs.microsoft.com/en-us/answers/support/accepted-answers#accepted-answer-in-a-question-thread)**)" the answer.

     

    Issue:

    Unable to complete code signing process due to 'tenant' account error

    Solution:

    • Issue was resolved by creating an additional tenant account through Entra Admin Center > Users > New User as a 'Member' with its own e-mail address as the 'Identity', then also create an app in Azure > Search > 'app registrations' > New Registration.
    • The latter provided a client ID, tenant ID, and 'secret' value necessary to complete the steps for authorization that Sign Tool would accept.
    • From there, three environment variables needed to be created within Windows (search > advanced system settings > Environment Variables).
    • The three value names are AZURE_CLIENT_ID, AZURE_TENANT_ID, and AZURE_CLIENT_SECRET and then each respective value needs to be assigned under each name.
    • a reboot is required to apply the new environment variables and with all of the other pieces in place as needed (certificate, signing profile, prerequisites, dlib, etc, etc, etc), SignTool could then code sign.

    Please "Accept the answer" if the information helped you. This will help us and others in the community as well.

    1 person found this answer helpful.
    0 comments No comments

1 additional answer

Sort by: Most helpful
  1. SForSW 20 Reputation points
    2024-08-26T21:28:40.0733333+00:00

    I was finally able to sort it out and successfully code sign. It apparently related to needing a different authorization approach than what was described (ie mostly omitted) in the Microsoft help documentation. Turned out the best route was to create an additional tenant account through Entra Admin Center > Users > New User as a 'Member' with its own e-mail address as the 'Identity', then also create an app in Azure > Search > 'app registrations' > New Registration. The latter provided a client ID, tenant ID, and 'secret' value necessary to complete the steps for authorization that SignTool would accept. From there, three environment variables needed to be created within Windows (search > advanced system settings > Environment Variables). The three value names are AZURE_CLIENT_ID, AZURE_TENANT_ID, and AZURE_CLIENT_SECRET and then each respective value needs to be assigned under each name. From there, a reboot is required to apply the new environment variables and with all of the other pieces in place as needed (certificate, signing profile, prerequisites, dlib, etc, etc, etc), SignTool could then code sign.

    0 comments No comments

Your answer

Answers can be marked as Accepted Answers by the question author, which helps users to know the answer solved the author's problem.