updateRolePermissions method
Update Role Permissions Update role permissions.
Parameters:
roleId
- The identifier for the role.updateRolePermissionsRequest
cancelToken
- ACancelToken
that can be used to cancel the operationheaders
- Can be used to add additional headers to the requestextras
- Can be used to add flags to the requestvalidateStatus
- AValidateStatus
callback that can be used to determine request success based on the HTTP status of the responseonSendProgress
- AProgressCallback
that can be used to get the send progressonReceiveProgress
- AProgressCallback
that can be used to get the receive progress
Returns a Future containing a Response
with a UpdateRolePermissionsResponse as data
Throws DioException
if API call or serialization fails
Implementation
Future<Response<UpdateRolePermissionsResponse>> updateRolePermissions({
required String roleId,
required UpdateRolePermissionsRequest updateRolePermissionsRequest,
CancelToken? cancelToken,
Map<String, dynamic>? headers,
Map<String, dynamic>? extra,
ValidateStatus? validateStatus,
ProgressCallback? onSendProgress,
ProgressCallback? onReceiveProgress,
}) async {
final path = r'/api/v1/roles/{role_id}/permissions'.replaceAll('{' r'role_id' '}', encodeQueryParameter(_serializers, roleId, const FullType(String)).toString());
final options = Options(
method: r'PATCH',
headers: <String, dynamic>{
...?headers,
},
extra: <String, dynamic>{
'secure': <Map<String, String>>[
{
'type': 'http',
'scheme': 'bearer',
'name': 'kindeBearerAuth',
},
],
...?extra,
},
contentType: 'application/json',
validateStatus: validateStatus,
);
dynamic bodyData;
try {
const type = FullType(UpdateRolePermissionsRequest);
bodyData = _serializers.serialize(updateRolePermissionsRequest, specifiedType: type);
} catch(error, stackTrace) {
throw DioException(
requestOptions: options.compose(
_dio.options,
path,
),
type: DioExceptionType.unknown,
error: error,
stackTrace: stackTrace,
);
}
final response = await _dio.request<Object>(
path,
data: bodyData,
options: options,
cancelToken: cancelToken,
onSendProgress: onSendProgress,
onReceiveProgress: onReceiveProgress,
);
UpdateRolePermissionsResponse? responseData;
try {
final rawResponse = response.data;
responseData = rawResponse == null ? null : _serializers.deserialize(
rawResponse,
specifiedType: const FullType(UpdateRolePermissionsResponse),
) as UpdateRolePermissionsResponse;
} catch (error, stackTrace) {
throw DioException(
requestOptions: response.requestOptions,
response: response,
type: DioExceptionType.unknown,
error: error,
stackTrace: stackTrace,
);
}
return Response<UpdateRolePermissionsResponse>(
data: responseData,
headers: response.headers,
isRedirect: response.isRedirect,
requestOptions: response.requestOptions,
redirects: response.redirects,
statusCode: response.statusCode,
statusMessage: response.statusMessage,
extra: response.extra,
);
}