mirror of
https://github.com/juspay/hyperswitch.git
synced 2025-10-28 20:23:43 +08:00
Co-authored-by: harsh_sharma_juspay <harsh.sharma@juspay.in> Co-authored-by: Ivor Dsouza <ivor.dsouza@juspay.in> Co-authored-by: Chethan Rao <70657455+Chethan-rao@users.noreply.github.com> Co-authored-by: nain-F49FF806 <126972030+nain-F49FF806@users.noreply.github.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: hyperswitch-bot[bot] <148525504+hyperswitch-bot[bot]@users.noreply.github.com> Co-authored-by: akshay.s <akshay.s@juspay.in> Co-authored-by: Gnanasundari24 <118818938+Gnanasundari24@users.noreply.github.com>
173 lines
5.6 KiB
SQL
173 lines
5.6 KiB
SQL
CREATE TABLE hyperswitch.refund_queue on cluster '{cluster}' (
|
|
`internal_reference_id` String,
|
|
`refund_id` String,
|
|
`payment_id` String,
|
|
`merchant_id` String,
|
|
`connector_transaction_id` String,
|
|
`connector` LowCardinality(Nullable(String)),
|
|
`connector_refund_id` Nullable(String),
|
|
`external_reference_id` Nullable(String),
|
|
`refund_type` LowCardinality(String),
|
|
`total_amount` Nullable(UInt32),
|
|
`currency` LowCardinality(String),
|
|
`refund_amount` Nullable(UInt32),
|
|
`refund_status` LowCardinality(String),
|
|
`sent_to_gateway` Bool,
|
|
`refund_error_message` Nullable(String),
|
|
`refund_arn` Nullable(String),
|
|
`attempt_id` String,
|
|
`description` Nullable(String),
|
|
`refund_reason` Nullable(String),
|
|
`refund_error_code` Nullable(String),
|
|
`created_at` DateTime,
|
|
`modified_at` DateTime,
|
|
`sign_flag` Int8
|
|
) ENGINE = Kafka SETTINGS kafka_broker_list = 'kafka0:29092',
|
|
kafka_topic_list = 'hyperswitch-refund-events',
|
|
kafka_group_name = 'hyper-c1',
|
|
kafka_format = 'JSONEachRow',
|
|
kafka_handle_error_mode = 'stream';
|
|
|
|
CREATE TABLE hyperswitch.refund_dist on cluster '{cluster}' (
|
|
`internal_reference_id` String,
|
|
`refund_id` String,
|
|
`payment_id` String,
|
|
`merchant_id` String,
|
|
`connector_transaction_id` String,
|
|
`connector` LowCardinality(Nullable(String)),
|
|
`connector_refund_id` Nullable(String),
|
|
`external_reference_id` Nullable(String),
|
|
`refund_type` LowCardinality(String),
|
|
`total_amount` Nullable(UInt32),
|
|
`currency` LowCardinality(String),
|
|
`refund_amount` Nullable(UInt32),
|
|
`refund_status` LowCardinality(String),
|
|
`sent_to_gateway` Bool,
|
|
`refund_error_message` Nullable(String),
|
|
`refund_arn` Nullable(String),
|
|
`attempt_id` String,
|
|
`description` Nullable(String),
|
|
`refund_reason` Nullable(String),
|
|
`refund_error_code` Nullable(String),
|
|
`created_at` DateTime DEFAULT now() CODEC(T64, LZ4),
|
|
`modified_at` DateTime DEFAULT now() CODEC(T64, LZ4),
|
|
`inserted_at` DateTime DEFAULT now() CODEC(T64, LZ4),
|
|
`sign_flag` Int8
|
|
) ENGINE = Distributed('{cluster}', 'hyperswitch', 'refund_clustered', cityHash64(refund_id));
|
|
|
|
|
|
|
|
CREATE TABLE hyperswitch.refund_clustered on cluster '{cluster}' (
|
|
`internal_reference_id` String,
|
|
`refund_id` String,
|
|
`payment_id` String,
|
|
`merchant_id` String,
|
|
`connector_transaction_id` String,
|
|
`connector` LowCardinality(Nullable(String)),
|
|
`connector_refund_id` Nullable(String),
|
|
`external_reference_id` Nullable(String),
|
|
`refund_type` LowCardinality(String),
|
|
`total_amount` Nullable(UInt32),
|
|
`currency` LowCardinality(String),
|
|
`refund_amount` Nullable(UInt32),
|
|
`refund_status` LowCardinality(String),
|
|
`sent_to_gateway` Bool,
|
|
`refund_error_message` Nullable(String),
|
|
`refund_arn` Nullable(String),
|
|
`attempt_id` String,
|
|
`description` Nullable(String),
|
|
`refund_reason` Nullable(String),
|
|
`refund_error_code` Nullable(String),
|
|
`created_at` DateTime DEFAULT now() CODEC(T64, LZ4),
|
|
`modified_at` DateTime DEFAULT now() CODEC(T64, LZ4),
|
|
`inserted_at` DateTime DEFAULT now() CODEC(T64, LZ4),
|
|
`sign_flag` Int8,
|
|
INDEX connectorIndex connector TYPE bloom_filter GRANULARITY 1,
|
|
INDEX refundTypeIndex refund_type TYPE bloom_filter GRANULARITY 1,
|
|
INDEX currencyIndex currency TYPE bloom_filter GRANULARITY 1,
|
|
INDEX statusIndex refund_status TYPE bloom_filter GRANULARITY 1
|
|
) ENGINE = ReplicatedCollapsingMergeTree(
|
|
'/clickhouse/{installation}/{cluster}/tables/{shard}/hyperswitch/refund_clustered',
|
|
'{replica}',
|
|
sign_flag
|
|
)
|
|
PARTITION BY toStartOfDay(created_at)
|
|
ORDER BY
|
|
(created_at, merchant_id, refund_id)
|
|
TTL created_at + toIntervalMonth(6)
|
|
;
|
|
|
|
CREATE MATERIALIZED VIEW hyperswitch.kafka_parse_refund on cluster '{cluster}' TO hyperswitch.refund_dist (
|
|
`internal_reference_id` String,
|
|
`refund_id` String,
|
|
`payment_id` String,
|
|
`merchant_id` String,
|
|
`connector_transaction_id` String,
|
|
`connector` LowCardinality(Nullable(String)),
|
|
`connector_refund_id` Nullable(String),
|
|
`external_reference_id` Nullable(String),
|
|
`refund_type` LowCardinality(String),
|
|
`total_amount` Nullable(UInt32),
|
|
`currency` LowCardinality(String),
|
|
`refund_amount` Nullable(UInt32),
|
|
`refund_status` LowCardinality(String),
|
|
`sent_to_gateway` Bool,
|
|
`refund_error_message` Nullable(String),
|
|
`refund_arn` Nullable(String),
|
|
`attempt_id` String,
|
|
`description` Nullable(String),
|
|
`refund_reason` Nullable(String),
|
|
`refund_error_code` Nullable(String),
|
|
`created_at` DateTime64(3),
|
|
`modified_at` DateTime64(3),
|
|
`inserted_at` DateTime64(3),
|
|
`sign_flag` Int8
|
|
) AS
|
|
SELECT
|
|
internal_reference_id,
|
|
refund_id,
|
|
payment_id,
|
|
merchant_id,
|
|
connector_transaction_id,
|
|
connector,
|
|
connector_refund_id,
|
|
external_reference_id,
|
|
refund_type,
|
|
total_amount,
|
|
currency,
|
|
refund_amount,
|
|
refund_status,
|
|
sent_to_gateway,
|
|
refund_error_message,
|
|
refund_arn,
|
|
attempt_id,
|
|
description,
|
|
refund_reason,
|
|
refund_error_code,
|
|
created_at,
|
|
modified_at,
|
|
now() as inserted_at,
|
|
sign_flag
|
|
FROM hyperswitch.refund_queue
|
|
WHERE length(_error) = 0;
|
|
|
|
CREATE MATERIALIZED VIEW hyperswitch.refund_parse_errors on cluster '{cluster}'
|
|
(
|
|
`topic` String,
|
|
`partition` Int64,
|
|
`offset` Int64,
|
|
`raw` String,
|
|
`error` String
|
|
)
|
|
ENGINE = MergeTree
|
|
ORDER BY (topic, partition, offset)
|
|
SETTINGS index_granularity = 8192 AS
|
|
SELECT
|
|
_topic AS topic,
|
|
_partition AS partition,
|
|
_offset AS offset,
|
|
_raw_message AS raw,
|
|
_error AS error
|
|
FROM hyperswitch.refund_queue
|
|
WHERE length(_error) > 0
|
|
; |