Portal

<back to all web services

AddUser

The following routes are available for this service:
POST/user
import Foundation
import ServiceStack

public class AddUser : IPost, Codable
{
    public var email:String
    public var password:String
    public var displayName:String
    public var mobilePhoneNumberCountryCodeId:Int
    public var mobilePhoneNumber:String
    public var phoneNumberCountryCodeId:Int?
    public var phoneNumber:String
    public var phoneNumberExtension:String

    required public init(){}
}

public class AddUserResponse : ModifyEntityResponse
{
    public var isConfirmationEmailSent:Bool
    public var isResetPasswordEmailSent:Bool

    required public init(){ super.init() }

    private enum CodingKeys : String, CodingKey {
        case isConfirmationEmailSent
        case isResetPasswordEmailSent
    }

    required public init(from decoder: Decoder) throws {
        try super.init(from: decoder)
        let container = try decoder.container(keyedBy: CodingKeys.self)
        isConfirmationEmailSent = try container.decodeIfPresent(Bool.self, forKey: .isConfirmationEmailSent)
        isResetPasswordEmailSent = try container.decodeIfPresent(Bool.self, forKey: .isResetPasswordEmailSent)
    }

    public override func encode(to encoder: Encoder) throws {
        try super.encode(to: encoder)
        var container = encoder.container(keyedBy: CodingKeys.self)
        if isConfirmationEmailSent != nil { try container.encode(isConfirmationEmailSent, forKey: .isConfirmationEmailSent) }
        if isResetPasswordEmailSent != nil { try container.encode(isResetPasswordEmailSent, forKey: .isResetPasswordEmailSent) }
    }
}

public class ModifyEntityResponse : ResponseBase
{
    public var id:Int

    required public init(){ super.init() }

    private enum CodingKeys : String, CodingKey {
        case id
    }

    required public init(from decoder: Decoder) throws {
        try super.init(from: decoder)
        let container = try decoder.container(keyedBy: CodingKeys.self)
        id = try container.decodeIfPresent(Int.self, forKey: .id)
    }

    public override func encode(to encoder: Encoder) throws {
        try super.encode(to: encoder)
        var container = encoder.container(keyedBy: CodingKeys.self)
        if id != nil { try container.encode(id, forKey: .id) }
    }
}

public class ResponseBase : Codable
{
    public var responseStatus:ResponseStatus

    required public init(){}
}


Swift AddUser 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 /user HTTP/1.1 
Host: szallitoiportal-be.veolia.hu 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	Email: String,
	Password: String,
	DisplayName: String,
	MobilePhoneNumberCountryCodeId: 0,
	MobilePhoneNumber: String,
	PhoneNumberCountryCodeId: 0,
	PhoneNumber: String,
	PhoneNumberExtension: String
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	IsConfirmationEmailSent: False,
	IsResetPasswordEmailSent: False,
	Id: 0,
	ResponseStatus: 
	{
		ErrorCode: String,
		Message: String,
		StackTrace: String,
		Errors: 
		[
			{
				ErrorCode: String,
				FieldName: String,
				Message: String,
				Meta: 
				{
					String: String
				}
			}
		],
		Meta: 
		{
			String: String
		}
	}
}