exchange

Base system with REST service to issue digital coins, run by the payment service provider
Log | Files | Refs | Submodules | README | LICENSE

taler-exchange-helper-measure-update-from-context (3695B)


      1 #!/bin/bash
      2 #
      3 #  This file is part of TALER
      4 #  Copyright (C) 2024 Taler Systems SA
      5 #
      6 #  TALER is free software; you can redistribute it and/or modify it under the
      7 #  terms of the GNU General Public License as published by the Free Software
      8 #  Foundation; either version 3, or (at your option) any later version.
      9 #
     10 #  TALER is distributed in the hope that it will be useful, but WITHOUT ANY
     11 #  WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
     12 #  A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
     13 #
     14 #  You should have received a copy of the GNU General Public License along with
     15 #  TALER; see the file COPYING.  If not, If not, see <http://www.gnu.org/license>
     16 #
     17 
     18 # Hard error reporting on.
     19 set -eu
     20 
     21 
     22 
     23 # Exit, with error message (hard failure)
     24 function exit_fail() {
     25     echo " FAIL: " "$@" >&2
     26     EXIT_STATUS=1
     27     exit "$EXIT_STATUS"
     28 }
     29 
     30 CONF="$HOME/.config/taler-exchange.conf"
     31 VERBOSE=0
     32 
     33 while getopts 'ac:hirvV' OPTION;
     34 do
     35     case "$OPTION" in
     36         a)
     37             # No attributes are required.
     38             exit 0
     39             ;;
     40         c)
     41             # shellcheck disable=SC2034
     42             CONF="$OPTARG"
     43             ;;
     44         h)
     45             echo "This is a KYC measure program that updates the current rules of an account based on values given in the context."
     46             echo 'Supported options:'
     47             echo '  -a           -- show required attributes'
     48             # shellcheck disable=SC2016
     49             echo '  -c $CONF     -- set configuration'
     50             echo '  -h           -- print this help'
     51             echo '  -i           -- show required inputs'
     52             echo '  -r           -- show required context'
     53             echo '  -v           -- show version'
     54             echo '  -V           -- be verbose'
     55             exit 0
     56             ;;
     57         i)
     58             # Need context and current_rules.
     59             echo "context"
     60             echo "current_rules"
     61             exit 0
     62             ;;
     63         r)
     64             # Need new_rules, custom_measures, expiration time and successor measure.
     65             echo "new_rules"
     66             echo "custom_measures"
     67             echo "expiration_time"
     68             echo "successor_measure"
     69             exit 0
     70             ;;
     71         v)
     72             echo "$0 v0.0.0"
     73             exit 0
     74             ;;
     75         V)
     76             VERBOSE=1
     77             ;;
     78         ?)
     79         exit_fail "Unrecognized command line option"
     80         ;;
     81     esac
     82 done
     83 
     84 if [ 1 = "$VERBOSE" ]
     85 then
     86     echo "Running $0" 1>&2
     87 fi
     88 
     89 # See https://docs.taler.net/taler-kyc-manual.html#tsref-type-AmlProgramInput
     90 # for the full JSON with possible inputs.
     91 
     92 # First, extract inputs we need
     93 INPUTS=$(jq '{"context":.context,"current_rules":.current_rules}')
     94 
     95 # Get context values.
     96 EXPIRATION_TIME=$(echo "$INPUTS" | jq '.context.expiration_time // .current_rules.expiration_time // null')
     97 SUCCESSOR_MEASURE=$(echo "$INPUTS" | jq '.context.successor_measure // .current_rules.successor_measure // null')
     98 CUSTOM_MEASURES=$(echo "$INPUTS" | jq '.context.custom_measures // null')
     99 NEW_RULES=$(echo "$INPUTS" | jq '.context.new_rules // null')
    100 
    101 # Finally, output the new rules.
    102 # See https://docs.taler.net/taler-kyc-manual.html#tsref-type-AmlOutcome
    103 # for the required output format.
    104 
    105 echo "$INPUTS" \
    106     | jq \
    107           --argjson et "$EXPIRATION_TIME" \
    108           --argjson sm "$SUCCESSOR_MEASURE" \
    109           --argjson cm "$CUSTOM_MEASURES" \
    110           --argjson nr "$NEW_RULES" \
    111           '.current_rules+{"new_rules":(.current_rules.new_rules+{"expiration_time":$et,"successor_measure":$sm,"rules":(.current_rules.new_rules.rules+$nr),"custom_measures":({}+.current_rules.custom_measures+$cm)})}|del(..|nulls)'
    112 
    113 exit 0