| PUT | /customers/{Id} | Update an existing customer | Updates an existing user if the current logged in user is allowed to update the specified customer. Users are only allowed to update their own info, administrators are allowed to update customer belonging to their company (if no account is created, email is added, if so the customer can only update it's own info). | 
|---|
| Name | Parameter | Data Type | Required | Description | 
|---|---|---|---|---|
| CompanyId | query | Guid? | No | Enter the company and id for the customer, if blank company id and you are an admin, your company id will be used. | 
| Id | path | Guid | Yes | customer id | 
| Firstname | body | string | Yes | |
| Lastname | body | string | Yes | |
| Phone | body | string | Yes | |
| body | string | Yes | ||
| CustomFields | body | List<AddCustomField> | Yes | If Custom Fields are added to the customer, here you will send the id and the value for each custom field to be updated | 
| AccessKeys | body | List<AddUserAccessKey> | Yes | List of Access Keys | 
| AccessKeysToDelete | body | List<DeleteUserAccessKey> | Yes | |
| SubscribedToNewsletter | body | bool? | No | |
| InvoiceAddress | body | InvoiceAddressToHandle | Yes | 
| Name | Parameter | Data Type | Required | Description | 
|---|---|---|---|---|
| Id | form | int | No | |
| Value | form | string | Yes | 
| Name | Parameter | Data Type | Required | Description | 
|---|---|---|---|---|
| Id | form | Guid? | No | Specify 'Id' to update an existing access key, leave empty to create a new one | 
| CompanyId | form | Guid? | No | The company ID associated with this access key | 
| AccessKeyTypeId | form | int | No | The type of access key to create | 
| Value | form | string | Yes | The actual key value or token | 
| CustomerId | form | Guid? | No | The customer ID this access key is associated with | 
| Description | form | string | Yes | A description or note about this access key | 
| Name | Parameter | Data Type | Required | Description | 
|---|---|---|---|---|
| Id | form | Guid | No | The unique identifier of the access key to delete | 
| Name | Parameter | Data Type | Required | Description | 
|---|---|---|---|---|
| CorporateIdentityNumber | form | string | Yes | |
| InvoiceAddress1 | form | string | Yes | |
| InvoiceAddress2 | form | string | Yes | |
| InvoiceCity | form | string | Yes | |
| InvoicePostalCode | form | string | Yes | |
| InvoiceCountryCode | form | string | Yes | 
| Name | Parameter | Data Type | Required | Description | 
|---|---|---|---|---|
| Id | form | Guid | No | |
| Firstname | form | string | Yes | |
| Lastname | form | string | Yes | |
| form | string | Yes | ||
| Phone | form | string | Yes | |
| ImageUrl | form | string | Yes | |
| CustomFields | form | List<CustomFieldConfigData> | Yes | |
| CustomFieldValues | form | List<CustomFieldDataResponse> | Yes | |
| Comments | form | List<CustomerCommentsResponse> | Yes | |
| AccessKeys | form | List<UserAccessKeys> | Yes | |
| Updated | form | DateTime | No | |
| Created | form | DateTime | No | |
| ResponseStatus | form | Object | Yes | |
| SubscribedToNewsletter | form | bool | No | |
| InvoiceAddress | form | InvoiceAddressResponse | Yes | 
| Name | Parameter | Data Type | Required | Description | 
|---|---|---|---|---|
| Id | form | int | No | Custom field id | 
| Name | form | string | Yes | Configuration name. Example: 'Number of persons'. | 
| Description | form | string | Yes | Custom field description. Example: 'For how many persons is this booking?' | 
| Width | form | int? | No | Field width. Example: 20 for 20px | 
| DataType | form | string | Yes | Data field of custom field. Valid values are: TextBox, ... Example: 'TextBox' | 
| DefaultValue | form | string | Yes | Default value of the field. Example: '3' | 
| IsMandatory | form | bool | No | Determines if the field is required to have a value or not | 
| MandatoryErrorMessage | form | string | Yes | Error message shown to the user if the field data is required but not entered | 
| MaxLength | form | int | No | Max lenght of the field | 
| MultipleLineText | form | bool | No | If the field should have multiple lines | 
| RegEx | form | string | Yes | Regular expression used for validation of the field | 
| RegExErrorMessage | form | string | Yes | Error message shown if the regular expression validation failed | 
| Values | form | List<CustomFieldValueResponse> | Yes | The values to select from if Datatype is DropDown for this custom field | 
| Name | Parameter | Data Type | Required | Description | 
|---|---|---|---|---|
| Value | form | string | Yes | 
| Name | Parameter | Data Type | Required | Description | 
|---|---|---|---|---|
| Id | form | int | No | |
| Column | form | string | Yes | |
| Name | form | string | Yes | |
| Description | form | string | Yes | |
| Value | form | string | Yes | |
| DataType | form | string | Yes | Data field of custom field. Valid values are: TextBox, ... Example: 'TextBox' | 
| Name | Parameter | Data Type | Required | Description | 
|---|---|---|---|---|
| Id | form | int | No | |
| CustomerId | form | Guid | No | |
| Comments | form | string | Yes | |
| Updated | form | DateTime | No | |
| Created | form | DateTime | No | |
| ImageUrl | form | Uri | Yes | 
| Name | Parameter | Data Type | Required | Description | 
|---|---|---|---|---|
| CompanyId | form | Guid | Yes | |
| AccessKeyTypeId | form | int | Yes | |
| Value | form | string | Yes | |
| CustomerId | form | Guid | Yes | |
| Description | form | string | No | |
| Id | form | Guid | Yes | 
| Name | Parameter | Data Type | Required | Description | 
|---|---|---|---|---|
| InvoiceAddressId | form | Guid | No | |
| UserId | form | Guid? | No | |
| CorporateIdentityNumber | form | string | Yes | |
| InvoiceAddress1 | form | string | Yes | |
| InvoiceAddress2 | form | string | Yes | |
| InvoiceCity | form | string | Yes | |
| InvoicePostalCode | form | string | Yes | |
| InvoiceCountryCode | form | string | Yes | 
To override the Content-type in your clients, use the HTTP Accept Header, append the .other suffix or ?format=other
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
PUT /customers/{Id} HTTP/1.1 
Host: api.bokamera.se 
Accept: text/jsonl
Content-Type: text/jsonl
Content-Length: length
{"CompanyId":"00000000-0000-0000-0000-000000000000","Firstname":"String","Lastname":"String","Phone":"String","Email":"String","CustomFields":[{"Id":0,"Value":"String"}],"AccessKeys":[{"Id":"00000000-0000-0000-0000-000000000000","CompanyId":"00000000-0000-0000-0000-000000000000","AccessKeyTypeId":0,"Value":"String","CustomerId":"00000000-0000-0000-0000-000000000000","Description":"String"}],"AccessKeysToDelete":[{}],"SubscribedToNewsletter":false,"InvoiceAddress":{"CorporateIdentityNumber":"String","InvoiceAddress1":"String","InvoiceAddress2":"String","InvoiceCity":"String","InvoicePostalCode":"String","InvoiceCountryCode":"String"}}
HTTP/1.1 200 OK
Content-Type: text/jsonl
Content-Length: length
{"Firstname":"String","Lastname":"String","Email":"String","Phone":"String","ImageUrl":"String","CustomFields":[{"Id":0,"Name":"String","Description":"String","Width":0,"DataType":"String","DefaultValue":"String","IsMandatory":false,"MandatoryErrorMessage":"String","MaxLength":0,"MultipleLineText":false,"RegEx":"String","RegExErrorMessage":"String","Values":[{"Value":"String"}]}],"CustomFieldValues":[{"Id":0,"Column":"String","Name":"String","Description":"String","Value":"String","DataType":"String"}],"Comments":[{"Id":0,"Comments":"String"}],"AccessKeys":[{"AccessKeyTypeId":0,"Value":"String","Description":"String"}],"ResponseStatus":{},"SubscribedToNewsletter":false,"InvoiceAddress":{"UserId":"00000000-0000-0000-0000-000000000000","CorporateIdentityNumber":"String","InvoiceAddress1":"String","InvoiceAddress2":"String","InvoiceCity":"String","InvoicePostalCode":"String","InvoiceCountryCode":"String"}}