index.js 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. // 云函数入口文件
  2. const cloud = require('wx-server-sdk')
  3. cloud.init()
  4. const db = cloud.database()
  5. const _ = db.command
  6. // 云函数入口函数
  7. exports.main = async (event, context) => {
  8. const {
  9. OPENID
  10. } = cloud.getWXContext()
  11. if (event.msg_id) {
  12. const questions = await db.collection('question')
  13. .aggregate()
  14. .match({
  15. msg_id: event.msg_id,
  16. answer: _.neq('')
  17. })
  18. .sort({
  19. rank: -1
  20. })
  21. .skip(event.page_token)
  22. .limit(event.page_size)
  23. .end()
  24. return {
  25. list: questions.list,
  26. next_page_token: event.page_token + questions.list.length,
  27. status: 'OK'
  28. }
  29. } else if (event.pub_id) {
  30. const questions = await db.collection('question')
  31. .aggregate()
  32. .lookup({
  33. from: 'message',
  34. localField: 'msg_id',
  35. foreignField: '_id',
  36. as: 'message'
  37. })
  38. .unwind('$message')
  39. .match({
  40. 'message.pub_id': event.pub_id
  41. })
  42. .sort({
  43. question_time: -1
  44. })
  45. .skip(event.page_token)
  46. .limit(event.page_size)
  47. .end()
  48. return {
  49. list: questions.list,
  50. next_page_token: event.page_token + questions.list.length,
  51. status: 'OK'
  52. }
  53. } else {
  54. const questions = await db.collection('question')
  55. .aggregate()
  56. .match({
  57. user_id: OPENID
  58. })
  59. .sort({
  60. question_time: -1
  61. })
  62. .skip(event.page_token)
  63. .limit(event.page_size)
  64. .lookup({
  65. from: 'message',
  66. localField: 'msg_id',
  67. foreignField: '_id',
  68. as: 'message'
  69. })
  70. .unwind('$message')
  71. .end()
  72. return {
  73. list: questions.list,
  74. next_page_token: event.page_token + questions.list.length,
  75. status: 'OK'
  76. }
  77. }
  78. }