BokaMera.API.Host

<back to all web services

CurrentUserQuery

Requires Authentication
The following routes are available for this service:
GET/usersGet user informationGet information about the currently logged in user
CurrentUserQuery Parameters:
NameParameterData TypeRequiredDescription
IncludeFavoritesquerybooleanNoIf you want to include the users favorites
IncludeCompanyCustomersqueryboolNo
IncludeInvoiceAddressqueryboolNo
CurrentUserQueryResponse Parameters:
NameParameterData TypeRequiredDescription
UserIdformGuidNoThe user id for your profile.
FavoritesformList<UserFavorites>Yes
UserProfileformUserProfileResponseYes
CustomerProfileformUserProfileResponseYes
AdminProfileformAdminProfileYes
CompanyCustomersformList<CompanyCustomerResponse>Yes
InvoiceAddressformInvoiceAddressResponseYes
UserFavorites Parameters:
NameParameterData TypeRequiredDescription
CompanyIdformGuidNo
CompanyformCompanyQueryResponseYes
CompanyQueryResponse Parameters:
NameParameterData TypeRequiredDescription
IdformGuidNo
NameformstringYes
OrganisationNumberformstringYesThe organisation number will only be visible if you are the owner of the company.
TypeIdformintNoWhat type of company. If it's used for personal use or as a company.
DetailsformstringYes
CategoryIdformintNo
CategoryformstringYes
LogoTypeformUriYes
CoverImageformUriYes
Street1formstringYes
Street2formstringYes
ZipCodeformstringYes
CityformstringYes
CountryIdformstringYes
LongitudeformstringYes
LatitudeformstringYes
Distanceformdouble?No
PhoneformstringYes
EmailformstringYes
HomepageformstringYes
SitePathformstringYes
ActiveformboolNo
CodeLockSystemformCodeLockSystemType?No
IsFreeAccountformboolNo
UpdatedformdatetimeNoWill show when the company was updated, note it will only be shown if your logged in as admin for the company.
CreatedformdatetimeNoWill show when the company was created, note it will only be shown if your logged in as admin for the company.
StatusIdformintNo
IsFavoriteformbooleanNoIf the company is marked as favourite for the logged in user
BookingAgreementsformstringYes
BookingSettingsformCompanyBookingSettingsNo
SystemSettingsformCompanySystemSettingsNo
WidgetSettingsformCompanyWidgetSettingsNo
HomepageSettingsformHomepageSettingsResponseYes
RatingSummaryformCompanyRatingSummaryNo
ReviewsformList<RatingReviewResponse>Yes
CustomerCustomFieldsformList<CustomFieldConfigData>Yes
ResponseStatusformResponseStatusYes
CodeLockSystemType Enum:
Sample
RcoM5
AxemaVaka
VanderbiltOmnis
ParakeyParakey
AmidoDax
TelkeyTelkey
TechSolutionsSiedle
Accessy
Zesec
Enabla
CompanyBookingSettings Parameters:
NameParameterData TypeRequiredDescription
EnableMobileAppformboolNo
BookingReceiptMessageformstringYes
ShowFreeTimesLeftformboolNo
EnableShowBookedTimesformboolNo
BookingAgreementformstringYes
WeekNumberSettingformintNoThe settings for how to display week number. 1 = ShowWeekNumberFromDate, 2 = ShowWeekNumberToDate, 3 = ShowWeekNumberFromToDate, 4 = DontShowWeekNumber
ShowBookedTimesformboolNo
PaymentProviderIdformintNoThe payment provider id. To get the full payment provider for the company call GET /payment/settings
BookOnlyOnExistingCustomersformbooleanNoIf it's only allowed for existing customers to book
PaymentEnabledformbooleanNoIf payment is enabled
BookingPinCodeRestrictionformstringYes
CustomerInvoiceAdressRequiredformboolNo
CompanySystemSettings Parameters:
NameParameterData TypeRequiredDescription
ActiveformboolNoIf the booking is active or not
InactiveMessageformstringYesIf the booking is not active, what message to show to the customers
SearchableformboolNoIf the company should be visible in search results on homepage
GATrackingIdformstringYesIf you have a Google Analytics account and want to track your customers behaviors.
GoogleAdsConversionIdformstringYesIf you have a Google Ads Conversion Id account and want to track your customers behaviors.
LinkedinTagIdformstringYesIf you have a LinkedIn account and want to track your customers behaviors.
GoogleAdsConversionLabelformstringYesIf you have a Google Ads Conversion Label and want to track your customers behaviors.
GTMTrackingIdformstringYesIf you have a Google Tag Manager account and want to track your customers behaviors.
FacebookPixelIdformstringYesIf you have a Facebook account and want to track your customers behaviors.
MultiLanguageformboolNoIf you want your customers to be able to change language on your homepage
ShowOnMarketplaceformboolNoIf the company should be visible on the marketplace
EnableAPITranslationformboolNoIf you want your own written text on your homepage to be translated using Google Translate when a user changes language
DefaultLanguageformstringYesWhat is the standard language your homepage information is written in. Select from the different countries, i.e. SE,NO,EN
SendCustomerInformationToExternalProvidersformboolNoIf you want to allow to send customer information in the tracking events to the external providers. Note you as a company are responsible for informing your customers and handling the data in terms of GDPR.
SMSMessageDailySendLimitformintNoThe maximum number of SMS messages that can be sent per day.
EmailMessageDailySendLimitformintNoThe maximum number of email messages that can be sent per day.
CompanyWidgetSettings Parameters:
NameParameterData TypeRequiredDescription
ServiceLayoutIdformintNoThe service layouts id.
TimeLayoutIdformintNoThe time layouts id.
BookingLayoutIdformintNoThe booking layouts id.
PrimaryColorformstringYesThe primary color of the booking widget.
ShowServiceImageformboolNoIf you should show the service image in the booking widget.
ShowRebateCodeFieldformboolNoIf you should show the rebate code field in the booking widget.
ShowNextAvailableTimeformboolNoIf you should show the next available time in the booking widget.
ShowEndTimeformboolNoIf you should show the end time in the booking widget.
BookedTimeSlotTextformstringYesWhat text to show on booked time slots. Default text is Booked
DarkThemeformboolNoIf the widget should be displayed in dark theme
ShowSubscribeToNewsletterformboolNoIf you should show the subscribe to newsletter checkbox in the booking widget.
HomepageSettingsResponse Parameters:
NameParameterData TypeRequiredDescription
HomepageHeadingformstringYesThe text for homepage heading
WelcomePageHeadingformstringYesThe text for homepage startpage heading
WelcomePageBodyformstringYesThe text for homepage startpage body
AboutUsPageHeadingformstringYesThe text for homepage about us page heading
AboutUsPageBodyformstringYesThe text for homepage about us page body
ImageUrlformUriYesThe startpage image url
CoverImageformUriYesThe cover image url
ShowRatingformboolNoShow rating on the page
HomePageTemplateIdformintNoThe template for the homepage
HeroSectionStyleIdformintNoThe hero section style for the homepage
EnableHomepageformboolNoEnable the BokaMera Homepage
CompanyRatingSummary Parameters:
NameParameterData TypeRequiredDescription
AverageScoreformdoubleNoThe average rating score
RatingScore1CountformintNoThe number of ratings of score 1
RatingScore2CountformintNoThe number of ratings of score 2
RatingScore3CountformintNoThe number of ratings of score 3
RaingScore4CountformintNoThe number of ratings of score 4
RatingScore5CountformintNoThe number of ratings of score 5
CountformintNoThe number of ratings
RatingReviewResponse Parameters:
NameParameterData TypeRequiredDescription
TitleformstringYesThe title for the review
DescriptionformstringYesThe description for the review
RatingScoreformintNoThe rating score
AuthorformstringYesThe review author
CreatedformDateTimeNoThe created date
ReviewAnswerformstringYesThe review answer from the company
CustomFieldConfigData Parameters:
NameParameterData TypeRequiredDescription
IdformintNoCustom field id
NameformstringYesConfiguration name. Example: 'Number of persons'.
DescriptionformstringYesCustom field description. Example: 'For how many persons is this booking?'
Widthformint?NoField width. Example: 20 for 20px
DataTypeformstringYesData field of custom field. Valid values are: TextBox, ... Example: 'TextBox'
DefaultValueformstringYesDefault value of the field. Example: '3'
IsMandatoryformboolNoDetermines if the field is required to have a value or not
MandatoryErrorMessageformstringYesError message shown to the user if the field data is required but not entered
MaxLengthformintNoMax lenght of the field
MultipleLineTextformboolNoIf the field should have multiple lines
RegExformstringYesRegular expression used for validation of the field
RegExErrorMessageformstringYesError message shown if the regular expression validation failed
ValuesformList<CustomFieldValueResponse>YesThe values to select from if Datatype is DropDown for this custom field
CustomFieldValueResponse Parameters:
NameParameterData TypeRequiredDescription
ValueformstringYes
UserProfileResponse Parameters:
NameParameterData TypeRequiredDescription
IdformGuidNo
FirstnameformstringYes
LastnameformstringYes
PhoneformstringYes
EmailformstringYes
InvoiceAddressformInvoiceAddressResponseYes
InvoiceAddressResponse Parameters:
NameParameterData TypeRequiredDescription
InvoiceAddressIdformGuidNo
UserIdformGuid?No
CorporateIdentityNumberformstringYes
InvoiceAddress1formstringYes
InvoiceAddress2formstringYes
InvoiceCityformstringYes
InvoicePostalCodeformstringYes
InvoiceCountryCodeformstringYes
AdminProfile Parameters:
NameParameterData TypeRequiredDescription
CompanyIdformGuidNo
IdformGuidNo
FirstnameformstringYes
LastnameformstringYes
EmailformstringYes
WorkerIdformstringYes
PhoneformstringYes
CompanyCustomerResponse Parameters:
NameParameterData TypeRequiredDescription
CompanyIdformGuid?No
CompanyNameformstringNo
CustomerIdformGuid?No
SubscribedToNewsletterformboolNo
CustomFieldValuesformList<CustomFieldDataResponse>Yes
InvoiceAddressformInvoiceAddressResponseYes
CustomFieldDataResponse Parameters:
NameParameterData TypeRequiredDescription
IdformintNo
ColumnformstringYes
NameformstringYes
DescriptionformstringYes
ValueformstringYes
DataTypeformstringYesData field of custom field. Valid values are: TextBox, ... Example: 'TextBox'

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.

GET /users HTTP/1.1 
Host: api.bokamera.se 
Accept: text/jsv
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	Favorites: 
	[
		{
			Company: 
			{
				Name: String,
				OrganisationNumber: String,
				TypeId: 0,
				Details: String,
				CategoryId: 0,
				Category: String,
				Street1: String,
				Street2: String,
				ZipCode: String,
				City: String,
				CountryId: String,
				Longitude: String,
				Latitude: String,
				Distance: 0,
				Phone: String,
				Email: String,
				Homepage: String,
				SitePath: String,
				Active: False,
				CodeLockSystem: Sample,
				IsFreeAccount: False,
				Updated: "0001-01-01T00:00:00",
				Created: "0001-01-01T00:00:00",
				StatusId: 0,
				IsFavorite: False,
				BookingAgreements: String,
				BookingSettings: 
				{
					EnableMobileApp: False,
					BookingReceiptMessage: String,
					ShowFreeTimesLeft: False,
					EnableShowBookedTimes: False,
					BookingAgreement: String,
					WeekNumberSetting: 0,
					ShowBookedTimes: False,
					PaymentProviderId: 0,
					BookOnlyOnExistingCustomers: False,
					PaymentEnabled: False,
					BookingPinCodeRestriction: String,
					CustomerInvoiceAdressRequired: False
				},
				SystemSettings: 
				{
					Active: False,
					InactiveMessage: String,
					Searchable: False,
					GATrackingId: String,
					GoogleAdsConversionId: String,
					LinkedinTagId: String,
					GoogleAdsConversionLabel: String,
					GTMTrackingId: String,
					FacebookPixelId: String,
					MultiLanguage: False,
					ShowOnMarketplace: False,
					EnableAPITranslation: False,
					DefaultLanguage: String,
					SendCustomerInformationToExternalProviders: False,
					SMSMessageDailySendLimit: 0,
					EmailMessageDailySendLimit: 0
				},
				WidgetSettings: 
				{
					ServiceLayoutId: 0,
					TimeLayoutId: 0,
					BookingLayoutId: 0,
					PrimaryColor: String,
					ShowServiceImage: False,
					ShowRebateCodeField: False,
					ShowNextAvailableTime: False,
					ShowEndTime: False,
					BookedTimeSlotText: String,
					DarkTheme: False,
					ShowSubscribeToNewsletter: False
				},
				HomepageSettings: 
				{
					HomepageHeading: String,
					WelcomePageHeading: String,
					WelcomePageBody: String,
					AboutUsPageHeading: String,
					AboutUsPageBody: String,
					ShowRating: False,
					HomePageTemplateId: 0,
					HeroSectionStyleId: 0,
					EnableHomepage: False
				},
				RatingSummary: 
				{
					AverageScore: 0,
					RatingScore1Count: 0,
					RatingScore2Count: 0,
					RatingScore3Count: 0,
					RaingScore4Count: 0,
					RatingScore5Count: 0,
					Count: 0
				},
				Reviews: 
				[
					{
						Title: String,
						Description: String,
						RatingScore: 0,
						Author: String,
						ReviewAnswer: String
					}
				],
				CustomerCustomFields: 
				[
					{
						"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"
							}
						]
					}
				],
				ResponseStatus: 
				{
					ErrorCode: String,
					Message: String,
					StackTrace: String,
					Errors: 
					[
						{
							ErrorCode: String,
							FieldName: String,
							Message: String,
							Meta: 
							{
								String: String
							}
						}
					],
					Meta: 
					{
						String: String
					}
				}
			}
		}
	],
	UserProfile: 
	{
		Firstname: String,
		Lastname: String,
		Phone: String,
		Email: String,
		InvoiceAddress: 
		{
			UserId: 00000000-0000-0000-0000-000000000000,
			CorporateIdentityNumber: String,
			InvoiceAddress1: String,
			InvoiceAddress2: String,
			InvoiceCity: String,
			InvoicePostalCode: String,
			InvoiceCountryCode: String
		}
	},
	CustomerProfile: 
	{
		Firstname: String,
		Lastname: String,
		Phone: String,
		Email: String,
		InvoiceAddress: 
		{
			UserId: 00000000-0000-0000-0000-000000000000,
			CorporateIdentityNumber: String,
			InvoiceAddress1: String,
			InvoiceAddress2: String,
			InvoiceCity: String,
			InvoicePostalCode: String,
			InvoiceCountryCode: String
		}
	},
	AdminProfile: 
	{
		Firstname: String,
		Lastname: String,
		Email: String,
		WorkerId: String,
		Phone: String
	},
	CompanyCustomers: 
	[
		{
			CompanyId: 00000000-0000-0000-0000-000000000000,
			CompanyName: String,
			CustomerId: 00000000-0000-0000-0000-000000000000,
			SubscribedToNewsletter: False,
			CustomFieldValues: 
			[
				{
					Id: 0,
					Column: String,
					Name: String,
					Description: String,
					Value: String,
					DataType: String
				}
			],
			InvoiceAddress: 
			{
				UserId: 00000000-0000-0000-0000-000000000000,
				CorporateIdentityNumber: String,
				InvoiceAddress1: String,
				InvoiceAddress2: String,
				InvoiceCity: String,
				InvoicePostalCode: String,
				InvoiceCountryCode: String
			}
		}
	],
	InvoiceAddress: 
	{
		UserId: 00000000-0000-0000-0000-000000000000,
		CorporateIdentityNumber: String,
		InvoiceAddress1: String,
		InvoiceAddress2: String,
		InvoiceCity: String,
		InvoicePostalCode: String,
		InvoiceCountryCode: String
	}
}