/DigiServices

DigiServices is a Cardano-based project that aims to be a trustworthy, reward-driven, platform for goods and service exchanges

Primary LanguageHaskellMIT LicenseMIT

DigiServices

DigiServices is a Cardano-based project that aims to be a trustworthy, reward-driven, platform for goods and service exchanges

Table of Contents

Tokenomics

Supply

Differently from traditional currencies, such as Bitcoin, Litecoin and Ethereum, DigiServices tokens (DSET) are not deflationary. This is important in order to incentivise cooperative and honest behaviour in the platform.

A fixed amount of DSET tokens is monthly minted and distributed according to a Credit Assesment System (CAS). Users receive tokens proportionally to their scores, obeying the following function:

-- The total amount of tokens that will be minted every month
totalAmt :: Int
totalAmt = 1000

-- Review is an integer between 0 and 100
calculateRewards :: [Review] -> [Int]
calculateRewards [] = []
calculateRewards (x:xs) = ((x `div` revSum) * totalAmt `div` 100) : calculateRewards xs
  where
    revSum :: Integer
    revSum = sum xs

Distribution

Need development

Utility

In order to ensure that dishonest parties are penalised, DigiServices makes it possible for service providers to lock an arbitrary amount of tokens inside their proposal in the marketplace and require that their client do the same. In this way, not only both know that each other is sufficiently honest to have this amount of tokens, but they can also use it as a pledge in case there is a conflict.

In this sense, DSET utility is to provide a good measure of honesty inside the platform and ensure parties are not violated, as well as, possibly in the future be used as a voting mechanism to ensure decentralisation in the platform.

Network

Because users receive rewards for being active, inviting new members and mantaining a good reputation, the network is benefited as a whole. Not only does DSET creates a viable way of classifying someone's honesty, but it also incentivises constant use of the platform and good services provion.

Alice and Bob example

Suppose Alice want’s to offer her services as a writer. In normal circunstances she could search for a publishing company and sign a contract with them. The problem, in this case, is that natural language contracts open doors for ambiguity and misinterpretation. Additionally, physical contracts do not fit the requirements of practicallaty and quickness.

Another approach, would be for Alice to access an online website focused on freelance jobs (e.g. Fiverr or Upwork). In this case, alongside with the ambiguity and flexibility problems (as these websites usually make use of pre-made natural language contracts), there could be the possibility of Alice not delivering the project or even of the client not paying the agreed amount.

To solve these issues, we propose DigiServices: a digital platform that, by making use of Cardano smart contracts, enables parties to offer their services in a trustfull manner avoiding misinterpratation or ambiguity and using a reputation system that penalizes dishonest parties and reward honest ones.

Simmilarly to the second example, with DigiServices Alice would be able to access a user-friendly web application and publish her service there. One of the key differences, though, would be that this service would not be stored inside a centralized database, but, rather, inside the Datum of a Plutus Validator called marketplace.

The Datum of the marketplace contains a list of Services. Service is a special data type that holds four values: A Title, a Description, a Price and a Signature symbol.

The first value (title) is the service Alice will provide (e.g. "Novel writer"). The second value (description) can contain a little bit of her background and should provide a nice explanation of what she will do (only for marketing reasons since it shoudn't affect the judge decision in case of a conflict). The third value (price) is the amount of DSET tokens the client should pay in order to receive the service.

The last value (signature) is a non-fungible token that is only valid if it contains a cryptographic signature resulted from the combination of the owner’s private key and the Accusation Contract validator hash.

Example

import Ledger

-- Defined explicitily for clarity
signAccusation :: Ledger.Crypto.PrivateKey -> Ledger.ValidatorHash -> Signature
signAccusation pk vh = Ledger.Crypto.sign vh pk

-- This will be stored in the Signature NFT metadata
data Sig = Sig { signatory          :: Ledger.PubKeyHash
               , accusationContract :: Ledger.ValidatorHash
               , signature          :: Signature
               } deriving (Eq, Show)

This means that the signature can be used to prove someone agreed with a determined contract.

In our example, Alice would first create an accusation contract. Let’s suppose she uses Charlie, Daniel and Emma public keys as the list of judges. Additionally, let’s say the inputs are “Was a book actually written and delivered?”, “Did it have more than 200 pages” and “Was the client collaborative, providing any information needed?”. Lastly, let’s say the logic written was the following:

type ClientTokens = Int
type ProviderTokens = Int
type JudgeTokens = Int

type TTDistribution = (ClientTokens, ProviderTokens, JudgeTokens)
type TotalAmount = Int

distributeTokens :: Bool  Bool  Bool -> TotalAmount  Distribution
distributeTokens inp1 inp2 inp3 totalAmt =
    | (not inp1 || not inp2) && inp3 = ((totalAmt - judgeAmt), 0, judgeAmt)
    | inp1 && inp2 && not inp3 = (0, (totalAmt - judgeAmt), judgeAmt)
    | otherwise = (0, 0, judgeAmt)
  where
    judgeAmt :: Int
    judgeAmt = totalAmt `div` 20

Bob could then, agreeing with the contract and seeing that Alice's judges are reliable and qualified, decide to actually request her services. For that he would need to provide his signature token and lock the same amount of trust tokens provided by Alice, as well as, the amount of DSET Alice set as her service price.

Supposing Alice is rebellious, though, and decide's to write a book with only 100 pages (contrary to the rules she herself defined), Bob could invoke an "Accuse" event inside the accusation contract, which would notify the first judge in the list (Charlie) and give him a hardcoded fixed deadline (e.g. 24h) to provide answers to the inputs defined by Alice ("Was a book actually...").

If he does, then the logic will be executed according to the inputs provided (e.g. (True, False, True)) and would distribute the tokens accordingly. Because of how the contract was defined, Alice would receive nothing, Bob 57 TT and Charlie 3 TT. It is possible, though, that Charlie does not respond within the deadline. In this case, the next judge in the list will be notified and the cycle repeat.

Of course, in our example Bob was the one to invoke the accusation, but nothing stops Alice to do the same in case Bob is not cooperative and does not follow the agreed rules. DigiServices, therefore proves to be a great way of making sure contracts are followed, eliminating ambiguity normally attached to natural language contracts and providing the ease of use so valued in our current world.

White Paper

Abstract

The growing need of goods and services exchange require a trusty social platform to act as escrow. Even though physical contracts appear to provide a solution, they are often misinterpreted because of their subjective language and they commonly lack the practicality needed in our digital word. We propose a platform that enables parties to create contracts stored in the Cardano blockchain and builds member trust based on token rewards calculated through an algorithm that collects statistics related to the service or good provided and returns the amount of tokens per hour that will be rewarded. Parties that refuse to follow the rules pre-defined in the contract will be penalized by losing tokens proportionally to the severity of their misbehavior.