add contract_sig field
This commit is contained in:
parent
914a77b5a7
commit
df8ff01f29
@ -30,7 +30,7 @@ LANGUAGE plpgsql
|
|||||||
AS $$
|
AS $$
|
||||||
BEGIN
|
BEGIN
|
||||||
|
|
||||||
IF shard_suffix IS NOT NULL THEN
|
IF shard_suffix IS NOT NULL THEN
|
||||||
table_name=table_name || '_' || shard_suffix;
|
table_name=table_name || '_' || shard_suffix;
|
||||||
main_table_partition_str = '';
|
main_table_partition_str = '';
|
||||||
END IF;
|
END IF;
|
||||||
@ -41,7 +41,7 @@ BEGIN
|
|||||||
main_table_partition_str
|
main_table_partition_str
|
||||||
);
|
);
|
||||||
|
|
||||||
END
|
END
|
||||||
$$;
|
$$;
|
||||||
|
|
||||||
----------------------- wire_targets ---------------------------
|
----------------------- wire_targets ---------------------------
|
||||||
@ -165,7 +165,7 @@ BEGIN
|
|||||||
',wire_reference INT8 NOT NULL'
|
',wire_reference INT8 NOT NULL'
|
||||||
',credit_val INT8 NOT NULL'
|
',credit_val INT8 NOT NULL'
|
||||||
',credit_frac INT4 NOT NULL'
|
',credit_frac INT4 NOT NULL'
|
||||||
',wire_source_h_payto BYTEA CHECK (LENGTH(wire_source_h_payto)=32)'
|
',wire_source_h_payto BYTEA CHECK (LENGTH(wire_source_h_payto)=32)'
|
||||||
',exchange_account_section TEXT NOT NULL'
|
',exchange_account_section TEXT NOT NULL'
|
||||||
',execution_date INT8 NOT NULL'
|
',execution_date INT8 NOT NULL'
|
||||||
') %s ;'
|
') %s ;'
|
||||||
@ -175,7 +175,7 @@ BEGIN
|
|||||||
);
|
);
|
||||||
|
|
||||||
table_name = concat_ws('_', table_name, shard_suffix);
|
table_name = concat_ws('_', table_name, shard_suffix);
|
||||||
|
|
||||||
EXECUTE FORMAT (
|
EXECUTE FORMAT (
|
||||||
'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_reserve_in_serial_id_index '
|
'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_reserve_in_serial_id_index '
|
||||||
'ON ' || table_name || ' '
|
'ON ' || table_name || ' '
|
||||||
@ -504,7 +504,7 @@ BEGIN
|
|||||||
);
|
);
|
||||||
|
|
||||||
table_name = concat_ws('_', table_name, shard_suffix);
|
table_name = concat_ws('_', table_name, shard_suffix);
|
||||||
|
|
||||||
EXECUTE FORMAT (
|
EXECUTE FORMAT (
|
||||||
'CREATE INDEX IF NOT EXISTS ' || table_name || '_coins_by_melt_serial_id_index '
|
'CREATE INDEX IF NOT EXISTS ' || table_name || '_coins_by_melt_serial_id_index '
|
||||||
'ON ' || table_name || ' '
|
'ON ' || table_name || ' '
|
||||||
@ -618,7 +618,7 @@ BEGIN
|
|||||||
|
|
||||||
EXECUTE FORMAT (
|
EXECUTE FORMAT (
|
||||||
'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_coin_pub_index '
|
'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_coin_pub_index '
|
||||||
'ON ' || table_name || ' '
|
'ON ' || table_name || ' '
|
||||||
'(coin_pub);'
|
'(coin_pub);'
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -928,7 +928,7 @@ BEGIN
|
|||||||
);
|
);
|
||||||
|
|
||||||
table_name = concat_ws('_', table_name, shard_suffix);
|
table_name = concat_ws('_', table_name, shard_suffix);
|
||||||
|
|
||||||
EXECUTE FORMAT (
|
EXECUTE FORMAT (
|
||||||
'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_coin_pub_index '
|
'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_coin_pub_index '
|
||||||
'ON ' || table_name || ' '
|
'ON ' || table_name || ' '
|
||||||
@ -1014,7 +1014,7 @@ BEGIN
|
|||||||
);
|
);
|
||||||
|
|
||||||
table_name = concat_ws('_', table_name, shard_suffix);
|
table_name = concat_ws('_', table_name, shard_suffix);
|
||||||
|
|
||||||
-- FIXME: any query using this index will be slow. Materialize index or change query?
|
-- FIXME: any query using this index will be slow. Materialize index or change query?
|
||||||
-- Also: which query uses this index?
|
-- Also: which query uses this index?
|
||||||
EXECUTE FORMAT (
|
EXECUTE FORMAT (
|
||||||
@ -1326,6 +1326,7 @@ BEGIN
|
|||||||
'(contract_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' --UNIQUE
|
'(contract_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' --UNIQUE
|
||||||
',purse_pub BYTEA NOT NULL CHECK (LENGTH(purse_pub)=32)'
|
',purse_pub BYTEA NOT NULL CHECK (LENGTH(purse_pub)=32)'
|
||||||
',pub_ckey BYTEA NOT NULL CHECK (LENGTH(pub_ckey)=32)'
|
',pub_ckey BYTEA NOT NULL CHECK (LENGTH(pub_ckey)=32)'
|
||||||
|
',contract_sig BYTEA NOT NULL CHECK (LENGTH(contract_sig)=64)'
|
||||||
',e_contract BYTEA NOT NULL'
|
',e_contract BYTEA NOT NULL'
|
||||||
',purse_expiration INT8 NOT NULL'
|
',purse_expiration INT8 NOT NULL'
|
||||||
',PRIMARY KEY (purse_pub)'
|
',PRIMARY KEY (purse_pub)'
|
||||||
@ -1744,28 +1745,28 @@ BEGIN
|
|||||||
|
|
||||||
ALTER TABLE IF EXISTS reserves_in
|
ALTER TABLE IF EXISTS reserves_in
|
||||||
DETACH PARTITION reserves_in_default;
|
DETACH PARTITION reserves_in_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS reserves_close
|
ALTER TABLE IF EXISTS reserves_close
|
||||||
DETACH PARTITION reserves_close_default;
|
DETACH PARTITION reserves_close_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS reserves_out
|
ALTER TABLE IF EXISTS reserves_out
|
||||||
DETACH PARTITION reserves_out_default;
|
DETACH PARTITION reserves_out_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS reserves_out_by_reserve
|
ALTER TABLE IF EXISTS reserves_out_by_reserve
|
||||||
DETACH PARTITION reserves_out_by_reserve_default;
|
DETACH PARTITION reserves_out_by_reserve_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS known_coins
|
ALTER TABLE IF EXISTS known_coins
|
||||||
DETACH PARTITION known_coins_default;
|
DETACH PARTITION known_coins_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS refresh_commitments
|
ALTER TABLE IF EXISTS refresh_commitments
|
||||||
DETACH PARTITION refresh_commitments_default;
|
DETACH PARTITION refresh_commitments_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS refresh_revealed_coins
|
ALTER TABLE IF EXISTS refresh_revealed_coins
|
||||||
DETACH PARTITION refresh_revealed_coins_default;
|
DETACH PARTITION refresh_revealed_coins_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS refresh_transfer_keys
|
ALTER TABLE IF EXISTS refresh_transfer_keys
|
||||||
DETACH PARTITION refresh_transfer_keys_default;
|
DETACH PARTITION refresh_transfer_keys_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS deposits
|
ALTER TABLE IF EXISTS deposits
|
||||||
DETACH PARTITION deposits_default;
|
DETACH PARTITION deposits_default;
|
||||||
|
|
||||||
@ -1778,28 +1779,28 @@ BEGIN
|
|||||||
|
|
||||||
ALTER TABLE IF EXISTS refunds
|
ALTER TABLE IF EXISTS refunds
|
||||||
DETACH PARTITION refunds_default;
|
DETACH PARTITION refunds_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS wire_out
|
ALTER TABLE IF EXISTS wire_out
|
||||||
DETACH PARTITION wire_out_default;
|
DETACH PARTITION wire_out_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS aggregation_transient
|
ALTER TABLE IF EXISTS aggregation_transient
|
||||||
DETACH PARTITION aggregation_transient_default;
|
DETACH PARTITION aggregation_transient_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS aggregation_tracking
|
ALTER TABLE IF EXISTS aggregation_tracking
|
||||||
DETACH PARTITION aggregation_tracking_default;
|
DETACH PARTITION aggregation_tracking_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS recoup
|
ALTER TABLE IF EXISTS recoup
|
||||||
DETACH PARTITION recoup_default;
|
DETACH PARTITION recoup_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS recoup_by_reserve
|
ALTER TABLE IF EXISTS recoup_by_reserve
|
||||||
DETACH PARTITION recoup_by_reserve_default;
|
DETACH PARTITION recoup_by_reserve_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS recoup_refresh
|
ALTER TABLE IF EXISTS recoup_refresh
|
||||||
DETACH PARTITION recoup_refresh_default;
|
DETACH PARTITION recoup_refresh_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS prewire
|
ALTER TABLE IF EXISTS prewire
|
||||||
DETACH PARTITION prewire_default;
|
DETACH PARTITION prewire_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS cs_nonce_locks
|
ALTER TABLE IF EXISTS cs_nonce_locks
|
||||||
DETACH partition cs_nonce_locks_default;
|
DETACH partition cs_nonce_locks_default;
|
||||||
|
|
||||||
@ -1808,7 +1809,7 @@ BEGIN
|
|||||||
|
|
||||||
ALTER TABLE IF EXISTS purse_merges
|
ALTER TABLE IF EXISTS purse_merges
|
||||||
DETACH partition purse_merges_default;
|
DETACH partition purse_merges_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS account_merges
|
ALTER TABLE IF EXISTS account_merges
|
||||||
DETACH partition account_merges_default;
|
DETACH partition account_merges_default;
|
||||||
|
|
||||||
@ -1817,10 +1818,10 @@ BEGIN
|
|||||||
|
|
||||||
ALTER TABLE IF EXISTS history_requests
|
ALTER TABLE IF EXISTS history_requests
|
||||||
DETACH partition history_requests_default;
|
DETACH partition history_requests_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS close_requests
|
ALTER TABLE IF EXISTS close_requests
|
||||||
DETACH partition close_requests_default;
|
DETACH partition close_requests_default;
|
||||||
|
|
||||||
ALTER TABLE IF EXISTS purse_deposits
|
ALTER TABLE IF EXISTS purse_deposits
|
||||||
DETACH partition purse_deposits_default;
|
DETACH partition purse_deposits_default;
|
||||||
|
|
||||||
@ -1951,7 +1952,7 @@ BEGIN
|
|||||||
,num_partitions
|
,num_partitions
|
||||||
);
|
);
|
||||||
PERFORM add_constraints_to_known_coins_partition(num_partitions::varchar);
|
PERFORM add_constraints_to_known_coins_partition(num_partitions::varchar);
|
||||||
|
|
||||||
PERFORM create_hash_partition(
|
PERFORM create_hash_partition(
|
||||||
'refresh_commitments'
|
'refresh_commitments'
|
||||||
,modulus
|
,modulus
|
||||||
@ -2096,7 +2097,7 @@ BEGIN
|
|||||||
,num_partitions
|
,num_partitions
|
||||||
);
|
);
|
||||||
PERFORM add_constraints_to_account_merges_partition(num_partitions::varchar);
|
PERFORM add_constraints_to_account_merges_partition(num_partitions::varchar);
|
||||||
|
|
||||||
PERFORM create_hash_partition(
|
PERFORM create_hash_partition(
|
||||||
'contracts'
|
'contracts'
|
||||||
,modulus
|
,modulus
|
||||||
@ -2136,7 +2137,7 @@ BEGIN
|
|||||||
,num_partitions
|
,num_partitions
|
||||||
);
|
);
|
||||||
PERFORM add_constraints_to_wads_in_partition(num_partitions::varchar);
|
PERFORM add_constraints_to_wads_in_partition(num_partitions::varchar);
|
||||||
|
|
||||||
PERFORM create_hash_partition(
|
PERFORM create_hash_partition(
|
||||||
'wad_in_entries'
|
'wad_in_entries'
|
||||||
,modulus
|
,modulus
|
||||||
@ -2308,7 +2309,7 @@ BEGIN
|
|||||||
|
|
||||||
END
|
END
|
||||||
$$;
|
$$;
|
||||||
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION create_shard_server(
|
CREATE OR REPLACE FUNCTION create_shard_server(
|
||||||
shard_suffix VARCHAR
|
shard_suffix VARCHAR
|
||||||
@ -2587,7 +2588,7 @@ BEGIN
|
|||||||
END
|
END
|
||||||
$$;
|
$$;
|
||||||
|
|
||||||
COMMENT ON FUNCTION create_shard_server
|
COMMENT ON FUNCTION create_shard_server
|
||||||
IS 'Create a shard server on the master
|
IS 'Create a shard server on the master
|
||||||
node with all foreign tables and user mappings';
|
node with all foreign tables and user mappings';
|
||||||
|
|
||||||
@ -2613,10 +2614,10 @@ BEGIN
|
|||||||
,'taler-exchange'
|
,'taler-exchange'
|
||||||
,'5432'
|
,'5432'
|
||||||
,'taler-exchange-httpd'
|
,'taler-exchange-httpd'
|
||||||
);
|
);
|
||||||
END LOOP;
|
END LOOP;
|
||||||
|
|
||||||
END
|
END
|
||||||
$$;
|
$$;
|
||||||
|
|
||||||
COMMIT;
|
COMMIT;
|
||||||
|
@ -183,7 +183,7 @@ BEGIN
|
|||||||
(NEW.reserve_uuid
|
(NEW.reserve_uuid
|
||||||
,NEW.h_blind_ev);
|
,NEW.h_blind_ev);
|
||||||
RETURN NEW;
|
RETURN NEW;
|
||||||
END $$;
|
END $$;
|
||||||
COMMENT ON FUNCTION reserves_out_by_reserve_insert_trigger()
|
COMMENT ON FUNCTION reserves_out_by_reserve_insert_trigger()
|
||||||
IS 'Replicate reserve_out inserts into reserve_out_by_reserve table.';
|
IS 'Replicate reserve_out inserts into reserve_out_by_reserve table.';
|
||||||
|
|
||||||
@ -200,7 +200,7 @@ BEGIN
|
|||||||
DELETE FROM reserves_out_by_reserve
|
DELETE FROM reserves_out_by_reserve
|
||||||
WHERE reserve_uuid = OLD.reserve_uuid;
|
WHERE reserve_uuid = OLD.reserve_uuid;
|
||||||
RETURN OLD;
|
RETURN OLD;
|
||||||
END $$;
|
END $$;
|
||||||
COMMENT ON FUNCTION reserves_out_by_reserve_delete_trigger()
|
COMMENT ON FUNCTION reserves_out_by_reserve_delete_trigger()
|
||||||
IS 'Replicate reserve_out deletions into reserve_out_by_reserve table.';
|
IS 'Replicate reserve_out deletions into reserve_out_by_reserve table.';
|
||||||
|
|
||||||
@ -457,7 +457,7 @@ COMMENT ON TABLE deposits_for_matching
|
|||||||
CREATE TABLE IF NOT EXISTS deposits_for_matching_default
|
CREATE TABLE IF NOT EXISTS deposits_for_matching_default
|
||||||
PARTITION OF deposits_for_matching
|
PARTITION OF deposits_for_matching
|
||||||
DEFAULT;
|
DEFAULT;
|
||||||
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION deposits_insert_trigger()
|
CREATE OR REPLACE FUNCTION deposits_insert_trigger()
|
||||||
RETURNS trigger
|
RETURNS trigger
|
||||||
@ -492,7 +492,7 @@ BEGIN
|
|||||||
,NEW.deposit_serial_id);
|
,NEW.deposit_serial_id);
|
||||||
END IF;
|
END IF;
|
||||||
RETURN NEW;
|
RETURN NEW;
|
||||||
END $$;
|
END $$;
|
||||||
COMMENT ON FUNCTION deposits_insert_trigger()
|
COMMENT ON FUNCTION deposits_insert_trigger()
|
||||||
IS 'Replicate deposit inserts into materialized indices.';
|
IS 'Replicate deposit inserts into materialized indices.';
|
||||||
|
|
||||||
@ -777,7 +777,7 @@ BEGIN
|
|||||||
(NEW.reserve_out_serial_id
|
(NEW.reserve_out_serial_id
|
||||||
,NEW.coin_pub);
|
,NEW.coin_pub);
|
||||||
RETURN NEW;
|
RETURN NEW;
|
||||||
END $$;
|
END $$;
|
||||||
COMMENT ON FUNCTION recoup_insert_trigger()
|
COMMENT ON FUNCTION recoup_insert_trigger()
|
||||||
IS 'Replicate recoup inserts into recoup_by_reserve table.';
|
IS 'Replicate recoup inserts into recoup_by_reserve table.';
|
||||||
|
|
||||||
@ -795,7 +795,7 @@ BEGIN
|
|||||||
WHERE reserve_out_serial_id = OLD.reserve_out_serial_id
|
WHERE reserve_out_serial_id = OLD.reserve_out_serial_id
|
||||||
AND coin_pub = OLD.coin_pub;
|
AND coin_pub = OLD.coin_pub;
|
||||||
RETURN OLD;
|
RETURN OLD;
|
||||||
END $$;
|
END $$;
|
||||||
COMMENT ON FUNCTION recoup_delete_trigger()
|
COMMENT ON FUNCTION recoup_delete_trigger()
|
||||||
IS 'Replicate recoup deletions into recoup_by_reserve table.';
|
IS 'Replicate recoup deletions into recoup_by_reserve table.';
|
||||||
|
|
||||||
@ -1068,6 +1068,8 @@ COMMENT ON TABLE contracts
|
|||||||
IS 'encrypted contracts associated with purses';
|
IS 'encrypted contracts associated with purses';
|
||||||
COMMENT ON COLUMN contracts.purse_pub
|
COMMENT ON COLUMN contracts.purse_pub
|
||||||
IS 'public key of the purse that the contract is associated with';
|
IS 'public key of the purse that the contract is associated with';
|
||||||
|
COMMENT ON COLUMN contracts.contract_sig
|
||||||
|
IS 'signature over the encrypted contract by the purse contract key';
|
||||||
COMMENT ON COLUMN contracts.pub_ckey
|
COMMENT ON COLUMN contracts.pub_ckey
|
||||||
IS 'Public ECDH key used to encrypt the contract, to be used with the purse private key for decryption';
|
IS 'Public ECDH key used to encrypt the contract, to be used with the purse private key for decryption';
|
||||||
COMMENT ON COLUMN contracts.e_contract
|
COMMENT ON COLUMN contracts.e_contract
|
||||||
|
Loading…
Reference in New Issue
Block a user