Hans Karlsen (talk | contribs) No edit summary |
Hans Karlsen (talk | contribs) No edit summary |
||
Line 6: | Line 6: | ||
Consume(amount:Double; message:String; tag:string):String | Consume(amount:Double; message:String; tag:string):String | ||
Also add: | Also add: | ||
GetPurchaseUrl(amount:Double; amountreadonly:Boolean; tag:String):String <- set this as IsQuery=true | |||
Mark both methods with a tagged value: Eco.ExternalLateBound = Existence | Mark both methods with a tagged value: Eco.ExternalLateBound = Existence | ||
[[File:2020-05-17 22h14 46.png|none|thumb|506x506px]] | [[File:2020-05-17 22h14 46.png|none|thumb|506x506px]] | ||
Line 51: | Line 51: | ||
In a ViewModel ensure that you have the following ViewModelColumns: | In a ViewModel ensure that you have the following ViewModelColumns: | ||
PurchaseUrl:SysSingleton.oclsingleton.CurrentUser.GetPurchaseUrl(amount:Double; amountreadonly:Boolean; tag:String):String | |||
PayButtonText | PayButtonText | ||
ReturnFromPurchaseAction: vNewVar:=SysSingleton.oclsingleton.CurrentUser.Consume( 0 , 'check' ) | ReturnFromPurchaseAction: vNewVar:=SysSingleton.oclsingleton.CurrentUser.Consume( 0 , 'check' ) | ||
PortalConsumer: [Angular_Ext_Component=PortalConsumer] self->asset | PortalConsumer: [Angular_Ext_Component=PortalConsumer] self->asset |
Revision as of 17:30, 23 May 2020
If you run the standard authentication package you will have your end users as SysUser objects.
Your service might cost some money to consume and to help you to charge a SysUser an amount of money when he or she performs an action or wants to access a resource behind your paywall we have added some streamlined functionality to get you going in minutes.
Add this method to SysUser in your model:
Consume(amount:Double; message:String; tag:string):String
Also add:
GetPurchaseUrl(amount:Double; amountreadonly:Boolean; tag:String):String <- set this as IsQuery=true
Mark both methods with a tagged value: Eco.ExternalLateBound = Existence
What turnkey will do when you call this method is the following:
It will post this data to https://portal.mdriven.net/Consume that is a RestAllowed viewmodel in Portal. The rootobject is looked up as the TurnkeySite-object that exists in portal based on its guid. The guid your turnkey system finds in the TurnkeySettings.xml file that portal writes when you say SendSettings in portal.
The key in SendSettings is:
<PortalGuid>a guid from the TurnkeySite object in portal</PortalGuid>
The settings file also includes the SharedSecret that you define on the login tab in portal:
<SharedSecret>a password shared between your site and portal</SharedSecret>
Your turnkey system will sign an UTC timestamp with this shared secret and portal will decrypt and verify that it is your system that sent the Consume command and that it is not an old recorded Consume command.
An example on how to charge a SysUser:
self.ConsumeRes:=SysSingleton.oclSingleton.CurrentUser .Consume(1.23,'You bought a magic strawberry','optional tag for you')
This call will return a json that looks like this:
{"Guid":"guid of the SysConsumer in portal", "ChangeTime":"2020-05-17T19:31:02.69", "MCoinAccount_CurrentStanding":-2.46, "LastTransactionTriedAmount":1.23, "LastTransactionTriedMessage":"You bought a magic strawberry", "LastTransactionTriedStatus":"Success", "MCoinTransactions":[ {"Guid":"a58753b9-2fe2-4fff-87ce-15294086fd9a", "MCoinAmount":-1.23, "Description":"Test20:06:40","ExitStanding":-2.46 }, {"Guid":"5d51e13b-c5cb-4329-aa72-de669c0d7109", "ChangeTime":"2020-05-17T19:31:02.69", "MCoinAmount":-1.23, "Description":"Test21:31:01","ExitStanding":-1.23 } ]}
This json will contain the current transaction and the 5 earlier transactions for this SysUser - that now has become a SysConsumer in Portal. A SysConsumer has an account with MCoins/Euros that the consumer can top up.
You are free to handle the returned Json with Tajson Merge to build up a replica of the account information stored in portal - but you do not have to.
Topping up Consumer Account
To bring up a Purchase UI that allows your SysUser to top up the Account with Euros go like this:
Install the PortalConsumer component in EXT_Components
In a ViewModel ensure that you have the following ViewModelColumns:
PurchaseUrl:SysSingleton.oclsingleton.CurrentUser.GetPurchaseUrl(amount:Double; amountreadonly:Boolean; tag:String):String
PayButtonText
ReturnFromPurchaseAction: vNewVar:=SysSingleton.oclsingleton.CurrentUser.Consume( 0 , 'check' )
PortalConsumer: [Angular_Ext_Component=PortalConsumer] self->asset