BokaMera.API.Host

<back to all web services

CreateIncentive

Requires Authentication
Requires the role:superadmin
The following routes are available for this service:
POST/superadmin/incentivesAdd a new incentive
CreateIncentive Parameters:
NameParameterData TypeRequiredDescription
HeadingbodystringYes
StorageUrlbodystringNo
BodybodystringNo
SuccessButtonTextbodystringYes
ActionIdbodyintYes
FrequencybodyIncentiveRecurrenceFrequencyYes
RecurrenceIntervalbodyuintNo
InitialDelayInSecondsbodyintYes
MaxDisplayCountbodyint?Yes
ValidFrombodyDateTimeOffsetYes
ValidTobodyDateTimeOffsetYes
ActivebodyboolNo
PayloadbodystringNo
CompanyIdsbodyList<Guid>No
CriteriabodyList<IncentiveCriteriaDto>No
IncentiveRecurrenceFrequency Enum:
NameValue
OneTime1
Weekly2
Monthly3
IncentiveCriteriaDto Parameters:
NameParameterData TypeRequiredDescription
CriteriaTypeformCriteriaTypeNo
ValueformstringNo
InvertConditionformboolNo
CriteriaType Enum:
LicenseAvailability
SmsActivation
eAccountingActivation
CodeLockActivation
SocialActivation
OnlinePaymentActivation
FollowUpMessageActivation
RatingActivation
AdminIncentiveQueryResponse Parameters:
NameParameterData TypeRequiredDescription
FrequencyformIncentiveRecurrenceFrequencyNo
RecurrenceIntervalformuintNo
CreatedDateformDateTimeOffsetNo
ModifiedDateformDateTimeOffsetNo
CompanyIdsformList<Guid>No
CriteriaformList<IncentiveCriteria>No
ApplyToAllCompaniesformboolNo
CompanyIncentiveResponse Parameters:
NameParameterData TypeRequiredDescription
IdformintNo
HeadingformstringNo
StorageUrlformstringNo
SuccessButtonTextformstringNo
ActionIdformintNo
InitialDelayInSecondsformintNo
MaxDisplayCountformint?No
ValidFromformDateTimeOffsetNo
ValidToformDateTimeOffsetNo
ActionformIncentiveActionResponseNo
PayloadformstringNo
IncentiveActionResponse Parameters:
NameParameterData TypeRequiredDescription
IdformintNo
ActionTypeformIncentiveActionTypeNo
PageformstringNo
SegmentformstringNo
ElementformstringNo
LicenseTypeIdformint?No
SuggestedLicenseToUpgradeformLicenseTypeQueryResponseNo
IncentiveActionType Enum:
NameValue
Upgrade1
AddOn2
Information3
LicenseTypeQueryResponse Parameters:
NameParameterData TypeRequiredDescription
IdformintNoThe license type id
NameformstringNoThe license type name
DescriptionformstringNoThe license type description
IsExtraLicenseOptionformboolNoIf the license type is not a standard license but instead an extra license option. An example would be sending new letter license.
PeriodOfNoticeDaysformintNoThe period of notice for the license in days.
ItemsformList<LicenseItemsResponse>NoThe license items for the license type
PricesformList<LicensePriceResponse>NoThe license prices in each country for the license type
LicenseItemsResponse Parameters:
NameParameterData TypeRequiredDescription
IdformintNo
NameformstringNo
AllowedItemsformintNo
LicensePriceResponse Parameters:
NameParameterData TypeRequiredDescription
LicenseTypeIdformintNo
CountryIdformstringNo
PriceformintNo
CountryformCountryNo
LicensePlanIdformintNo
Country Parameters:
NameParameterData TypeRequiredDescription
CurrencyIdformstringNo
CurrencyInfoformCurrencyNo
NameformstringYes
CultureformstringNo
TimeZoneformstringNo
ModifiedDateformDateTimeOffset?No
IdformstringYes
Currency Parameters:
NameParameterData TypeRequiredDescription
NameformstringYes
CurrencySignformstringYes
ActiveformboolYes
ModifiedDateformDateTimeOffset?No
IdformstringYes
IncentiveCriteria Parameters:
NameParameterData TypeRequiredDescription
IdformintNo
IncentiveIdformintNo
CriteriaTypeformCriteriaTypeNo
ValueformstringNo
InvertConditionformboolNo
CreatedDateformDateTimeOffsetNo

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 /superadmin/incentives HTTP/1.1 
Host: testapi.bokamera.se 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	Heading: String,
	StorageUrl: String,
	Body: String,
	SuccessButtonText: String,
	ActionId: 0,
	Frequency: OneTime,
	RecurrenceInterval: 0,
	InitialDelayInSeconds: 0,
	MaxDisplayCount: 0,
	ValidFrom: 0001-01-01T00:00:00.0000000+00:00,
	ValidTo: 0001-01-01T00:00:00.0000000+00:00,
	Active: False,
	Payload: String,
	CompanyIds: 
	[
		00000000-0000-0000-0000-000000000000
	],
	Criteria: 
	[
		{
			CriteriaType: LicenseAvailability,
			Value: String,
			InvertCondition: False
		}
	]
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	Frequency: OneTime,
	RecurrenceInterval: 0,
	CreatedDate: 0001-01-01T00:00:00.0000000+00:00,
	ModifiedDate: 0001-01-01T00:00:00.0000000+00:00,
	CompanyIds: 
	[
		00000000-0000-0000-0000-000000000000
	],
	Criteria: 
	[
		{
			Id: 0,
			IncentiveId: 0,
			CriteriaType: LicenseAvailability,
			Value: String,
			InvertCondition: False,
			CreatedDate: 0001-01-01T00:00:00.0000000+00:00
		}
	],
	ApplyToAllCompanies: False,
	Id: 0,
	Heading: String,
	StorageUrl: String,
	SuccessButtonText: String,
	ActionId: 0,
	InitialDelayInSeconds: 0,
	MaxDisplayCount: 0,
	ValidFrom: 0001-01-01T00:00:00.0000000+00:00,
	ValidTo: 0001-01-01T00:00:00.0000000+00:00,
	Action: 
	{
		Id: 0,
		ActionType: Upgrade,
		Page: String,
		Segment: String,
		Element: String,
		LicenseTypeId: 0,
		SuggestedLicenseToUpgrade: 
		{
			Id: 0,
			Name: String,
			Description: String,
			IsExtraLicenseOption: False,
			PeriodOfNoticeDays: 0,
			Items: 
			[
				{
					Id: 0,
					Name: String,
					AllowedItems: 0
				}
			],
			Prices: 
			[
				{
					LicenseTypeId: 0,
					CountryId: String,
					Price: 0,
					Country: 
					{
						CurrencyId: String,
						CurrencyInfo: 
						{
							Name: String,
							CurrencySign: String,
							Active: False,
							ModifiedDate: 0001-01-01T00:00:00.0000000+00:00,
							Id: String
						},
						Name: String,
						Culture: String,
						TimeZone: String,
						ModifiedDate: 0001-01-01T00:00:00.0000000+00:00,
						Id: String
					},
					LicensePlanId: 0
				}
			]
		}
	},
	Payload: String
}