1
0
mirror of https://github.com/dkmstr/openuds.git synced 2025-01-08 21:18:00 +03:00

Fixed managed and unmanaged actor_v3

This commit is contained in:
Adolfo Gómez García 2024-01-01 05:16:33 +01:00
parent 974f652df0
commit dc5cc99afd
No known key found for this signature in database
GPG Key ID: DD1ABF20724CDA23
4 changed files with 26 additions and 19 deletions

2
client

@ -1 +1 @@
Subproject commit d340a8075e7692354a1b486fde98d78ba165890b
Subproject commit c699725350b09f1f9f3440708b3ed7659e0daa3e

View File

@ -389,8 +389,8 @@ class Initialize(ActorV3Action):
) -> dict[str, typing.Any]:
return ActorV3Action.actorResult(
{
'own_token': alias_token or own_token, # Compat with old actor versions, TBR on 5.0
'token': alias_token or own_token, # New token, will be used from now onwards
'own_token': own_token or alias_token, # Compat with old actor versions, TBR on 5.0
'token': own_token or alias_token, # New token, will be used from now onwards
'unique_id': unique_id,
'os': os,
}
@ -410,6 +410,9 @@ class Initialize(ActorV3Action):
# Not on alias token, try to locate on Service table
if not service:
service = typing.cast('Service', Service.objects.get(token=token))
# If exists, create and alias for it
alias_token = CryptoManager().randomString(40) # fix alias with new token
service.aliases.create(alias=alias_token)
# Locate an userService that belongs to this service and which
# Build the possible ids and make initial filter to match service

View File

@ -110,10 +110,8 @@ class ActorInitializeTest(rest.test.RESTActorTestCase):
result = success(unique_id)
# Ensure own token is assigned
self.assertEqual(result['own_token'], user_service.uuid)
# Ensure no alias token is provided
self.assertIsNone(result['alias_token'])
self.assertEqual(result['token'], user_service.uuid)
self.assertEqual(result['own_token'], result['token']) # Compat value with 3.x actors
# Ensure unique_id detected is ours
self.assertEqual(result['unique_id'], unique_id)
@ -133,8 +131,8 @@ class ActorInitializeTest(rest.test.RESTActorTestCase):
# Now invoke failure with valid token but invalid mac
result = failure(actor_token, 'invalid mac', False)
self.assertIsNone(result['own_token'], None)
self.assertIsNone(result['alias_token'])
self.assertIsNone(result['own_token'])
self.assertIsNone(result['token'])
self.assertIsNone(result['os'])
self.assertIsNone(result['unique_id'])
@ -157,34 +155,37 @@ class ActorInitializeTest(rest.test.RESTActorTestCase):
)
# Unmanaged host is the response for initialization of unmanaged actor ALWAYS
self.assertIsNone(result['alias_token'])
self.assertIsNone(result['own_token'])
self.assertIsInstance(result['token'], str)
self.assertEqual(result['token'], result['own_token'])
self.assertIsNone(result['unique_id'])
self.assertIsNone(result['os'])
# Store alias token for later tests
alias_token = result['token']
# Now, invoke a "nice" initialize
result = success(
actor_token,
mac=unique_id,
)
alias_token = result['alias_token']
token = result['token']
self.assertIsInstance(alias_token, str)
self.assertEqual(result['own_token'], user_service.uuid)
self.assertEqual(result['alias_token'], alias_token)
self.assertIsInstance(token, str)
self.assertEqual(token, user_service.uuid)
self.assertEqual(token, result['own_token'])
self.assertEqual(result['unique_id'], unique_id)
# Ensure that the alias returned is on alias db, and it points to the same service as the one we belong to
alias = models.ServiceTokenAlias.objects.get(alias=result['alias_token'])
alias = models.ServiceTokenAlias.objects.get(alias=alias_token)
self.assertEqual(alias.service, user_service.deployed_service.service)
# Now, we should be able to "initialize" with valid mac and with original and alias tokens
# If we call initialize and we get "own-token" means that we have already logged in with this data
result = success(alias_token, mac=unique_id)
self.assertEqual(result['own_token'], user_service.uuid)
self.assertEqual(result['alias_token'], alias_token)
self.assertEqual(result['token'], user_service.uuid)
self.assertEqual(result['token'], result['own_token'])
self.assertEqual(result['unique_id'], unique_id)
#

View File

@ -52,7 +52,10 @@ class UDSHttpResponse(HttpResponse):
def __init__(self, content, *args, **kwargs):
super().__init__(content, *args, **kwargs)
self.content = content
self.content = content # type: ignore # mypy does not know about this setter
def json(self) -> typing.Any:
return super().json() # type: ignore # mypy does not know about this method
class UDSClientMixin: