addUserRaw method
Create a new user.
This method and the response it returns is experimental. The API might change without a major version bump.
Returns a Future containing a DynamiteRawResponse
with the raw HttpClientResponse
and serialization helpers.
Throws a DynamiteApiException
if the API call does not return an expected status code.
Parameters:
userid
ID of the user.password
Password of the user. Defaults to''
.displayName
Display name of the user. Defaults to''
.email
Email of the user. Defaults to''
.groups
Groups of the user. Defaults to[]
.subadmin
Groups where the user is subadmin. Defaults to[]
.quota
Quota of the user. Defaults to''
.language
Language of the user. Defaults to''
.manager
Manager of the user.oCSAPIRequest
Required to be true for the API request to pass. Defaults totrue
.
Status codes:
- 200: User added successfully
- 403: Missing permissions to make user subadmin
See:
- addUser for an operation that returns a
DynamiteResponse
with a stable API.
Implementation
@_i4.experimental
_i1.DynamiteRawResponse<UsersAddUserResponseApplicationJson, void> addUserRaw({
required String userid,
String? password,
String? displayName,
String? email,
BuiltList<String>? groups,
BuiltList<String>? subadmin,
String? quota,
String? language,
String? manager,
bool? oCSAPIRequest,
}) {
final _parameters = <String, dynamic>{};
final _headers = <String, String>{'Accept': 'application/json'};
// coverage:ignore-start
final authentication = _rootClient.authentications?.firstWhereOrNull(
(auth) => switch (auth) {
_i1.DynamiteHttpBearerAuthentication() || _i1.DynamiteHttpBasicAuthentication() => true,
_ => false,
},
);
if (authentication != null) {
_headers.addAll(
authentication.headers,
);
} else {
throw Exception('Missing authentication for bearer_auth or basic_auth');
}
// coverage:ignore-end
final $userid = _$jsonSerializers.serialize(userid, specifiedType: const FullType(String));
_parameters['userid'] = $userid;
var $password = _$jsonSerializers.serialize(password, specifiedType: const FullType(String));
$password ??= '';
_parameters['password'] = $password;
var $displayName = _$jsonSerializers.serialize(displayName, specifiedType: const FullType(String));
$displayName ??= '';
_parameters['displayName'] = $displayName;
var $email = _$jsonSerializers.serialize(email, specifiedType: const FullType(String));
$email ??= '';
_parameters['email'] = $email;
var $groups = _$jsonSerializers.serialize(groups, specifiedType: const FullType(BuiltList, [FullType(String)]));
$groups ??= [];
_parameters['groups%5B%5D'] = $groups;
var $subadmin = _$jsonSerializers.serialize(subadmin, specifiedType: const FullType(BuiltList, [FullType(String)]));
$subadmin ??= [];
_parameters['subadmin%5B%5D'] = $subadmin;
var $quota = _$jsonSerializers.serialize(quota, specifiedType: const FullType(String));
$quota ??= '';
_parameters['quota'] = $quota;
var $language = _$jsonSerializers.serialize(language, specifiedType: const FullType(String));
$language ??= '';
_parameters['language'] = $language;
final $manager = _$jsonSerializers.serialize(manager, specifiedType: const FullType(String));
_parameters['manager'] = $manager;
var $oCSAPIRequest = _$jsonSerializers.serialize(oCSAPIRequest, specifiedType: const FullType(bool));
$oCSAPIRequest ??= true;
_headers['OCS-APIRequest'] = const _i2.HeaderEncoder().convert($oCSAPIRequest);
final _path = _i3.UriTemplate(
'/ocs/v2.php/cloud/users{?userid*,password*,displayName*,email*,groups%5B%5D*,subadmin%5B%5D*,quota*,language*,manager*}',
).expand(_parameters);
return _i1.DynamiteRawResponse<UsersAddUserResponseApplicationJson, void>(
response: _rootClient.executeRequest(
'post',
_path,
headers: _headers,
validStatuses: const {200},
),
bodyType: const FullType(UsersAddUserResponseApplicationJson),
headersType: null,
serializers: _$jsonSerializers,
);
}