使用个人消息创建多个用户登录系统

时间:2016-01-25 14:01:34

标签: javascript theory user-management

我想创建一个包含私人消息的多用户登录系统。 我在JavaScript中创建了理论(仅用于概述理论和功能),我想知道我是否在正确的轨道上。 当然我稍后会用所有验证将它改为后端语言,这纯粹是为了素描。

// User database simulation
var users = [];

var defaultUser = {
    'rights': 1, /* 0 - 3: 0 is banned, 1 is default, 2 is moderator, 3 is admin */
  'activated': false,
  'createdAt': null,
  'updatedAt': null,
  'username': null,
  'userId': null,
  'email': null,
  'pass': null, /* will be encrypted */
  'profile': {
    'sex': null,
    'age': null,
    'avatar': null,
    'updatedAt': null,
  },
  'messages': {
    'inbox': [],
    'outbox': [],
    'trash': [],
    'drafts': []
  }
};

var defaultMessage = {
    'id': null, 
    'date': null,
    'from': null,
    'to': null,
    'message': null
};

var userManagement = {
    'register': function(username, email, pass){
        var user = $.extend({}, defaultUser);
        user.username = username;
        user.email = email;
        user.pass = pass;
        user.userId = username + '_' + Math.floor(Date.now() / 1000);
        // If everything is valid, register:
        // User database insert simulation
        users.push(user);
        console.log('Registered', user);
  },
    'login': function(username, pass) {
    // User database query simulation
    for(var i = 0, l = users.length; i < l; i++) {
        var user = users[i];
          if(user.username === username) {
        if(user.pass === pass) {
            console.log('Logged in', user);
        } else {
            console.log('Pass incorrect');
        }
      } else {
        console.log('User not found');
      }
    }
  },
  'forgotUsername': function(email) {
    // User database query simulation
    for(var i = 0, l = users.length; i < l; i++) {
        var user = users[i];
      if(user.email === email) {
        console.log('username ['+ user.username +'] send to ' + user.email);
      } else {
        console.log('User not found');
      }
    }   
  },
  'forgotPass': function(username) {
    // User database query simulation
    for(var i = 0, l = users.length; i < l; i++) {
        var user = users[i];
      if(user.username === username) {
        console.log('pass from user ['+ user.username +'] send to ' + user.email);
      } else {
        console.log('User not found');
      }
    }   
  },
  'getUserById': function(userId){
    var key;
    for(var i = 0, l = users.length; i < l; i++) {
        var user = users[i];
      if(user.userId === userId) {
        return user;    
      }
    }
    return null;
  },
  'getUserByUsername': function(username){
    for(var i = 0, l = users.length; i < l; i++) {
        var user = users[i];
      if(user.username === username) {
        return user;    
      }
    }
    return null;
  }
  /* TODO: updateProfile, activate */
}

var message = {
    'send': function(fromUserId, toUserId, msg){
    var sender = userManagement.getUserById(fromUserId);
    var receiver = userManagement.getUserById(toUserId);
    var message = $.extend({}, defaultMessage);
    message.id = fromUserId + '_' + Math.floor(Date.now() / 1000);
    message.from = sender.username;
    message.fromUserId = fromUserId;
    message.to = receiver.username
    message.toUserId = toUserId;
    message.message = msg;
    message.date = new Date();
    sender.messages.outbox.push(message);
    receiver.messages.inbox.push(message);
  }
  /* TODO: delete, move etc. */
}

userManagement.register('barry', 'barry@test.nl', 'bcf2ibc');
userManagement.register('john', 'john@test.nl', 'bahjscb');

userManagement.login('test', 'blabla'); // fail
userManagement.login('barry', 'blabla'); // fail
userManagement.login('barry', 'bcf2ibc'); // success
userManagement.login('John', 'bahjscb'); // success
//userManagement.forgotPass('barry');

var barry = userManagement.getUserByUsername('barry');
var john = userManagement.getUserByUsername('John');

message.send(barry.userId, john.userId, 'My test message.');
message.send(barry.userId, john.userId, 'You received my previous message?');
message.send(john.userId, barry.userId, 'Yes I did received them.');

console.log(users);

JS小提琴:https://jsfiddle.net/vmjs1n9n/12/

他们为每个用户设置私信,这是一件好事吗?我也很感激对其他人的建议!

1 个答案:

答案 0 :(得分:0)

这是一个开始,如果你的主要目的是促进私人消息,那么是的,每个用户的私人消息是一件好事。

我的第一个想法,你知道你正在重新发明轮子吗?如果我将此作为业务要求,我将与现有的消息服务或协议集成,而不是必须处理此类数据的长期管理。即使是身份验证,在这一天,您应该尝试实施某种开放式身份验证标准,例如OAuth,再次减少您需要花费的精力来实现这一目标并保持长期运行。

我通常不会将邮件数据物理地放入发件人的发件箱中,然后也进入收件箱收件箱,主要是因为您的数据存储量会增加一倍,但我想是电子邮件,路由的副本原始消息将使消息的管理变得非常简单,同时使得很难不小心地让一个用户访问另一个消息。

这里因为你是原型,所以提供体面的评论很难,因为你已经暗示过你会在后端以不同的方式做事,所以我不想再次猜测你的位置已经决定顺其自然了。对于这样一个简单的系统,UI应该是精简的,后端的逻辑,特定的逻辑是我希望提供未来的评论和见解。