whatsapp.api 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504
  1. import "../base.api"
  2. import "./agent.api"
  3. import "./label_relationship.api"
  4. type (
  5. // The data of whatsapp information | Whatsapp信息
  6. WhatsappInfo {
  7. BaseIDInfo
  8. // Status 1: normal 2: ban | 状态 1 正常 2 禁用
  9. Status *uint8 `json:"status,optional"`
  10. WaId *string `json:"waId,optional"`
  11. WaName *string `json:"waName,optional"`
  12. // 回调地址
  13. Callback *string `json:"callback,optional"`
  14. // 模式ID
  15. AgentId *uint64 `json:"agentId,optional"`
  16. AgentInfo *AgentInfo `json:"agentInfo,optional"`
  17. // 微信账号
  18. Account *string `json:"account,optional"`
  19. // 手机号
  20. Phone *string `json:"phone,optional"`
  21. Cc *string `json:"cc,optional"`
  22. // 号码名称
  23. PhoneName *string `json:"phoneName,optional"`
  24. // 号码状态
  25. PhoneStatus *string `json:"phoneStatus,optional"`
  26. Tokens *uint64 `json:"tokens,optional"`
  27. // 号码发送频率号码发送频率
  28. Frequency *string `json:"frequency,optional"`
  29. // 号码质量
  30. Quality *string `json:"quality,optional"`
  31. // 号码校验状态
  32. VerifyStatus *string `json:"verifyStatus,optional"`
  33. // 机构 ID
  34. OrganizationId *uint64 `json:"organizationId,optional"`
  35. OrganizationName *string `json:"organizationName,optional"`
  36. // 大模型服务地址
  37. ApiBase *string `json:"apiBase,optional"`
  38. // 大模型服务密钥
  39. ApiKey *string `json:"apiKey,optional"`
  40. // 白名单
  41. AllowList []ContactInfo `json:"allowList,optional"`
  42. // 群白名单
  43. GroupAllowList []ContactInfo `json:"groupAllowList,optional"`
  44. // 黑名单
  45. BlockList []ContactInfo `json:"blockList,optional"`
  46. // 群黑名单
  47. GroupBlockList []ContactInfo `json:"groupBlockList,optional"`
  48. }
  49. WhatsappPhoneInfo {
  50. Avatar *string `json:"avatar,optional"`
  51. Industry *string `json:"industry,optional"`
  52. Intro *string `json:"intro,optional"`
  53. Address *string `json:"address,optional"`
  54. Email *string `json:"email,optional"`
  55. Website *string `json:"website,optional"`
  56. }
  57. // The response data of whatsapp list | Whatsapp列表数据
  58. WhatsappListResp {
  59. BaseDataInfo
  60. // Whatsapp list data | Whatsapp列表数据
  61. Data WhatsappListInfo `json:"data"`
  62. }
  63. // Whatsapp list data | Whatsapp列表数据
  64. WhatsappListInfo {
  65. BaseListInfo
  66. // The API list data | Whatsapp列表数据
  67. Data []WhatsappInfo `json:"data"`
  68. }
  69. // Get whatsapp list request params | Whatsapp列表请求参数
  70. WhatsappListReq {
  71. PageInfo
  72. // 手机号
  73. Phone *string `json:"phone,optional"`
  74. // 号码名称
  75. PhoneName *string `json:"phoneName,optional"`
  76. WaId *string `json:"waId,optional"`
  77. OrganizationId *uint64 `json:"organizationId,optional"`
  78. }
  79. // Whatsapp information response | Whatsapp信息返回体
  80. WhatsappInfoResp {
  81. BaseDataInfo
  82. // Whatsapp information | Whatsapp数据
  83. Data WhatsappInfo `json:"data"`
  84. }
  85. AutomationReq {
  86. WaId *string `json:"waId,optional"`
  87. Phone *string `json:"phone,optional"`
  88. }
  89. AutomationResp {
  90. BaseDataInfo
  91. // Whatsapp list data | Whatsapp列表数据
  92. Data ConversationalAutomationInfo `json:"data"`
  93. }
  94. ConversationalAutomationInfo {
  95. Prompts []string `json:"prompts,optional"`
  96. Commands []Command `json:"commands,optional"`
  97. Phone string `json:"phone,optional"`
  98. EnableWelcomeMessage bool `json:"enableWelcomeMessage,optional"`
  99. }
  100. Command {
  101. CommandDescription string `json:"commandDescription,optional"`
  102. CommandName string `json:"commandName,optional"`
  103. }
  104. SetAutomationReq {
  105. EnableWelcomeMessage bool `json:"enableWelcomeMessage,optional"`
  106. Phone string `json:"phone,optional"`
  107. Commands []Command `json:"commands,optional"`
  108. Prompts []string `json:"prompts,optional"`
  109. WaId string `json:"waId,optional"`
  110. }
  111. sendCodeReq {
  112. Cc *string `json:"cc"`
  113. Phone *string `json:"phone"`
  114. WaId *string `json:"waId"`
  115. Method *string `json:"method"`
  116. Locale *string `json:"locale"`
  117. }
  118. submitCodeReq {
  119. Cc *string `json:"cc"`
  120. Phone *string `json:"phone"`
  121. WaId *string `json:"waId"`
  122. Code *string `json:"code"`
  123. }
  124. getQrcodeReq {
  125. Phone *string `json:"phone"`
  126. WaId *string `json:"waId"`
  127. }
  128. getQrcodeResp {
  129. BaseDataInfo
  130. Data []Qrcode `json:"data"`
  131. }
  132. Qrcode {
  133. Phone string `json:"phone,optional"`
  134. QrdlCode string `json:"qrdlCode,optional"`
  135. GenerateQrImage string `json:"generateQrImage,optional"`
  136. PrefilledMessage string `json:"prefilledMessage,optional"`
  137. DeepLinkUrl string `json:"deepLinkUrl,optional"`
  138. QrImageUrl string `json:"qrImageUrl,optional"`
  139. }
  140. createQrcodeReq {
  141. Phone string `json:"phone"`
  142. GenerateQrImage string `json:"generateQrImage"`
  143. PrefilledMessage string `json:"prefilledMessage"`
  144. WaId string `json:"waId"`
  145. }
  146. updateQrcodeReq {
  147. Phone string `json:"phone,optional"`
  148. GenerateQrImage string `json:"generateQrImage,optional"`
  149. PrefilledMessage string `json:"prefilledMessage,optional"`
  150. QrdlCode string `json:"qrdlCode,optional"`
  151. WaId string `json:"waId"`
  152. }
  153. removeQrcodeReq {
  154. Phone string `json:"phone,optional"`
  155. QrdlCode string `json:"qrdlCode,optional"`
  156. WaId string `json:"waId"`
  157. }
  158. getBusinessReq {
  159. Phone *string `json:"phone"`
  160. WaId *string `json:"waId"`
  161. }
  162. getBusinessResp {
  163. BaseDataInfo
  164. Data BusinessInfo `json:"data"`
  165. }
  166. BusinessInfo {
  167. Vertical string `json:"vertical,optional"`
  168. Description string `json:"description,optional"`
  169. Email string `json:"email,optional"`
  170. Address string `json:"address,optional"`
  171. ProfilePictureUrl string `json:"profilePictureUrl,optional"`
  172. Websites []string `json:"websites,optional"`
  173. About string `json:"about,optional"`
  174. }
  175. setBusinessReq {
  176. Phone *string `json:"phone"`
  177. WaId *string `json:"waId"`
  178. Vertical string `json:"vertical,optional"`
  179. Description string `json:"description,optional"`
  180. Email string `json:"email,optional"`
  181. Address string `json:"address,optional"`
  182. ProfilePictureUrl string `json:"profilePictureUrl,optional"`
  183. Websites []string `json:"websites,optional"`
  184. About string `json:"about,optional"`
  185. }
  186. registerReq {
  187. Phone *string `json:"phone"`
  188. WaId *string `json:"waId"`
  189. }
  190. deregisterReq {
  191. Phone *string `json:"phone"`
  192. WaId *string `json:"waId"`
  193. }
  194. UpdateAgentReq {
  195. Id uint64 `json:"id"`
  196. AgentId uint64 `json:"agentId"`
  197. }
  198. // 获取黑白名单列表返回体
  199. WhatsappAllowBlockListResp {
  200. BaseDataInfo
  201. // Wx information | Wx数据
  202. Data WhatsappAllowBlockListRespData `json:"data"`
  203. }
  204. // WhatsappAllowBlockListRespData
  205. WhatsappAllowBlockListRespData {
  206. // 白名单
  207. AllowList *string `json:"allowList,optional"`
  208. // 群白名单
  209. GroupAllowList *string `json:"groupAllowList,optional"`
  210. // 黑名单
  211. BlockList *string `json:"blockList,optional"`
  212. // 群黑名单
  213. GroupBlockList *string `json:"groupBlockList,optional"`
  214. }
  215. UpdateAllowAndBlockListReq {
  216. Id uint64 `json:"id"`
  217. // 白名单
  218. AllowList *string `json:"allowList,optional"`
  219. // 群白名单
  220. GroupAllowList *string `json:"groupAllowList,optional"`
  221. // 黑名单
  222. BlockList *string `json:"blockList,optional"`
  223. // 群黑名单
  224. GroupBlockList *string `json:"groupBlockList,optional"`
  225. }
  226. TemplateInfo {
  227. Category string `json:"category,optional"`
  228. TemplateCode string `json:"templateCode,optional"`
  229. Name string `json:"name,optional"`
  230. Language string `json:"language,optional"`
  231. TemplateType string `json:"templateType,optional"`
  232. AuditStatus string `json:"auditStatus,optional"`
  233. Components []TemplateComponent `json:"components,optional"`
  234. QualityScore string `json:"qualityScore,optional"`
  235. MessageSendTtlSeconds int `json:"messageSendTtlSeconds,optional"`
  236. Reason string `json:"reason,optional"`
  237. }
  238. TemplateSingleInfo {
  239. Category string `json:"category,optional"`
  240. TemplateCode string `json:"templateCode,optional"`
  241. Name string `json:"name,optional"`
  242. Language string `json:"language,optional"`
  243. TemplateType string `json:"templateType,optional"`
  244. AuditStatus string `json:"auditStatus,optional"`
  245. }
  246. TemplateComponent {
  247. Type string `json:"type,optional"`
  248. Url string `json:"url,optional"`
  249. Text string `json:"text,optional"`
  250. Caption string `json:"caption,optional"`
  251. FileName string `json:"fileName,optional"`
  252. Format string `json:"format,optional"`
  253. Buttons []TemplateButton `json:"buttons,optional"`
  254. ThumbUrl string `json:"thumbUrl,optional"`
  255. Duration int `json:"duration,optional"`
  256. FileType string `json:"fileType,optional"`
  257. Latitude string `json:"latitude,optional"`
  258. Longitude string `json:"longitude,optional"`
  259. LocationName string `json:"locationName,optional"`
  260. LocationAddress string `json:"locationAddress,optional"`
  261. AddSecretRecommendation bool `json:"addSecretRecommendation,optional"`
  262. CodeExpirationMinutes int `json:"codeExpirationMinutes,optional"`
  263. HasExpiration bool `json:"hasExpiration,optional"`
  264. OfferExpirationTimeMs string `json:"offerExpirationTimeMs,optional"`
  265. }
  266. TemplateButton {
  267. Type string `json:"type,optional"`
  268. Text string `json:"text,optional"`
  269. PhoneNumber string `json:"phoneNumber,optional"`
  270. Url string `json:"url,optional"`
  271. UrlType string `json:"urlType,optional"`
  272. SignatureHash string `json:"signatureHash,optional"`
  273. PackageName string `json:"packageName,optional"`
  274. AutofillText string `json:"autofillText,optional"`
  275. IsOptOut bool `json:"isOptOut,optional"`
  276. ExtendAttrs []TemplateExtendAttr `json:"extendAttrs,optional"`
  277. CouponCode string `json:"couponCode,optional"`
  278. FlowId string `json:"flowId,optional"`
  279. FlowAction string `json:"flowAction,optional"`
  280. NavigateScreen string `json:"navigateScreen,optional"`
  281. SupportedApps []TemplateSupportedApp `json:"supportedApps,optional"`
  282. }
  283. TemplateSupportedApp {
  284. SignatureHash string `json:"signatureHash,optional"`
  285. PackageName string `json:"packageName,optional"`
  286. }
  287. TemplateExtendAttr {
  288. NextTemplateCode string `json:"nextTemplateCode,optional"`
  289. NextTemplateName string `json:"nextTemplateName,optional"`
  290. NextLanguageCode string `json:"nextLanguageCode,optional"`
  291. Action string `json:"action,optional"`
  292. IntentCode string `json:"intentCode,optional"`
  293. }
  294. createTemplateReq {
  295. Category string `json:"category"`
  296. TemplateCode string `json:"templateCode"`
  297. Name string `json:"name"`
  298. Language string `json:"language"`
  299. TemplateType string `json:"templateType,optional"`
  300. AllowCategoryChange bool `json:"allowCategoryChange,optional"`
  301. MessageSendTtlSeconds int `json:"messageSendTtlSeconds,optional"`
  302. }
  303. listTemplateReq {
  304. Page int32 `json:"page"`
  305. pageSize int32 `json:"pageSize"`
  306. Name string `json:"name,optional"`
  307. Language string `json:"language,optional"`
  308. AuditStatus string `json:"auditStatus,optional"`
  309. TemplateType string `json:"templateType,optional"`
  310. Code string `json:"code,optional"`
  311. }
  312. listTemplateResp {
  313. Code int `json:"code"`
  314. Msg string `json:"msg"`
  315. Data []TemplateSingleInfo `json:"data,omitempty"`
  316. }
  317. removeTemplateReq {
  318. TemplateCode string `json:"templateCode,optional"`
  319. TemplateName string `json:"templateName,optional"`
  320. Language string `json:"language"`
  321. TemplateType string `json:"templateType,optional"`
  322. }
  323. editTemplateReq {
  324. Components []TemplateComponent `json:"components,optional"`
  325. Language string `json:"language,optional"`
  326. TemplateCode string `json:"templateCode,optional"`
  327. Category string `json:"category,optional"`
  328. TemplateType string `json:"templateType,optional"`
  329. MessageSendTtlSeconds int `json:"messageSendTtlSeconds,optional"`
  330. TemplateName string `json:"templateName,optional"`
  331. }
  332. getTemplateReq {
  333. TemplateCode string `json:"templateCode,optional"`
  334. Language string `json:"language"`
  335. TemplateType string `json:"templateType,optional"`
  336. TemplateName string `json:"templateName,optional"`
  337. }
  338. getTemplateResp {
  339. Code int `json:"code"`
  340. Msg string `json:"msg"`
  341. Data TemplateSingleInfo `json:"data,omitempty"`
  342. }
  343. )
  344. @server(
  345. jwt: Auth
  346. group: whatsapp
  347. middleware: Authority
  348. )
  349. service Wechat {
  350. // Create whatsapp information | 创建Whatsapp
  351. @handler createWhatsapp
  352. post /whatsapp/create (WhatsappInfo) returns (BaseMsgResp)
  353. // Update whatsapp information | 更新Whatsapp
  354. @handler updateWhatsapp
  355. post /whatsapp/update (WhatsappPhoneInfo) returns (BaseMsgResp)
  356. // Delete whatsapp information | 删除Whatsapp信息
  357. @handler deleteWhatsapp
  358. post /whatsapp/delete (IDsReq) returns (BaseMsgResp)
  359. // Get whatsapp list | 获取Whatsapp列表
  360. @handler getWhatsappList
  361. post /whatsapp/list (WhatsappListReq) returns (WhatsappListResp)
  362. // Get whatsapp by ID | 通过ID获取Whatsapp
  363. @handler getWhatsappById
  364. post /whatsapp (IDReq) returns (WhatsappInfoResp)
  365. // 发送验证码
  366. @handler sendWhatsappCode
  367. post /whatsapp/sendCode (sendCodeReq) returns (BaseMsgResp)
  368. // 提交验证信息
  369. @handler submitWhatsappCode
  370. post /whatsapp/submitCode (submitCodeReq) returns (BaseMsgResp)
  371. // 获取开场白
  372. @handler getAutomation
  373. post /whatsapp/getAutomation (AutomationReq) returns (AutomationResp)
  374. // 编辑开场白
  375. @handler setAutomation
  376. post /whatsapp/setAutomation (SetAutomationReq) returns (BaseMsgResp)
  377. // 获取二维码
  378. @handler getQrcode
  379. post /whatsapp/getQrcode (getQrcodeReq) returns (getQrcodeResp)
  380. // 创建二维码
  381. @handler createQrcode
  382. post /whatsapp/createQrcode (createQrcodeReq) returns (BaseMsgResp)
  383. // 删除二维码
  384. @handler removeQrcode
  385. post /whatsapp/removeQrcode (removeQrcodeReq) returns (BaseMsgResp)
  386. // 修改二维码
  387. @handler updateQrcode
  388. post /whatsapp/updateQrcode (updateQrcodeReq) returns (BaseMsgResp)
  389. // 获取商业信息
  390. @handler getBusinessInfo
  391. post /whatsapp/getBusinessInfo (getBusinessReq) returns (getBusinessResp)
  392. // 设置商业信息
  393. @handler setBusinessInfo
  394. post /whatsapp/setBusinessInfo (setBusinessReq) returns (BaseMsgResp)
  395. // 注册WhatsApp号码
  396. @handler registerPhoneNumber
  397. post /whatsapp/registerPhoneNumber (registerReq) returns (BaseMsgResp)
  398. // 取消注册WhatsApp号码
  399. @handler deregisterPhoneNumber
  400. post /whatsapp/deregisterPhoneNumber (deregisterReq) returns (BaseMsgResp)
  401. // Update whatsapp information | 更新Whatsapp
  402. @handler updateAgent
  403. post /whatsapp/updateAgent (UpdateAgentReq) returns (BaseMsgResp)
  404. // Get whatsapp allow and block list | 获取黑白名单列表
  405. @handler getAllowBlockList
  406. post /whatsapp/getAllowBlockList (IDReq) returns (WhatsappAllowBlockListResp)
  407. // Update whatsapp information | 更新黑白名单
  408. @handler updateAllowAndBlockList
  409. post /whatsapp/updateAllowAndBlockList (UpdateAllowAndBlockListReq) returns (BaseMsgResp)
  410. // 创建模板
  411. @handler createWhatsappTemplate
  412. post /whatsapp/createTemplate (createTemplateReq) returns (BaseDataInfo)
  413. // 创建模板
  414. @handler listWhatsappTemplate
  415. post /whatsapp/listTemplate (listTemplateReq) returns (listTemplateResp)
  416. // 删除模板
  417. @handler removeWhatsappTemplate
  418. post /whatsapp/removeTemplate (removeTemplateReq) returns (BaseDataInfo)
  419. // 编辑模板
  420. @handler editWhatsappTemplate
  421. post /whatsapp/editTemplate (editTemplateReq) returns (BaseDataInfo)
  422. // 模板详情
  423. @handler getWhatsappTemplate
  424. post /whatsapp/getTemplate (getTemplateReq) returns (getTemplateResp)
  425. }