MicroApp API

<back to all web services

AssignRoles

auth
Requires Authentication
Required role:Admin
The following routes are available for this service:
POST/assignroles
import 'package:servicestack/servicestack.dart';

// @DataContract
class AssignRolesResponse implements IMeta, IConvertible
{
    // @DataMember(Order=1)
    List<String>? allRoles;

    // @DataMember(Order=2)
    List<String>? allPermissions;

    // @DataMember(Order=3)
    Map<String,String?>? meta;

    // @DataMember(Order=4)
    ResponseStatus? responseStatus;

    AssignRolesResponse({this.allRoles,this.allPermissions,this.meta,this.responseStatus});
    AssignRolesResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        allRoles = JsonConverters.fromJson(json['allRoles'],'List<String>',context!);
        allPermissions = JsonConverters.fromJson(json['allPermissions'],'List<String>',context!);
        meta = JsonConverters.toStringMap(json['meta']);
        responseStatus = JsonConverters.fromJson(json['responseStatus'],'ResponseStatus',context!);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'allRoles': JsonConverters.toJson(allRoles,'List<String>',context!),
        'allPermissions': JsonConverters.toJson(allPermissions,'List<String>',context!),
        'meta': meta,
        'responseStatus': JsonConverters.toJson(responseStatus,'ResponseStatus',context!)
    };

    getTypeName() => "AssignRolesResponse";
    TypeContext? context = _ctx;
}

// @DataContract
class AssignRoles implements IPost, IMeta, IConvertible
{
    // @DataMember(Order=1)
    String? userName;

    // @DataMember(Order=2)
    List<String>? permissions;

    // @DataMember(Order=3)
    List<String>? roles;

    // @DataMember(Order=4)
    Map<String,String?>? meta;

    AssignRoles({this.userName,this.permissions,this.roles,this.meta});
    AssignRoles.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        userName = json['userName'];
        permissions = JsonConverters.fromJson(json['permissions'],'List<String>',context!);
        roles = JsonConverters.fromJson(json['roles'],'List<String>',context!);
        meta = JsonConverters.toStringMap(json['meta']);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'userName': userName,
        'permissions': JsonConverters.toJson(permissions,'List<String>',context!),
        'roles': JsonConverters.toJson(roles,'List<String>',context!),
        'meta': meta
    };

    getTypeName() => "AssignRoles";
    TypeContext? context = _ctx;
}

TypeContext _ctx = TypeContext(library: 'apps.harbourassist.com', types: <String, TypeInfo> {
});

Dart AssignRoles DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv

HTTP + JSV

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /assignroles HTTP/1.1 
Host: apps.harbourassist.com 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	userName: String,
	permissions: 
	[
		String
	],
	roles: 
	[
		String
	],
	meta: 
	{
		String: String
	}
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	allRoles: 
	[
		String
	],
	allPermissions: 
	[
		String
	],
	meta: 
	{
		String: String
	},
	responseStatus: 
	{
		errorCode: String,
		message: String,
		stackTrace: String,
		errors: 
		[
			{
				errorCode: String,
				fieldName: String,
				message: String,
				meta: 
				{
					String: String
				}
			}
		],
		meta: 
		{
			String: String
		}
	}
}