Requires any of the roles: | bookingsupplier-administrator-write, superadmin |
PUT | /codelock/settings | Update settings for the code locks of the company of the currently logged in user | Update settings for code lock of the company of the currently logged in user. |
---|
import Foundation
import ServiceStack
// @ValidateRequest(Validator="IsAuthenticated")
// @ApiResponse(Description="You were unauthorized to call this service", StatusCode=401)
// @ApiResponse(Description="You have too low privileges to call this service", StatusCode=403)
public class UpdateCodeLockSetting : ICompany, Codable
{
/**
* The company id, if empty will use the company id for the user you are logged in with.
*/
// @ApiMember(Description="The company id, if empty will use the company id for the user you are logged in with.")
public var companyId:String?
/**
* If code lock sync is active
*/
// @ApiMember(DataType="bool", Description="If code lock sync is active")
public var active:Bool?
/**
* The system type of the code lock
*/
// @ApiMember(DataType="int", Description="The system type of the code lock")
public var codeLockSystemsId:Int?
/**
* Number of minutes the access should be valid before booking starts.
*/
// @ApiMember(DataType="int", Description="Number of minutes the access should be valid before booking starts.")
public var validBeforeMinutes:Int?
/**
* Number of minutes the access should be valid after booking ends.
*/
// @ApiMember(DataType="int", Description="Number of minutes the access should be valid after booking ends.")
public var validAfterMinutes:Int?
/**
* If it should clean up old bookings after the passed
*/
// @ApiMember(DataType="boolean", Description="If it should clean up old bookings after the passed")
public var deleteOldBySchedule:Bool?
/**
* If a notification should be sent by Email
*/
// @ApiMember(DataType="boolean", Description="If a notification should be sent by Email")
public var sendEmailNotification:Bool?
/**
* If a notification should be sent by SMS
*/
// @ApiMember(DataType="boolean", Description="If a notification should be sent by SMS")
public var sendSMSNotification:Bool?
/**
* How long before the booking starts in minutes the notification should be sent
*/
// @ApiMember(DataType="int", Description="How long before the booking starts in minutes the notification should be sent")
public var emailNotificationTime:Int?
/**
* How long before the booking starts in minutes the notification should be sent
*/
// @ApiMember(DataType="int", Description="How long before the booking starts in minutes the notification should be sent")
public var smsNotificationTime:Int?
required public init(){}
}
public class CodeLockSettingResponse : Codable
{
public var companyId:String
/**
* The system type of the code lock
*/
// @ApiMember(DataType="int", Description="The system type of the code lock")
public var codeLockSystemsId:Int
/**
* If code lock sync is active
*/
// @ApiMember(DataType="bool", Description="If code lock sync is active")
public var active:Bool
/**
* Number of minutes the access should be valid before booking starts.
*/
// @ApiMember(DataType="int", Description="Number of minutes the access should be valid before booking starts.")
public var validBeforeMinutes:Int
/**
* Number of minutes the access should be valid after booking ends.
*/
// @ApiMember(DataType="int", Description="Number of minutes the access should be valid after booking ends.")
public var validAfterMinutes:Int
/**
* If it should clean up old bookings after the passed
*/
// @ApiMember(DataType="boolean", Description="If it should clean up old bookings after the passed")
public var deleteOldBySchedule:Bool
/**
* If a notification should be sent by Email
*/
// @ApiMember(DataType="boolean", Description="If a notification should be sent by Email")
public var sendEmailNotification:Bool
/**
* If a notification should be sent by SMS
*/
// @ApiMember(DataType="boolean", Description="If a notification should be sent by SMS")
public var sendSMSNotification:Bool
/**
* How long before the booking starts in minutes the notification should be sent
*/
// @ApiMember(DataType="int", Description="How long before the booking starts in minutes the notification should be sent")
public var emailNotificationTime:Int
/**
* How long before the booking starts in minutes the notification should be sent
*/
// @ApiMember(DataType="int", Description="How long before the booking starts in minutes the notification should be sent")
public var smsNotificationTime:Int
/**
* When settings was created
*/
// @ApiMember(DataType="datetime", Description="When settings was created")
public var created:Date
/**
* When settings was updated
*/
// @ApiMember(DataType="datetime", Description="When settings was updated")
public var updated:Date
/**
* The available code lock systems to choose from
*/
// @ApiMember(Description="The available code lock systems to choose from")
public var codeLockSystemOptions:[CodeLockSystemResponse] = []
required public init(){}
}
public class CodeLockSystemResponse : Codable
{
/**
* The system type of the code lock
*/
// @ApiMember(DataType="int", Description="The system type of the code lock")
public var id:Int
/**
* The name of the code lock system
*/
// @ApiMember(DataType="string", Description="The name of the code lock system")
public var name:String
/**
* The description of the code lock system
*/
// @ApiMember(DataType="string", Description="The description of the code lock system")
public var Description:String
/**
* The logotype of the code lock system
*/
// @ApiMember(Description="The logotype of the code lock system")
public var logoType:Uri
/**
* The supplier name of the code lock system
*/
// @ApiMember(Description="The supplier name of the code lock system")
public var supplier:String
required public init(){}
}
Swift UpdateCodeLockSetting DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .xml suffix or ?format=xml
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
PUT /codelock/settings HTTP/1.1
Host: api.bokamera.se
Accept: application/xml
Content-Type: application/xml
Content-Length: length
<UpdateCodeLockSetting xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/BokaMera.API.ServiceModel.Dtos">
<Active>false</Active>
<CodeLockSystemsId>0</CodeLockSystemsId>
<CompanyId>00000000-0000-0000-0000-000000000000</CompanyId>
<DeleteOldBySchedule>false</DeleteOldBySchedule>
<EmailNotificationTime>0</EmailNotificationTime>
<SMSNotificationTime>0</SMSNotificationTime>
<SendEmailNotification>false</SendEmailNotification>
<SendSMSNotification>false</SendSMSNotification>
<ValidAfterMinutes>0</ValidAfterMinutes>
<ValidBeforeMinutes>0</ValidBeforeMinutes>
</UpdateCodeLockSetting>
HTTP/1.1 200 OK Content-Type: application/xml Content-Length: length <CodeLockSettingResponse xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/BokaMera.API.ServiceModel.Dtos"> <Active>false</Active> <CodeLockSystemOptions> <CodeLockSystemResponse> <Description>String</Description> <Id>0</Id> <LogoType i:nil="true" /> <Name>String</Name> <Supplier>String</Supplier> </CodeLockSystemResponse> </CodeLockSystemOptions> <CodeLockSystemsId>0</CodeLockSystemsId> <CompanyId>00000000-0000-0000-0000-000000000000</CompanyId> <Created>0001-01-01T00:00:00</Created> <DeleteOldBySchedule>false</DeleteOldBySchedule> <EmailNotificationTime>0</EmailNotificationTime> <SMSNotificationTime>0</SMSNotificationTime> <SendEmailNotification>false</SendEmailNotification> <SendSMSNotification>false</SendSMSNotification> <Updated>0001-01-01T00:00:00</Updated> <ValidAfterMinutes>0</ValidAfterMinutes> <ValidBeforeMinutes>0</ValidBeforeMinutes> </CodeLockSettingResponse>