libeufin

Integration and sandbox testing for FinTech APIs and data formats
Log | Files | Refs | Submodules | README | LICENSE

libeufin-nexus-0003.sql (1535B)


      1 --
      2 -- This file is part of TALER
      3 -- Copyright (C) 2024 Taler Systems SA
      4 --
      5 -- TALER is free software; you can redistribute it and/or modify it under the
      6 -- terms of the GNU General Public License as published by the Free Software
      7 -- Foundation; either version 3, or (at your option) any later version.
      8 --
      9 -- TALER is distributed in the hope that it will be useful, but WITHOUT ANY
     10 -- WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
     11 -- A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
     12 --
     13 -- You should have received a copy of the GNU General Public License along with
     14 -- TALER; see the file COPYING.  If not, see <http://www.gnu.org/licenses/>
     15 
     16 BEGIN;
     17 
     18 SELECT _v.register_patch('libeufin-nexus-0003', NULL, NULL);
     19 
     20 SET search_path TO libeufin_nexus;
     21 
     22 CREATE TABLE talerable_outgoing_transactions
     23   ( outgoing_transaction_id INT8 UNIQUE NOT NULL REFERENCES outgoing_transactions(outgoing_transaction_id) ON DELETE CASCADE
     24    ,wtid BYTEA NOT NULL UNIQUE CHECK (LENGTH(wtid)=32)
     25    ,exchange_base_url TEXT NOT NULL
     26   );
     27 
     28 CREATE TABLE transfer_operations
     29   ( initiated_outgoing_transaction_id INT8 UNIQUE NOT NULL REFERENCES initiated_outgoing_transactions(initiated_outgoing_transaction_id) ON DELETE CASCADE
     30    ,request_uid BYTEA UNIQUE NOT NULL CHECK (LENGTH(request_uid)=64)
     31    ,wtid BYTEA UNIQUE NOT NULL CHECK (LENGTH(wtid)=32)
     32    ,exchange_base_url TEXT NOT NULL
     33   );
     34 COMMENT ON TABLE transfer_operations
     35   IS 'Operation table for idempotent wire gateway transfers.';
     36 COMMIT;