migrations_v1.sql 9.8 KB

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