如何在userSchema中将枚举设置为空默认值

时间:2018-08-03 04:59:28

标签: node.js mongodb express mongoose passport.js

我目前正在使用MongoDB作为数据库,ExpressJS和PassportJS的项目的注册表格上工作,但是,我试图使用户能够选择rol,然后像这样在数据库中注册用户登录后重定向到正确的页面。

const mongoose = require("mongoose");
const Schema = mongoose.Schema;

const userSchema = new Schema({
    name: String,
    username: String,
    password: String,
    role: {
        type: String,
        enum: ['COMPANY', 'IRONHACKER', 'ADMIN'],
        default: 'IRONHACKER',
    },
    session: String,
    last_login: {
        type: Date,
        default: ""
    }
}, {
    timestamps: {
        createdAt: "created_at",
        updatedAt: "updated_at"
    },
});

const User = mongoose.model("User", userSchema);
module.exports = User;

默认情况下,它有3个值,用户只能选择2:IRONHACKER和COMPANY。

当前,它的行为有所不同,因为我将“ IRONHACKER”设置为默认值,所以它始终是用户一旦注册便获得的值。

1 个答案:

答案 0 :(得分:0)

我找到了解决方案,实际上效果很好!

我将userSchema保持不变

const mongoose = require("mongoose");
const Schema = mongoose.Schema;

const userSchema = new Schema({
    name: String,
    username: String,
    password: String,
    role: {
        type: String,
        enum: ['COMPANY', 'IRONHACKER', 'ADMIN'],
        default: 'IRONHACKER',
    },
    session: String,
    last_login: {
        type: Date,
        default: ""
    }
}, {
    timestamps: {
        createdAt: "created_at",
        updatedAt: "updated_at"
    },
});

const User = mongoose.model("User", userSchema);
module.exports = User;

我修改的唯一一件事是注册表单配置:(注册仅具有测试目的,没有此功能)。

    <h2>Signup</h2>

<form action="/signup" method="POST" id="form-container">
  <label for="name">Full Name</label>
  <input id="name" type="name" name="name" placeholder="Provide your Name">
  <br>
  <br>
  <label for="username">Username</label>
  <input id="username" type="text" name="username" placeholder="Set Username">
  <br>
  <br>
  <label for="password">Password</label>
  <input id="password" type="password" name="password" placeholder="Set a password"> 
  <br>
  <br>
  <select name="role" id="role">
    <option value="" disabled="disabled" selected="selected">--Please choose an option--</option>
    <option value="IRONHACKER">Ironhacker</option>
    <option value="COMPANY">Employer</option>
    <option value="ADMIN">Administrator</option>
  </select>
  {{#if message}}
    <div class="error-message">{{ message }}</div>
  {{/if}}
  <br>
  <br>
  <button>Create account</button>

  <p class="account-message">
    Do you already have an account?
    <a href="/login">Login</a>
  </p>
</form>

因此,它现在可以检测到角色,并为用户正确分配角色和权限。