migrations_v1.sql 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  1. CREATE TABLE "chain" (
  2. "chain_id" SERIAL PRIMARY KEY,
  3. "chain_name" TEXT NOT NULL
  4. );
  5. CREATE TABLE "company" (
  6. "company_id" SERIAL PRIMARY KEY,
  7. "company_name" TEXT NOT NULL,
  8. "company_flag" TEXT NOT NULL,
  9. "company_cnpj" TEXT NOT NULL
  10. );
  11. CREATE TABLE "role" (
  12. "role_id" SERIAL PRIMARY KEY,
  13. "company_id" INTEGER NOT NULL,
  14. "role_name" TEXT NOT NULL,
  15. "role_permission" JSONB NOT NULL,
  16. "role_flag" TEXT NOT NULL,
  17. CHECK (jsonb_typeof("role_permission") = 'object'),
  18. FOREIGN KEY ("company_id") REFERENCES "company" ("company_id")
  19. );
  20. CREATE TABLE "status" (
  21. "status_id" SERIAL PRIMARY KEY,
  22. "status_status" TEXT NOT NULL
  23. );
  24. CREATE TABLE "user" (
  25. "user_id" SERIAL PRIMARY KEY,
  26. "user_name" TEXT NOT NULL,
  27. "user_email" TEXT NOT NULL UNIQUE,
  28. "user_password" TEXT NOT NULL,
  29. "user_phone" TEXT NOT NULL,
  30. "user_address" TEXT NOT NULL,
  31. "user_city" TEXT NOT NULL,
  32. "user_state" TEXT NOT NULL,
  33. "user_zip" TEXT NOT NULL,
  34. "user_country" TEXT NOT NULL,
  35. "user_kyc" INTEGER NOT NULL,
  36. "user_birthdate" INTEGER NOT NULL,
  37. "user_cpf" TEXT NOT NULL,
  38. "company_id" INTEGER NOT NULL,
  39. "role_id" INTEGER NOT NULL,
  40. "user_flag" TEXT NOT NULL,
  41. FOREIGN KEY ("company_id") REFERENCES "company" ("company_id"),
  42. FOREIGN KEY ("role_id") REFERENCES "role" ("role_id")
  43. );
  44. CREATE TABLE payment (
  45. "payment_id" SERIAL PRIMARY KEY,
  46. "payment_external_id" TEXT NOT NULL,
  47. "status_id" INTEGER NOT NULL,
  48. "user_id" INTEGER NOT NULL,
  49. "payment_ts" INTEGER NOT NULL,
  50. "payment_e2e" TEXT NOT NULL,
  51. "payment_flag" TEXT NOT NULL,
  52. FOREIGN KEY ("status_id") REFERENCES "status" ("status_id"),
  53. FOREIGN KEY ("user_id") REFERENCES "user" ("user_id")
  54. );
  55. CREATE TABLE "cpr" (
  56. "cpr_id" SERIAL PRIMARY KEY,
  57. "cpr_type_code" TEXT NOT NULL,
  58. "cpr_otc_register_account_code" TEXT NOT NULL,
  59. "cpr_otc_payment_agent_account_code" TEXT NOT NULL,
  60. "cpr_otc_custodian_account_code" TEXT NOT NULL,
  61. "cpr_internal_control_number" TEXT NOT NULL,
  62. "cpr_electronic_emission_indicator" TEXT NOT NULL,
  63. "cpr_isin_code" TEXT NOT NULL,
  64. "cpr_issue_date" TEXT NOT NULL,
  65. "cpr_maturity_date" TEXT NOT NULL,
  66. "cpr_issue_quantity" TEXT NOT NULL,
  67. "cpr_issue_value" TEXT NOT NULL,
  68. "cpr_issue_financial_value" TEXT NOT NULL,
  69. "cpr_unit_value" TEXT NOT NULL,
  70. "cpr_reference_date" TEXT NOT NULL,
  71. "cpr_profitability_start_date" TEXT NOT NULL,
  72. "cpr_automatic_expiration_indicator" TEXT NOT NULL,
  73. "cpr_collateral_type_code" TEXT NOT NULL,
  74. "cpr_collateral_type_name" TEXT NOT NULL,
  75. "cpr_constitution_process_indicator" TEXT NOT NULL,
  76. "cpr_otc_bondsman_account_code" TEXT NOT NULL,
  77. "cpr_product_name" TEXT NOT NULL,
  78. "cpr_product_class_name" TEXT NOT NULL,
  79. "cpr_product_harvest" TEXT NOT NULL,
  80. "cpr_product_description" TEXT NOT NULL,
  81. "cpr_product_quantity" TEXT NOT NULL,
  82. "cpr_measure_unit_name" TEXT NOT NULL,
  83. "cpr_packaging_way_name" TEXT NOT NULL,
  84. "cpr_product_status_code" TEXT NOT NULL,
  85. "cpr_production_type_code" TEXT NOT NULL,
  86. "cpr_issuer_name" TEXT NOT NULL,
  87. "cpr_collaterals_document_number" TEXT NOT NULL,
  88. "cpr_issuers_person_type_acronym" TEXT NOT NULL,
  89. "cpr_issuers_state_acronym" TEXT NOT NULL,
  90. "cpr_issuers_city_name" TEXT NOT NULL,
  91. "cpr_issuers_ibge_code" TEXT NOT NULL,
  92. "cpr_issuer_legal_nature_code" TEXT NOT NULL,
  93. "cpr_otc_favored_account_code" TEXT NOT NULL,
  94. "cpr_issuers_document_number" TEXT NOT NULL,
  95. "cpr_deposit_person_type_acronym" TEXT NOT NULL,
  96. "cpr_self_number" TEXT NOT NULL,
  97. "cpr_settlement_modality_type_code" TEXT NOT NULL,
  98. "cpr_otc_settlement_bank_account_code" TEXT NOT NULL,
  99. "cpr_deposit_quantity" TEXT NOT NULL,
  100. "cpr_deposit_unit_price_value" TEXT NOT NULL,
  101. "cpr_payment_method_code" TEXT NOT NULL,
  102. "cpr_index_code" TEXT NOT NULL,
  103. "cpr_index_short_name" TEXT NOT NULL,
  104. "cpr_vcp_indicator_type_code" TEXT NOT NULL,
  105. "cpr_indexador_percentage_value" TEXT NOT NULL,
  106. "cpr_interest_rate_spread_percentage" TEXT NOT NULL,
  107. "cpr_interest_rate_criteria_type_code" TEXT NOT NULL,
  108. "cpr_interest_payment_date" TEXT NOT NULL,
  109. "cpr_interest_payment_value" TEXT NOT NULL,
  110. "cpr_interest_payment_frequency_code" TEXT NOT NULL,
  111. "cpr_interest_months_quantity" TEXT NOT NULL,
  112. "cpr_interestPaymentFlow_time_unit_type_code" TEXT NOT NULL,
  113. "cpr_interestPaymentFlow_deadline_type_code" TEXT NOT NULL,
  114. "cpr_payment_start_date" TEXT NOT NULL,
  115. "cpr_amortization_type_code" TEXT NOT NULL,
  116. "cpr_amortization_months_quantity" TEXT NOT NULL,
  117. "cpr_amortizationPaymentFlow_time_unit_type_code" TEXT NOT NULL,
  118. "cpr_amortizationPaymentFlow_deadline_type_code" TEXT NOT NULL,
  119. "cpr_amortization_start_date" TEXT NOT NULL,
  120. "cpr_scr_type_code" TEXT NOT NULL,
  121. "cpr_scr_customer_detail" TEXT NOT NULL,
  122. "cpr_scr_person_type_acronym" TEXT NOT NULL,
  123. "cpr_deposit_document_number" TEXT NOT NULL,
  124. "cpr_contract_code" TEXT NOT NULL,
  125. "cpr_operation_modality_type_code" TEXT NOT NULL,
  126. "cpr_bacen_reference_code" TEXT NOT NULL,
  127. "cpr_finality_code" TEXT NOT NULL,
  128. "cpr_ipoc_code" TEXT NOT NULL,
  129. "cpr_calculation_type_code" TEXT NOT NULL,
  130. "cpr_initial_exchange_value" TEXT NOT NULL,
  131. "cpr_fixing_type_code" TEXT NOT NULL,
  132. "cpr_data_source_type_code" TEXT NOT NULL,
  133. "cpr_adjustment_frequency_type_code" TEXT NOT NULL,
  134. "cpr_adjustment_pro_rata_type_code" TEXT NOT NULL,
  135. "cpr_adjustment_type_code" TEXT NOT NULL,
  136. "cpr_creditor_name" TEXT NOT NULL,
  137. "cpr_scr_document_number" TEXT NOT NULL,
  138. "cpr_creditor_document_number" TEXT NOT NULL,
  139. "cpr_ballast_type_code" TEXT NOT NULL,
  140. "cpr_lot_number" TEXT NOT NULL,
  141. "cpr_ballast_quantity" TEXT NOT NULL,
  142. "cpr_currency_code" TEXT NOT NULL,
  143. "cpr_transaction_identification" TEXT NOT NULL,
  144. "cpr_additional_text" TEXT NOT NULL,
  145. "cpr_number" TEXT NOT NULL,
  146. "cpr_contract_number" TEXT NOT NULL,
  147. "cpr_event_type_code" TEXT NOT NULL,
  148. "cpr_event_original_date" TEXT NOT NULL,
  149. "cpr_unit_price_value" TEXT NOT NULL,
  150. "cpr_interest_unit_price_value" TEXT NOT NULL,
  151. "cpr_residual_value" TEXT NOT NULL,
  152. "cpr_amortization_percentage" TEXT NOT NULL,
  153. "cpr_event_quantity" TEXT NOT NULL,
  154. "cpr_production_place_name" TEXT NOT NULL,
  155. "cpr_property_registration_number" TEXT NOT NULL,
  156. "cpr_notary_name" TEXT NOT NULL,
  157. "cpr_total_production_area_in_hectares_number" TEXT NOT NULL,
  158. "cpr_total_area_in_hectares_number" TEXT NOT NULL,
  159. "cpr_car_code" TEXT NOT NULL,
  160. "cpr_latitude_code" TEXT NOT NULL,
  161. "cpr_longitude_code" TEXT NOT NULL,
  162. "cpr_zip_code" TEXT NOT NULL,
  163. "cpr_green_cpr_indicator" TEXT NOT NULL,
  164. "cpr_green_cpr_certificate_name" TEXT NOT NULL,
  165. "cpr_green_cpr_certificate_cnpj_number" TEXT NOT NULL,
  166. "cpr_green_cpr_georeferencing_description" TEXT NOT NULL,
  167. "cpr_green_cpr_declaration_indicator" TEXT NOT NULL,
  168. "cpr_document_deadline_days_number" TEXT NOT NULL,
  169. "cpr_place_name" TEXT NOT NULL,
  170. "cpr_deliveryPlace_state_acronym" TEXT NOT NULL,
  171. "cpr_deliveryPlace_city_name" TEXT NOT NULL,
  172. "cpr_deliveryPlace_ibge_code" TEXT NOT NULL,
  173. "cpr_guarantee_limit_type_code" TEXT NOT NULL,
  174. "cpr_mother_code" TEXT NOT NULL,
  175. "cpr_children_codes" TEXT NOT NULL, -- text array
  176. "status_id" INTEGER NOT NULL,
  177. "payment_id" INTEGER NOT NULL,
  178. FOREIGN KEY ("status_id") REFERENCES "status" ("status_id"),
  179. FOREIGN KEY ("payment_id") REFERENCES "payment" ("payment_id")
  180. );
  181. CREATE TABLE "commodities" (
  182. "commodities_id" SERIAL PRIMARY KEY,
  183. "commodities_name" TEXT NOT NULL,
  184. "commodities_flag" TEXT NOT NULL
  185. );
  186. CREATE TABLE "wallet" (
  187. "wallet_id" SERIAL PRIMARY KEY,
  188. "company_id" INTEGER NOT NULL,
  189. "wallet_public_key" TEXT NOT NULL,
  190. "wallet_address" TEXT NOT NULL,
  191. "wallet_private_key" TEXT NOT NULL,
  192. "wallet_flag" TEXT NOT NULL,
  193. "chain_id" INTEGER NOT NULL,
  194. FOREIGN KEY ("company_id") REFERENCES "company" ("company_id"),
  195. FOREIGN KEY ("chain_id") REFERENCES "chain" ("chain_id")
  196. );
  197. CREATE TABLE "currency" (
  198. "currency_id" SERIAL PRIMARY KEY,
  199. "currency_external_id" TEXT NOT NULL,
  200. "currency_name" TEXT NOT NULL,
  201. "currency_digits" INTEGER NOT NULL,
  202. "chain_id" INTEGER NOT NULL,
  203. "currency_flag" TEXT NOT NULL,
  204. FOREIGN KEY ("chain_id") REFERENCES "chain" ("chain_id")
  205. );
  206. CREATE TABLE "token" (
  207. "token_id" SERIAL PRIMARY KEY,
  208. "token_external_id" TEXT NOT NULL,
  209. "token_commodities_amount" INTEGER NOT NULL,
  210. "token_commodities_value" REAL NOT NULL,
  211. "token_uf" TEXT NOT NULL,
  212. "token_city" TEXT NOT NULL,
  213. "token_content" TEXT NOT NULL, -- financial instrument
  214. "token_flag" TEXT NOT NULL,
  215. "wallet_id" INTEGER NOT NULL,
  216. "chain_id" INTEGER NOT NULL,
  217. "commodities_id" INTEGER NOT NULL,
  218. "cpr_id" INTEGER NOT NULL,
  219. "user_id" INTEGER NOT NULL,
  220. FOREIGN KEY ("wallet_id") REFERENCES "wallet" ("wallet_id"),
  221. FOREIGN KEY ("chain_id") REFERENCES "chain" ("chain_id"),
  222. FOREIGN KEY ("commodities_id") REFERENCES "commodities" ("commodities_id"),
  223. FOREIGN KEY ("cpr_id") REFERENCES "cpr" ("cpr_id"),
  224. FOREIGN KEY ("user_id") REFERENCES "user" ("user_id")
  225. );
  226. CREATE TABLE "tx_coin" (
  227. "tx_coin_id" TEXT PRIMARY KEY,
  228. "tx_coin_value" TEXT NOT NULL,
  229. "tx_coin_flag" TEXT NOT NULL,
  230. "tx_coin_ts" INTEGER NOT NULL,
  231. "tx_coin_from_address" TEXT NOT NULL,
  232. "tx_coin_to_address" TEXT NOT NULL,
  233. "currency_id" INTEGER NOT NULL,
  234. "chain_id" INTEGER NOT NULL,
  235. FOREIGN KEY ("currency_id") REFERENCES "currency" ("currency_id"),
  236. FOREIGN KEY ("chain_id") REFERENCES "chain" ("chain_id")
  237. );
  238. CREATE TABLE "tx_token" (
  239. "tx_token_id" TEXT PRIMARY KEY,
  240. "tx_token_flag" TEXT NOT NULL,
  241. "tx_token_ts" INTEGER NOT NULL,
  242. "tx_token_from_address" TEXT NOT NULL,
  243. "tx_token_to_address" TEXT NOT NULL,
  244. "token_id" INTEGER NOT NULL,
  245. "chain_id" INTEGER NOT NULL,
  246. FOREIGN KEY ("token_id") REFERENCES "token" ("token_id"),
  247. FOREIGN KEY ("chain_id") REFERENCES "chain" ("chain_id")
  248. );
  249. CREATE TABLE "orderbook" (
  250. "orderbook_id" SERIAL PRIMARY KEY,
  251. "orderbook_flag" TEXT NOT NULL,
  252. "orderbook_ts" INTEGER NOT NULL,
  253. "orderbook_is_token" BOOLEAN NOT NULL, -- true = venda, false = compra
  254. "orderbook_amount" TEXT NOT NULL,
  255. "status_id" INTEGER NOT NULL,
  256. "user_id" INTEGER NOT NULL,
  257. "wallet_id" INTEGER NOT NULL,
  258. "token_id" INTEGER,
  259. "currency_id" INTEGER,
  260. "chain_id" INTEGER NOT NULL,
  261. FOREIGN KEY ("status_id") REFERENCES "status" ("status_id"),
  262. FOREIGN KEY ("user_id") REFERENCES "user" ("user_id"),
  263. FOREIGN KEY ("wallet_id") REFERENCES "wallet" ("wallet_id"),
  264. FOREIGN KEY ("token_id") REFERENCES "token" ("token_id"),
  265. FOREIGN KEY ("currency_id") REFERENCES "currency" ("currency_id"),
  266. FOREIGN KEY ("chain_id") REFERENCES "chain" ("chain_id")
  267. );