common_fields.proto 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474
  1. // Copyright 2022 Google LLC
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. syntax = "proto3";
  15. package google.cloud.paymentgateway.issuerswitch.v1;
  16. import "google/api/field_behavior.proto";
  17. option csharp_namespace = "Google.Cloud.PaymentGateway.IssuerSwitch.V1";
  18. option go_package = "google.golang.org/genproto/googleapis/cloud/paymentgateway/issuerswitch/v1;issuerswitch";
  19. option java_multiple_files = true;
  20. option java_outer_classname = "CommonFieldsProto";
  21. option java_package = "com.google.cloud.paymentgateway.issuerswitch.v1";
  22. option php_namespace = "Google\\Cloud\\PaymentGateway\\IssuerSwitch\\V1";
  23. option ruby_package = "Google::Cloud::PaymentGateway::IssuerSwitch::V1";
  24. // A reference to uniquely identify an account according to India's UPI
  25. // standards.
  26. message AccountReference {
  27. // IFSC code of a bank's branch.
  28. string ifsc_code = 1;
  29. // Type of account. Examples include SAVINGS, CURRENT, etc.
  30. string account_type = 2;
  31. // Unique number for an account in a bank and branch.
  32. string account_number = 3;
  33. }
  34. // A participant in a payment settlement transaction processed by the issuer
  35. // switch. The participant could either be the payer or the payee in the
  36. // transaction.
  37. message SettlementParticipant {
  38. // The participant information.
  39. Participant participant = 1;
  40. // Unique identification of an account according to India's UPI standards.
  41. AccountReference account = 2;
  42. // Information about a merchant who is a participant in the payment. This
  43. // field will be specified only if the participant is a merchant.
  44. MerchantInfo merchant_info = 3;
  45. // Output only. The mobile number of the participant.
  46. string mobile = 4 [(google.api.field_behavior) = OUTPUT_ONLY];
  47. // Output only. The device id of the participant.
  48. string device_id = 5 [(google.api.field_behavior) = OUTPUT_ONLY];
  49. }
  50. // A participant in a transaction processed by the issuer switch.
  51. message Participant {
  52. // The type of the participant.
  53. enum Persona {
  54. // Unspecified persona.
  55. PERSONA_UNSPECIFIED = 0;
  56. // Participant is an entity.
  57. ENTITY = 1;
  58. // Participant is a person.
  59. PERSON = 2;
  60. }
  61. // The virtual payment address (VPA) of the participant.
  62. string virtual_payment_address = 1;
  63. // The persona of the participant.
  64. Persona persona = 2;
  65. // The name of the participant.
  66. string user = 3;
  67. }
  68. // A merchant entity participating in a payment settlement transaction.
  69. message MerchantInfo {
  70. // A unique identifier for the merchant.
  71. string id = 1;
  72. // The name of the merchant who is a party in the payment. Includes multiple
  73. // possible names for the merchant.
  74. MerchantName merchant = 2;
  75. // Additional information about the merchant.
  76. MerchantAdditionalInfo additional_info = 3;
  77. }
  78. // The name of a merchant who is a participant in a payment settlement
  79. // transaction. Includes multiple possible names for the merchant.
  80. message MerchantName {
  81. // The brand name of the merchant.
  82. string brand = 1;
  83. // The merchant's legal name.
  84. string legal = 2;
  85. // The franchise name under which the merchant operates.
  86. string franchise = 3;
  87. }
  88. // Additional merchant information specific to India's UPI requirements.
  89. message MerchantAdditionalInfo {
  90. // Indicates the merchant's type as a small or large merchant.
  91. enum Type {
  92. // Unspecified merchant type.
  93. TYPE_UNSPECIFIED = 0;
  94. // Large merchant.
  95. LARGE = 1;
  96. // Small merchant.
  97. SMALL = 2;
  98. }
  99. // Indicates whether the merchant is an online or offline merchant.
  100. enum Genre {
  101. // Unspecified merchant genre.
  102. GENRE_UNSPECIFIED = 0;
  103. // Offline merchant
  104. OFFLINE = 1;
  105. // Online merchant.
  106. ONLINE = 2;
  107. }
  108. // Indicates whether the merchant has been onboarded by a bank or an
  109. // aggregator.
  110. enum OnboardingType {
  111. // Unspecified merchant onboarding type.
  112. ONBOARDING_TYPE_UNSPECIFIED = 0;
  113. // Onboarded by aggreagator.
  114. AGGREGATOR = 1;
  115. // Onboarded by bank.
  116. BANK = 2;
  117. // Onboarded by the UPI network.
  118. NETWORK = 3;
  119. // Onboarded by the TPAP.
  120. TPAP = 4;
  121. }
  122. // Indicates the ownership type of the merchant.
  123. enum OwnershipType {
  124. // Unspecified merchant ownership type.
  125. OWNERSHIP_TYPE_UNSPECIFIED = 0;
  126. // Properietary ownership.
  127. PROPRIETARY = 1;
  128. // Partnership ownership.
  129. PARTNERSHIP = 2;
  130. // Public ownership.
  131. PUBLIC = 3;
  132. // Private ownership.
  133. PRIVATE = 4;
  134. // Other ownership model.
  135. OTHERS = 5;
  136. }
  137. // Merchant Category Code (MCC) as specified by UPI. This is a four-digit
  138. // number listed in ISO 18245 for retail financial services.
  139. string category_code = 1;
  140. // A unique identifier for the merchant store where the payment settlement
  141. // transaction occurred.
  142. string store_id = 2;
  143. // A unique identifier for the POS terminal in the store where the payment
  144. // settlement transaction occurred.
  145. string terminal_id = 3;
  146. // Indicates the type of merchant.
  147. Type type = 4;
  148. // Indicates the genre of the merchant.
  149. Genre genre = 5;
  150. // Indicates the merchant's onboarding type.
  151. OnboardingType onboarding_type = 6;
  152. // Indicates the merchant's owner type.
  153. OwnershipType ownership_type = 7;
  154. }
  155. // The API type for a transaction. Every transaction processed by the issuer
  156. // switch will be one of these API types.
  157. enum ApiType {
  158. // Unspecified API type.
  159. API_TYPE_UNSPECIFIED = 0;
  160. // Balance API. Maps to UPI's `BalEnq` API. This is a metadata
  161. // transaction API.
  162. BALANCE = 1;
  163. // Check transaction status API. Maps to UPI's `ChkTxn` API. This is a
  164. // metadata transaction API.
  165. CHECK_STATUS = 2;
  166. // Complaint API. Maps to UPI's `Complaint` API. This is a dispute and issue
  167. // resolution API.
  168. COMPLAINT = 3;
  169. // Heart beat API. Maps to UPI's `Hbt` API. This is a metadata transaction
  170. // API.
  171. HEART_BEAT = 4;
  172. // Initiate registration API. Maps to UPI's `Otp` API. This is a metadata
  173. // transaction API.
  174. INITIATE_REGISTRATION = 5;
  175. // List accounts API. Maps to UPI's `ListAccount` API. This is a metadata
  176. // transaction API.
  177. LIST_ACCOUNTS = 6;
  178. // Mandate API. Maps to UPI's `Mandate` API. This is a metadata transaction
  179. // API.
  180. MANDATE = 7;
  181. // Mandate confirmation API. Maps to UPI's `MandateConfirmation` API. This is
  182. // a metadata transaction API.
  183. MANDATE_CONFIRMATION = 8;
  184. // Payment settlement API. Maps to UPI's `Pay` API. This is a financial
  185. // transaction API.
  186. SETTLE_PAYMENT = 9;
  187. // Update credentials API. Maps to UPI's `SetCre` API. This is a metadata
  188. // transaction API.
  189. UPDATE_CREDENTIALS = 10;
  190. // Validate registration API. Maps to UPI's `RegMob` API. This is a metadata
  191. // transaction API.
  192. VALIDATE_REGISTRATION = 11;
  193. // Validate customer API. Maps to UPI's `ValCust` API. This is a validation
  194. // API.
  195. VALIDATE_CUSTOMER = 12;
  196. // Voucher API. Maps to UPI's `Voucher` API.
  197. VOUCHER = 13;
  198. // Voucher confirmation API. Maps to UPI's `VoucherConfirmation` API.
  199. VOUCHER_CONFIRMATION = 14;
  200. }
  201. // The type of a transaction. Every transaction processed by the issuer switch
  202. // will be one of these transaction types. Transaction types are associated with
  203. // a particular API type. This associated is documented with each value.
  204. enum TransactionType {
  205. // Unspecified transaction type.
  206. TRANSACTION_TYPE_UNSPECIFIED = 0;
  207. // Autoupdate transaction type. This is associated with the `CHECK_STATUS`
  208. // API type. Maps to UPI's `AUTOUPDATE` type.
  209. TRANSACTION_TYPE_AUTOUPDATE = 1;
  210. // Balance check transaction type. This is associated with the
  211. // `BALANCE_ENQUIRY` API type. Maps to UPI's `BalChk` type.
  212. TRANSACTION_TYPE_BALANCE_CHECK = 2;
  213. // Balance enquiry transaction type. This is associated with the
  214. // `BALANCE_ENQUIRY` API type. Maps to UPI's `BalEnq` type.
  215. TRANSACTION_TYPE_BALANCE_ENQUIRY = 3;
  216. // Check status transaction type. This is associated with the `COMPLAINT` API
  217. // type. Maps to UPI's `CHECKSTATUS` type.
  218. TRANSACTION_TYPE_CHECK_STATUS = 4;
  219. // Check transaction type. This is associated with the `CHECK_STATUS` API
  220. // type. Maps to UPI's `ChkTxn` type.
  221. TRANSACTION_TYPE_CHECK_TRANSACTION = 5;
  222. // Complaint transaction type. This is associated with the `COMPLAINT` API
  223. // type. Maps to UPI's `COMPLAINT` type.
  224. TRANSACTION_TYPE_COMPLAINT = 6;
  225. // Create transaction type. This is associated with the `MANDATE` API type.
  226. // Maps to UPI's `CREATE` type.
  227. TRANSACTION_TYPE_CREATE = 7;
  228. // Credit transaction type. This is associated with the `SETTLE_PAYMENT` API
  229. // type. Maps to UPI's `CREDIT` type.
  230. TRANSACTION_TYPE_CREDIT = 8;
  231. // Debit transaction type. This is associated with the `SETTLE_PAYMENT` API
  232. // type. Maps to UPI's `DEBIT` type.
  233. TRANSACTION_TYPE_DEBIT = 9;
  234. // Dispute transaction type. This is associated with the `COMPLAINT` API
  235. // type. Maps to UPI's `DISPUTE` type.
  236. TRANSACTION_TYPE_DISPUTE = 10;
  237. // Heart beat transaction type. This is associated with `HEART_BEAT` API type.
  238. // Maps to UPI's `Hbt` type.
  239. TRANSACTION_TYPE_HEART_BEAT = 11;
  240. // List accounts transaction type. This is associated with `LIST_ACCOUNTS` API
  241. // type. Maps to UPI's `ListAccount` type.
  242. TRANSACTION_TYPE_LIST_ACCOUNTS = 12;
  243. // Mandate notification transaction type. This is associated with the
  244. // `VALIDATE_CUSTOMER` API type. Maps to UPI's `MandateNotification` type.
  245. TRANSACTION_TYPE_MANDATE_NOTIFICATION = 13;
  246. // OTP transaction type. This is associated with the `INITIATE_REGISTRATION`
  247. // API type. Maps to UPI's `Otp` type.
  248. TRANSACTION_TYPE_OTP = 14;
  249. // Pause transaction type. This is associated with the `MANDATE` API type.
  250. // Maps to UPI's `PAUSE` type.
  251. TRANSACTION_TYPE_PAUSE = 15;
  252. // Redeem transaction type. This is associated with the `VOUCHER_CONFIRMATION`
  253. // API type. Maps to UPI's `REDEEM` type.
  254. TRANSACTION_TYPE_REDEEM = 16;
  255. // Refund transaction type. This is associated with the `COMPLAINT` API
  256. // type. Maps to UPI's `REFUND` type.
  257. TRANSACTION_TYPE_REFUND = 17;
  258. // Register mobile transaction type. This is associated with the
  259. // `VALIDATE_REGISTRATION` API type. Maps to UPI's `RegMob` type.
  260. TRANSACTION_TYPE_REGISTER_MOBILE = 18;
  261. // Reversal transaction type. This is associated with the `SETTLE_PAYMENT` and
  262. // `COMPLAINT` API types. Maps to UPI's `REVERSAL` type.
  263. TRANSACTION_TYPE_REVERSAL = 19;
  264. // Revoke transaction type. This is associated with the `MANDATE` API type.
  265. // Maps to UPI's `REVOKE` type.
  266. TRANSACTION_TYPE_REVOKE = 20;
  267. // Status update transaction type. This is associated with the `COMPLAINT` API
  268. // type. Maps to UPI's `STATUSUPDATE` type.
  269. TRANSACTION_TYPE_STATUS_UPDATE = 21;
  270. // Update transaction type. This is associated with the `MANDATE` API type.
  271. // Maps to UPI's `UNPAUSE` type.
  272. TRANSACTION_TYPE_UNPAUSE = 22;
  273. // Update transaction type. This is associated with the `MANDATE` API type.
  274. // Maps to UPI's `UPDATE` type.
  275. TRANSACTION_TYPE_UPDATE = 23;
  276. // Update credentials transaction type. This is associated with
  277. // `UPDATE_CREDENTIALS` API type. Maps to UPI's `SetCre` type.
  278. TRANSACTION_TYPE_UPDATE_CREDENTIALS = 24;
  279. // Validate customer transaction type. This is associated with
  280. // `VALIDATE_CUSTOMER` API type. Maps to UPI's `ValCust` type.
  281. TRANSACTION_TYPE_VALIDATE_CUSTOMER = 25;
  282. }
  283. // XmlApiType specifies the API type of the request or response as specified in
  284. // the XML payload.
  285. enum XmlApiType {
  286. // Unspecified API type.
  287. XML_API_TYPE_UNSPECIFIED = 0;
  288. // Balance enquiry request API type. Maps to UPI's `ReqBalEnq` API.
  289. REQ_BAL_ENQ = 1;
  290. // Check transaction request API type. Maps to UPI's `ReqChkTxn` API.
  291. REQ_CHK_TXN = 2;
  292. // Complaint request API type. Maps to UPI's `ReqComplaint` API.
  293. REQ_COMPLAINT = 3;
  294. // Heart beat request API type. Maps to UPI's `ReqHbt` API.
  295. REQ_HBT = 4;
  296. // List accounts request API type. Maps to UPI's `ReqListAccount` API.
  297. REQ_LIST_ACCOUNT = 5;
  298. // Mandate request API. Maps to UPI's `ReqMandate` API.
  299. REQ_MANDATE = 6;
  300. // Mandate confirmation request API type. Maps to UPI's
  301. // `ReqMandateConfirmation` API.
  302. REQ_MANDATE_CONFIRMATION = 7;
  303. // OTP request API. Maps to UPI's `ReqOtp` API.
  304. REQ_OTP = 8;
  305. // Payment settlement request API type. Maps to UPI's `ReqPay` API.
  306. REQ_PAY = 9;
  307. // Register mobile request API type. Maps to UPI's `ReqRegMob` API.
  308. REQ_REG_MOB = 10;
  309. // Update credentials request API type. Maps to UPI's `ReqSetCre` API.
  310. REQ_SET_CRE = 11;
  311. // Validate customer request API type. Maps to UPI's `ReqValCust`.
  312. REQ_VAL_CUST = 12;
  313. // Create voucher request API type. Maps to UPI's `ReqVoucher`.
  314. REQ_VOUCHER = 13;
  315. // Voucher confirmation request API type. Maps to UPI's
  316. // `ReqVoucherConfirmation` API.
  317. REQ_VOUCHER_CONFIRMATION = 14;
  318. // Transaction confirmation request API type. Maps to UPI's
  319. // `ReqTxnConfirmation` API.
  320. REQ_TXN_CONFIRMATION = 15;
  321. // Balance enquiry response API type. Maps to UPI's `RespBalEnq` API.
  322. RESP_BAL_ENQ = 16;
  323. // Check transaction response API type. Maps to UPI's `RespChkTxn` API.
  324. RESP_CHK_TXN = 17;
  325. // Complaint response API type. Maps to UPI's `RespComplaint` API.
  326. RESP_COMPLAINT = 18;
  327. // Heart beat response API type. Maps to UPI's `RespHbt` API.
  328. RESP_HBT = 19;
  329. // List accounts response API type. Maps to UPI's `RespListAccount` API.
  330. RESP_LIST_ACCOUNT = 20;
  331. // Mandate response API type. Maps to UPI's `RespMandate` API.
  332. RESP_MANDATE = 21;
  333. // Mandate confirmation response API type. Maps to UPI's
  334. // `RespMandateConfirmation` API.
  335. RESP_MANDATE_CONFIRMATION = 22;
  336. // OTP response API. Maps to UPI's `RespOtp` API.
  337. RESP_OTP = 23;
  338. // Payment settlement response API type. Maps to UPI's `RespPay` API.
  339. RESP_PAY = 24;
  340. // Register mobile response API type. Maps to UPI's `RespRegMob` API.
  341. RESP_REG_MOB = 25;
  342. // Update credentials response API type. Maps to UPI's `RespSetCre` API.
  343. RESP_SET_CRE = 26;
  344. // Validate customer response API type. Maps to UPI's `RespValCust`.
  345. RESP_VAL_CUST = 27;
  346. // Create voucher response API type. Maps to UPI's `RespVoucher`.
  347. RESP_VOUCHER = 28;
  348. // Voucher confirmation responseAPI type. Maps to UPI's
  349. // `RespVoucherConfirmation` API.
  350. RESP_VOUCHER_CONFIRMATION = 29;
  351. // Transaction confirmation response API type. Maps to UPI's
  352. // `RespTxnConfirmation` API.
  353. RESP_TXN_CONFIRMATION = 30;
  354. }