BokaMera.API.Host

<back to all web services

UpdateUser

Requires Authentication
The following routes are available for this service:
PUT/usersUpdate my informationUpdates the logged in users info both in customer profile and application admin profile if any exists. Users are only allowed to update their own info.
using System;
using System.Collections;
using System.Collections.Generic;
using System.Runtime.Serialization;
using ServiceStack;
using ServiceStack.DataAnnotations;
using BokaMera.API.ServiceModel.Dtos;
using BokaMera.API.ServiceModel.Enums;

namespace BokaMera.API.ServiceModel.Dtos
{
    public partial class AdminProfile
    {
        public virtual Guid CompanyId { get; set; }
        public virtual Guid Id { get; set; }
        public virtual string Firstname { get; set; }
        public virtual string Lastname { get; set; }
        public virtual string Email { get; set; }
        public virtual string WorkerId { get; set; }
        public virtual string Phone { get; set; }
    }

    public partial class UpdateAdminProfile
    {
        public virtual string Firstname { get; set; }
        public virtual string Lastname { get; set; }
        public virtual string Phone { get; set; }
        public virtual string Email { get; set; }
    }

    public partial class UpdateCustomerProfile
    {
        public virtual string Firstname { get; set; }
        public virtual string Lastname { get; set; }
        public virtual string Phone { get; set; }
        public virtual string Email { get; set; }
    }

    [ApiResponse(Description="Returned if there is a validation error on the input parameters", StatusCode=400)]
    [ApiResponse(Description="Returned if the current user is not allowed to perform the action", StatusCode=401)]
    [ValidateRequest("IsAuthenticated")]
    public partial class UpdateUser
    {
        ///<summary>
        ///The user id for your profile.
        ///</summary>
        [ApiMember(Description="The user id for your profile.")]
        public virtual Guid? UserId { get; set; }

        public virtual string NewEmail { get; set; }
        public virtual UpdateCustomerProfile UserProfile { get; set; }
        public virtual UpdateAdminProfile AdminProfile { get; set; }
        ///<summary>
        ///The user realm for identity server.  BookMore = 1, BookMoreAdmin = 2 
        ///</summary>
        [ApiMember(Description="The user realm for identity server.  BookMore = 1, BookMoreAdmin = 2 ", IsRequired=true)]
        public virtual KeyCloakRealm Realm { get; set; }
    }

    public partial class UpdateUserResponse
    {
        public virtual Object ResponseStatus { get; set; }
        ///<summary>
        ///The user id for your profile.
        ///</summary>
        [ApiMember(Description="The user id for your profile.", IsRequired=true)]
        public virtual Guid? UserId { get; set; }

        public virtual UserProfileResponse UserProfile { get; set; }
        public virtual AdminProfile AdminProfile { get; set; }
        public virtual bool? IsSentConfirmationUpdateEmail { get; set; }
    }

    public partial class UserProfileResponse
    {
        public virtual Guid Id { get; set; }
        public virtual string Firstname { get; set; }
        public virtual string Lastname { get; set; }
        public virtual string Phone { get; set; }
        public virtual string Email { get; set; }
    }

}

namespace BokaMera.API.ServiceModel.Enums
{
    public enum KeyCloakRealm
    {
        BookMore = 1,
        BookMoreAdmin = 2,
        SuperAdmin = 3,
    }

}

C# UpdateUser 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.

PUT /users HTTP/1.1 
Host: testapi.bokamera.se 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	UserId: 00000000-0000-0000-0000-000000000000,
	NewEmail: String,
	UserProfile: 
	{
		Firstname: String,
		Lastname: String,
		Phone: String,
		Email: String
	},
	AdminProfile: 
	{
		Firstname: String,
		Lastname: String,
		Phone: String,
		Email: String
	},
	Realm: BookMore
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	ResponseStatus: {},
	UserId: 00000000-0000-0000-0000-000000000000,
	UserProfile: 
	{
		Firstname: String,
		Lastname: String,
		Phone: String,
		Email: String
	},
	AdminProfile: 
	{
		Firstname: String,
		Lastname: String,
		Email: String,
		WorkerId: String,
		Phone: String
	},
	IsSentConfirmationUpdateEmail: False
}