payOrder.js 1.6 KB

1234567891011121314151617181920212223242526272829303132
  1. 'use strict';
  2. const Schema = require('mongoose').Schema;
  3. const metaPlugin = require('naf-framework-mongoose-free/lib/model/meta-plugin');
  4. // 付款订单表
  5. const payOrder = {
  6. openid: { type: String, required: false, zh: '微信id' }, // 其实和user_id有些重复,但是这里一定要留痕,因为有可能发生更换绑定
  7. school_id: { type: String, required: false, zh: '学校id', ref: 'School', getProp: [ 'name' ] }, //
  8. user_id: { type: String, required: false, zh: '用户id' }, // 不是角色的数据id,是普通用户的那个id,因为付款需要确定openid,和你是什么角色没关系
  9. pay_for: { type: String, required: false, zh: '支付原因' }, // lesson:上课,写表名等...
  10. from_id: { type: String, required: false, zh: '关联id' }, // 支付原因的数据id.有就写,没有不写
  11. money: { type: Number, required: false, zh: '金额' }, //
  12. time: { type: String, required: false, zh: '时间' }, //
  13. order_no: { type: String, required: false, zh: '订单号' }, //
  14. desc: { type: String, required: false, zh: '支付说明' }, //
  15. status: { type: String, required: false, default: '0', zh: '支付状态' }, // 0:未支付;1:已支付;-1:支付失败-2:已退款
  16. };
  17. const schema = new Schema(payOrder, { toJSON: { virtuals: true } });
  18. schema.index({ id: 1 });
  19. schema.index({ 'meta.createdAt': 1 });
  20. schema.index({ openid: 1 });
  21. schema.index({ school_id: 1 });
  22. schema.index({ user_id: 1 });
  23. schema.index({ order_no: 1 });
  24. schema.index({ time: 1 });
  25. schema.index({ status: 1 });
  26. schema.plugin(metaPlugin);
  27. module.exports = app => {
  28. const { mongoose } = app;
  29. return mongoose.model('PayOrder', schema, 'payOrder');
  30. };