/* jslint node: true */ 'use strict'; var msgDb = require('./database.js').dbs.message; var Config = require('./config.js').config; var async = require('async'); var _ = require('lodash'); var assert = require('assert'); exports.getAvailableMessageAreas = getAvailableMessageAreas; exports.getMessageAreaByName = getMessageAreaByName; exports.changeMessageArea = changeMessageArea; exports.getMessageListForArea = getMessageListForArea; function getAvailableMessageAreas() { // example: [ { "name" : "local_music", "desc" : "Music Discussion", "groups" : ["somegroup"] }, ... ] return Config.messages.areas; } function getMessageAreaByName(areaName) { areaName = areaName.toLowerCase(); var availAreas = getAvailableMessageAreas(); var index = _.findIndex(availAreas, function pred(an) { return an.name == areaName; }); if(index > -1) { return availAreas[index]; } } function changeMessageArea(client, areaName, cb) { async.waterfall( [ function getArea(callback) { var area = getMessageAreaByName(areaName); if(area) { callback(null, area); } else { callback(new Error('Invalid message area')); } }, function validateAccess(area, callback) { // :TODO: validate user has access to |area| -- must belong to group(s) specified callback(null, area); }, function changeArea(area, callback) { client.user.persistProperty('message_area_name', area.name, function persisted(err) { callback(err, area); }); } ], function complete(err, area) { if(!err) { console.log(JSON.stringify(area)) client.log.info( area, 'Current message area changed'); } else { client.log.warn( { area : area, error : err.message }, 'Could not change message area'); } cb(err); } ); } function getMessageListForArea(options, areaName, cb) { // // options.client (required) // options.client.log.debug( { areaName : areaName }, 'Fetching available messages'); assert(_.isObject(options.client)); /* [ { messageId, messageUuid, replyToId, toUserName, fromUserName, subject, modTimestamp, status(new|old), viewCount } ] */ var msgList = []; async.series( [ function fetchMessages(callback) { msgDb.each( 'SELECT message_id, message_uuid, reply_to_message_id, to_user_name, from_user_name, subject, modified_timestamp, view_count ' + 'FROM message ' + 'WHERE area_name=? ' + 'ORDER BY message_id;', [ areaName.toLowerCase() ], function msgRow(err, row) { if(!err) { msgList.push( { messageId : row.message_id, messageUuid : row.message_uuid, replyToMsgId : row.reply_to_message_id, toUserName : row.to_user_name, fromUserName : row.from_user_name, subject : row.subject, modTimestamp : row.modified_timestamp, viewCount : row.view_count, } ); } }, callback ); }, function fetchStatus(callback) { callback(null);// :TODO: fixmeh. } ], function complete(err) { cb(err, msgList); } ); }