DJ2QPTFUBHZJ66NTY3YBMQOOT3WA7YFB
[
"autonomous agent",
{
"init": "{
$nom_AA = 'FOP_Geto';
$versio = '0.01';
$geto = 'Geto_ee';
$id_geto = 'Tvx24iDhcQC15LjsOIAQDXSaLlOth7o1oroE1XzD8RM=';
//$_Registre = '5WVBJQHTEP54AEYUJGTQKWTXTXZSJQWA';
$_Registre = trigger.data._Registre; // * només x tests
$adr__ = trigger.initial_address;
$args = trigger.data;
$unitat = trigger.output[[ asset != base ]].asset;
// Retorna una dada del Registre
$__dada = $refdada =>
data_feed[[ oracles = $_Registre, feed_name = $refdada, ifnone = 0 ]];
// $_Portal = $__dada( '_Portal' );
$_Portal = trigger.address; // * només x tests
if ( $_Portal != trigger.address
AND $__dada( '_Accions' ) != trigger.address )
bounce( 'Accés interdit' );
$sentit = $args.sentit;
$total_entrades = $__dada( 'total_entrades_' || $geto ) otherwise 0;
$total_sortides = $__dada( 'total_sortides_' || $geto ) otherwise 0;
$provisio = $unitat == 'none';
$idgeto_registrada = $__dada( $geto || '_id' ) otherwise '';
if( $idgeto_registrada != $unitat AND ! $provisio )
bounce( 'Unitat desconeguda' );
$registre = {};
$dades = {};
if ( $sentit == 'entrada' ) {
$qt_entrada = trigger.output[[ asset = $unitat ]];
$nou_total_entrades = $total_entrades + $qt_entrada;
$ord_entrada_actual = $__dada( 'ordinal_entrada_' || $geto ) otherwise 0;
$ord_entrada = $ord_entrada_actual + 1;
$ref_entrada = 'entrada_' || $geto || '_' || $ord_entrada;
$dades[ $ref_entrada || '_data' ] = timestamp;
$dades[ $ref_entrada || '_qt' ] = $qt_entrada;
$dades[ $ref_entrada || '_emissora' ] = $args.emissora otherwise $adr__;
$dades[ 'total_entrades_' || $geto ] = $nou_total_entrades;
$dades[ 'ordinal_entrada_' || $geto ] = $ord_entrada;
}
if ( $sentit == 'sortida' ) {
$qt_sortida = $args.qt;
$rebedora = $args.rebedora;
$ord_sortida_actual = $__dada( 'ordinal_sortida_' || $geto ) otherwise 0;
$ord_sortida = $ord_sortida_actual + 1;
$ref_sortida = 'sortida_' || $ord_sortida;
$nou_total_sortides = $total_sortides - $qt_sortida;
$dades[ $ref_sortida || '_data' ] = timestamp;
$dades[ $ref_sortida || '_qt' ] = $qt_sortida;
$dades[ $ref_sortida || '_actuant' ] = $adr__;
$dades[ $ref_sortida || '_rebedora' ] = $rebedora;
$dades[ 'total_sortides_' || $geto ] = $nou_total_sortides;
$dades[ 'ordinal_sortida_' || $geto ] = $ord_sortida;
}
$registre.dades = $dades;
}",
"messages": [
{
"app": "data",
"payload": "{ $registre }"
},
{
"if": "{ ! $provisio }",
"app": "payment",
"payload": {
"asset": "base",
"outputs": [
{
"address": "{ $_Registre }",
"amount": "{ $__dada( 'Provisio' ) }"
}
]
}
},
{
"if": "{ $sentit == 'sortida' AND ! $provisio }",
"app": "payment",
"payload": {
"asset": "base",
"outputs": [
{
"address": "{ $rebedora }",
"amount": "{ $qt_sortida }"
}
]
}
},
{
"if": "{ ! $provisio }",
"app": "state",
"state": "{
if ( $sentit == 'entrada' ) {
response[ $ref_entrada ] =
$qt_entrada || ' ' || $geto || ' de ' || $adr__;
response[ 'Total entrades en ' || $geto ] = $nou_total_entrades;
}
if ( $sentit == 'sortida') {
response[ $ref_sortida ] =
$qt_sortida || ' ' || $geto || ' a ' || $rebedora;
response[ 'Total sortides en ' || $geto ] = $nou_total_sortides;
}
}"
}
]
}
]
Show transactions in assets:
No transactions found, it may be worth changing the filter
Unit ID
Date
From
Direction
To
Amount