Charge end user
(Created page with "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 SysU...")
 
No edit summary
Line 4: Line 4:


Add this method to SysUser in your model:
Add this method to SysUser in your model:
  Consume(amount:Double; message:String):String
  Consume(amount:Double; message:String; tag:string):String
Mark it with a tagged value: Eco.ExternalLateBound = Existence
Also add:
GetSecurityStamp():String   <- set this as IsQuery=true
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]]
What turnkey will do when you call this method is the following:
What turnkey will do when you call this method is the following:
Line 19: Line 21:
An example on how to charge a SysUser:
An example on how to charge a SysUser:
  self.ConsumeRes:=SysSingleton.oclSingleton.CurrentUser
  self.ConsumeRes:=SysSingleton.oclSingleton.CurrentUser
               .Consume(1.23,'You bought a magic strawberry')
               .Consume(1.23,'You bought a magic strawberry','optional tag for you')
This call will return a json that looks like this:
This call will return a json that looks like this:
  {"Guid":"guid of the SysConsumer in portal",
  {"Guid":"guid of the SysConsumer in portal",
Line 41: Line 43:


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.
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:
SysUserGuid:SysSingleton.oclsingleton.CurrentUser.Guid
SysUserSecurityStamp:SysSingleton.oclsingleton.CurrentUser.GetSecurityStamp
PayAmount (double)
PayButtonText
PayAmountReadOnly (bool)
ReturnFromPurchaseAction: vNewVar:=SysSingleton.oclsingleton.CurrentUser.Consume( 0 ,  'check' )

Revision as of 16:47, 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:

GetSecurityStamp():String    <- set this as IsQuery=true

Mark both methods with a tagged value: Eco.ExternalLateBound = Existence

2020-05-17 22h14 46.png

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:

SysUserGuid:SysSingleton.oclsingleton.CurrentUser.Guid

SysUserSecurityStamp:SysSingleton.oclsingleton.CurrentUser.GetSecurityStamp

PayAmount (double)

PayButtonText

PayAmountReadOnly (bool)

ReturnFromPurchaseAction: vNewVar:=SysSingleton.oclsingleton.CurrentUser.Consume( 0 ,  'check' )

This page was edited more than 11 months ago on 02/10/2024. What links here