- 
    Type:Task 
- 
    Resolution: Fixed
- 
    Priority:Major - P3 
- 
    Affects Version/s: None
- 
    Component/s: None
- 
    None
- 
        Fully Compatible
- 
        Service Arch 2024-01-08, Service Arch 2024-01-22
- 
        None
- 
        None
- 
        None
- 
        None
- 
        None
- 
        None
- 
        None
In order to replace the use of a SerializationContext we have taken actions into using a ValidatedTenancyScope as our single source of truth in order to serialize / deserialize namespacestring and databasename objects.
As part of the process we are now replacing the use of a SerializationContext when serializing / deserializing a DatabaseName.
In order to achieve that we have to include and link a ValidatedTenancyScope as part of the namespace_string_database_name_util library.
One solution is to cleanup the library dependencies to no longer depend on the namespace_string_database_name_util library and to be able to include the 'security_token' library as part of the utility library.
The other solution is to create an intermediate data structure (such as ValidatedTenancydata) that will only contain a flag related to the Tenant Protocol (if the operation comes from Atlas proxy or not) and the tenantId associated to it. This information is already on the ValidatedTenancyScope. This would avoid any work to try to refactor all the auth libraries.
See comments for extra details.
- is depended on by
- 
                    SERVER-83797 Introduce DatabaseNameUtil (de)serialize functions without SerializationContext for non idl generated command code -         
- Closed
 
-         
- 
                    SERVER-83798 Introduce NamespaceStringUtil (de)serialize functions without SerializationContext for non idl generated command code -         
- Closed
 
-         
- 
                    SERVER-84742 Refactor the ValidatedTenancyScope class to become a POD class -         
- Closed
 
-