Working with a client in our Multi-tenant CRM environment who was doing a database
migration into CRM and as part of the process, a backup of their Organization_MSCRM database was taken just prior
to starting the
migration in case it needed
to be restored and run a second time.
In this case it did, so I restored the database and let the client know he should be good
to go. A few hours later I received a call that they were unable
to add some new users, they would appear as available when using the add multiple user wizard, but anyone added would not be added
to CRM. It was also disucussed that these users had been added
to CRM initally AFTER the database backup had been taken.
I turned on tracing and tried
to add the users through both the single user form and multiple user interface and was unable
to do so. The error message in the logs wasn't much help:
Unexpected error adding user
[email protected]: Microsoft.Crm.CrmException: INVALID_WRPC_TOKEN: Validate WRPC Token: WRPCTokenState=Invalid, TOKEN_EXPIRY=4320, IGNORE_TOKEN=False
Searching on Google or bing didn't offer any assitance. Apparently not a very common problem, or no one has been able
to resolve.
I did some searching in the MSCRM_CONFIG database and found that their are several user tables there and after getting my head around the structure found that there were enties here for users that were not part of the restored DB. It seems that new users are added
to both the Orgnaization_MSCRM and MSCRM_CONFIG and after the restore these were out of sync.
I needed
to remove the extra entries in order
to address. Restoring the MSCRM_CONFIG database was not an option as other clients could have been adding users at this point and
to restore would risk breaking their instances of CRM.
Long story short, I was finally able
to generate a script
to remove the bad entries and when I tried
to add users again, I was succesful. In case someone else out there finds themselves in a similar situation, here is the script I used
to delete the bad entries.
DECLARE @UsersToDelete TABLE
(
UserId uniqueidentifier
)
Insert Into @UsersToDelete(UserId)
Select UserId from [MSCRM_CONFIG].[dbo].[SystemUserOrganizations]
Where CrmuserId Not in (select systemuserid from Organization_MSCRM.dbo.SystemUserBase)
And OrganizationId = '00000000-643F-E011-0000-0050568572A1' --Id From the Organization table for this instance
Delete From [MSCRM_CONFIG].[dbo].[SystemUserAuthentication]
Where UserId in (Select UserId From @UsersToDelete)
Delete From [MSCRM_CONFIG].[dbo].[SystemUserOrganizations]
Where UserId in (Select UserId From @UsersToDelete)
Delete From [MSCRM_CONFIG].[dbo].[SystemUser]
Where Id in (Select UserId From @UsersToDelete)