Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions scaleway-async/scaleway_async/iam/v1alpha1/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,7 @@
from .types import UpdateSSHKeyRequest
from .types import UpdateUserPasswordRequest
from .types import UpdateUserRequest
from .types import UpdateUserUsernameRequest
from .api import IamV1Alpha1API

__all__ = [
Expand Down Expand Up @@ -199,5 +200,6 @@
"UpdateSSHKeyRequest",
"UpdateUserPasswordRequest",
"UpdateUserRequest",
"UpdateUserUsernameRequest",
"IamV1Alpha1API",
]
39 changes: 39 additions & 0 deletions scaleway-async/scaleway_async/iam/v1alpha1/api.py
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,7 @@
UpdateSSHKeyRequest,
UpdateUserPasswordRequest,
UpdateUserRequest,
UpdateUserUsernameRequest,
User,
)
from .marshalling import (
Expand Down Expand Up @@ -120,6 +121,7 @@
marshal_UpdateSSHKeyRequest,
marshal_UpdateUserPasswordRequest,
marshal_UpdateUserRequest,
marshal_UpdateUserUsernameRequest,
)


Expand Down Expand Up @@ -585,6 +587,43 @@ async def create_user(
self._throw_on_error(res)
return unmarshal_User(res.json())

async def update_user_username(
self,
*,
user_id: str,
username: str,
) -> User:
"""
:param user_id:
:param username:
:return: :class:`User <User>`

Usage:
::

result = await api.update_user_username(
user_id="example",
username="example",
)
"""

param_user_id = validate_path_param("user_id", user_id)

res = self._request(
"POST",
f"/iam/v1alpha1/users/{param_user_id}/update-username",
body=marshal_UpdateUserUsernameRequest(
UpdateUserUsernameRequest(
user_id=user_id,
username=username,
),
self.client,
),
)

self._throw_on_error(res)
return unmarshal_User(res.json())

async def update_user_password(
self,
*,
Expand Down
13 changes: 13 additions & 0 deletions scaleway-async/scaleway_async/iam/v1alpha1/marshalling.py
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,7 @@
UpdateSSHKeyRequest,
UpdateUserPasswordRequest,
UpdateUserRequest,
UpdateUserUsernameRequest,
)


Expand Down Expand Up @@ -1473,3 +1474,15 @@ def marshal_UpdateUserRequest(
output["email"] = request.email

return output


def marshal_UpdateUserUsernameRequest(
request: UpdateUserUsernameRequest,
defaults: ProfileDefaults,
) -> Dict[str, Any]:
output: Dict[str, Any] = {}

if request.username is not None:
output["username"] = request.username

return output
7 changes: 7 additions & 0 deletions scaleway-async/scaleway_async/iam/v1alpha1/types.py
Original file line number Diff line number Diff line change
Expand Up @@ -1992,3 +1992,10 @@ class UpdateUserRequest:
"""
IAM member email.
"""


@dataclass
class UpdateUserUsernameRequest:
user_id: str

username: str
2 changes: 2 additions & 0 deletions scaleway/scaleway/iam/v1alpha1/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,7 @@
from .types import UpdateSSHKeyRequest
from .types import UpdateUserPasswordRequest
from .types import UpdateUserRequest
from .types import UpdateUserUsernameRequest
from .api import IamV1Alpha1API

__all__ = [
Expand Down Expand Up @@ -199,5 +200,6 @@
"UpdateSSHKeyRequest",
"UpdateUserPasswordRequest",
"UpdateUserRequest",
"UpdateUserUsernameRequest",
"IamV1Alpha1API",
]
39 changes: 39 additions & 0 deletions scaleway/scaleway/iam/v1alpha1/api.py
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,7 @@
UpdateSSHKeyRequest,
UpdateUserPasswordRequest,
UpdateUserRequest,
UpdateUserUsernameRequest,
User,
)
from .marshalling import (
Expand Down Expand Up @@ -120,6 +121,7 @@
marshal_UpdateSSHKeyRequest,
marshal_UpdateUserPasswordRequest,
marshal_UpdateUserRequest,
marshal_UpdateUserUsernameRequest,
)


Expand Down Expand Up @@ -585,6 +587,43 @@ def create_user(
self._throw_on_error(res)
return unmarshal_User(res.json())

def update_user_username(
self,
*,
user_id: str,
username: str,
) -> User:
"""
:param user_id:
:param username:
:return: :class:`User <User>`

Usage:
::

result = api.update_user_username(
user_id="example",
username="example",
)
"""

param_user_id = validate_path_param("user_id", user_id)

res = self._request(
"POST",
f"/iam/v1alpha1/users/{param_user_id}/update-username",
body=marshal_UpdateUserUsernameRequest(
UpdateUserUsernameRequest(
user_id=user_id,
username=username,
),
self.client,
),
)

self._throw_on_error(res)
return unmarshal_User(res.json())

def update_user_password(
self,
*,
Expand Down
13 changes: 13 additions & 0 deletions scaleway/scaleway/iam/v1alpha1/marshalling.py
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,7 @@
UpdateSSHKeyRequest,
UpdateUserPasswordRequest,
UpdateUserRequest,
UpdateUserUsernameRequest,
)


Expand Down Expand Up @@ -1473,3 +1474,15 @@ def marshal_UpdateUserRequest(
output["email"] = request.email

return output


def marshal_UpdateUserUsernameRequest(
request: UpdateUserUsernameRequest,
defaults: ProfileDefaults,
) -> Dict[str, Any]:
output: Dict[str, Any] = {}

if request.username is not None:
output["username"] = request.username

return output
7 changes: 7 additions & 0 deletions scaleway/scaleway/iam/v1alpha1/types.py
Original file line number Diff line number Diff line change
Expand Up @@ -1992,3 +1992,10 @@ class UpdateUserRequest:
"""
IAM member email.
"""


@dataclass
class UpdateUserUsernameRequest:
user_id: str

username: str
Loading