@ -16,7 +16,7 @@ cache.setVar = function(variable, value) {
cache . dumpCacheBeforeExit = function ( ) {
cache . dumpCacheBeforeExit = function ( ) {
if ( inMemCache ) {
if ( inMemCache ) {
console . log ( 'dumping cache before exit' ) ;
console . log ( 'dumping cache before exit' ) ;
fs . writeFileSync ( cache . iguanaDir + '/shepherd/cache-' + inMemPubkey + '.json' , JSON . stringify ( inMemCache ) , 'utf8' ) ;
fs . writeFileSync ( ` ${ cache . iguanaDir } /shepherd/cache- ${ inMemPubkey } .json ` , JSON . stringify ( inMemCache ) , 'utf8' ) ;
}
}
}
}
@ -29,8 +29,8 @@ cache.get = function(req, res, next) {
if ( ! inMemCache ) {
if ( ! inMemCache ) {
console . log ( 'serving cache from disk' ) ;
console . log ( 'serving cache from disk' ) ;
if ( fs . existsSync ( cache . iguanaDir + '/shepherd/cache-' + pubkey + '.json' ) ) {
if ( fs . existsSync ( ` ${ cache . iguanaDir } /shepherd/cache- ${ pubkey } .json ` ) ) {
fs . readFile ( cache . iguanaDir + '/shepherd/cache-' + pubkey + '.json' , 'utf8' , function ( err , data ) {
fs . readFile ( ` ${ cache . iguanaDir } /shepherd/cache- ${ pubkey } .json ` , 'utf8' , function ( err , data ) {
if ( err ) {
if ( err ) {
const errorObj = {
const errorObj = {
'msg' : 'error' ,
'msg' : 'error' ,
@ -54,10 +54,10 @@ cache.get = function(req, res, next) {
if ( e . toString ( ) . indexOf ( 'at position' ) > - 1 ) {
if ( e . toString ( ) . indexOf ( 'at position' ) > - 1 ) {
const errorPos = e . toString ( ) . split ( ' ' ) ;
const errorPos = e . toString ( ) . split ( ' ' ) ;
console . log ( 'JSON error ---> ' + data . substring ( errorPos [ errorPos . length - 1 ] - 20 , errorPos [ errorPos . length - 1 ] + 20 ) + ' | error sequence: ' + data . substring ( errorPos [ errorPos . length - 1 ] , errorPos [ errorPos . length - 1 ] + 1 ) ) ;
console . log ( ` JSON error ---> ${ data . substring ( errorPos [ errorPos . length - 1 ] - 20 , errorPos [ errorPos . length - 1 ] + 20 ) } | error sequence: ${ data . substring ( errorPos [ errorPos . length - 1 ] , errorPos [ errorPos . length - 1 ] + 1 ) } ` ) ;
console . log ( 'attempting to recover JSON data' ) ;
console . log ( 'attempting to recover JSON data' ) ;
fs . writeFile ( cache . iguanaDir + '/shepherd/cache-' + pubkey + '.json' , data . substring ( 0 , errorPos [ errorPos . length - 1 ] ) , function ( err ) {
fs . writeFile ( ` ${ cache . iguanaDir } /shepherd/cache- ${ pubkey } .json ` , data . substring ( 0 , errorPos [ errorPos . length - 1 ] ) , function ( err ) {
const successObj = {
const successObj = {
'msg' : 'success' ,
'msg' : 'success' ,
'result' : data . substring ( 0 , errorPos [ errorPos . length - 1 ] )
'result' : data . substring ( 0 , errorPos [ errorPos . length - 1 ] )
@ -73,7 +73,7 @@ cache.get = function(req, res, next) {
} else {
} else {
const errorObj = {
const errorObj = {
'msg' : 'error' ,
'msg' : 'error' ,
'result' : 'no file with handle ' + pubkey
'result' : ` no file with handle ${ pubkey } `
} ;
} ;
res . end ( JSON . stringify ( errorObj ) ) ;
res . end ( JSON . stringify ( errorObj ) ) ;
@ -100,8 +100,8 @@ cache.groomGet = function(req, res, next) {
const _ filename = req . query . filename ;
const _ filename = req . query . filename ;
if ( _ filename ) {
if ( _ filename ) {
if ( fs . existsSync ( cache . iguanaDir + '/shepherd/cache-' + _ filename + '.json' ) ) {
if ( fs . existsSync ( ` ${ cache . iguanaDir } /shepherd/cache- ${ _ filename } .json ` ) ) {
fs . readFile ( cache . iguanaDir + '/shepherd/cache-' + _ filename + '.json' , 'utf8' , function ( err , data ) {
fs . readFile ( ` ${ cache . iguanaDir } /shepherd/cache- ${ _ filename } .json ` , 'utf8' , function ( err , data ) {
if ( err ) {
if ( err ) {
const errorObj = {
const errorObj = {
'msg' : 'error' ,
'msg' : 'error' ,
@ -121,7 +121,7 @@ cache.groomGet = function(req, res, next) {
} else {
} else {
const errorObj = {
const errorObj = {
'msg' : 'error' ,
'msg' : 'error' ,
'result' : 'no file with name ' + _ filename
'result' : ` no file with name ${ _ filename } `
} ;
} ;
res . end ( JSON . stringify ( errorObj ) ) ;
res . end ( JSON . stringify ( errorObj ) ) ;
@ -140,10 +140,10 @@ cache.groomDelete = function(req, res, next) {
const _ filename = req . body . filename ;
const _ filename = req . body . filename ;
if ( _ filename ) {
if ( _ filename ) {
if ( fs . existsSync ( cache . iguanaDir + '/shepherd/cache-' + _ filename + '.json' ) ) {
if ( fs . existsSync ( ` ${ cache . iguanaDir } /shepherd/cache- ${ _ filename } .json ` ) ) {
inMemCache = null ;
inMemCache = null ;
fs . unlink ( cache . iguanaDir + '/shepherd/cache-' + _ filename + '.json' , function ( err ) {
fs . unlink ( ` ${ cache . iguanaDir } /shepherd/cache- ${ _ filename } .json ` , function ( err ) {
if ( err ) {
if ( err ) {
const errorObj = {
const errorObj = {
'msg' : 'error' ,
'msg' : 'error' ,
@ -163,7 +163,7 @@ cache.groomDelete = function(req, res, next) {
} else {
} else {
const errorObj = {
const errorObj = {
'msg' : 'error' ,
'msg' : 'error' ,
'result' : 'no file with name ' + _ filename
'result' : ` no file with name ${ _ filename } `
} ;
} ;
res . end ( JSON . stringify ( errorObj ) ) ;
res . end ( JSON . stringify ( errorObj ) ) ;
@ -198,7 +198,7 @@ cache.groomPost = function(req, res) {
console . log ( 'appending groom post to in mem cache' ) ;
console . log ( 'appending groom post to in mem cache' ) ;
console . log ( 'appending groom post to on disk cache' ) ;
console . log ( 'appending groom post to on disk cache' ) ;
fs . writeFile ( cache . iguanaDir + '/shepherd/cache-' + _ filename + '.json' , _ payload , function ( err ) {
fs . writeFile ( ` ${ cache . iguanaDir } /shepherd/cache- ${ _ filename } .json ` , _ payload , function ( err ) {
if ( err ) {
if ( err ) {
const errorObj = {
const errorObj = {
'msg' : 'error' ,
'msg' : 'error' ,
@ -271,7 +271,7 @@ checkCallStack = function() {
* /
* /
cache . one = function ( req , res , next ) {
cache . one = function ( req , res , next ) {
if ( req . query . pubkey &&
if ( req . query . pubkey &&
! fs . existsSync ( cache . iguanaDir + '/shepherd/cache-' + req . query . pubkey + '.json' ) ) {
! fs . existsSync ( ` ${ cache . iguanaDir } /shepherd/cache- ${ req . query . pubkey } .json ` ) ) {
cacheCallInProgress = false ;
cacheCallInProgress = false ;
}
}
@ -282,8 +282,8 @@ cache.one = function(req, res, next) {
if ( ! cacheCallInProgress ) {
if ( ! cacheCallInProgress ) {
cache . dumpCacheBeforeExit ( ) ;
cache . dumpCacheBeforeExit ( ) ;
if ( fs . existsSync ( cache . iguanaDir + '/shepherd/cache-' + req . query . pubkey + '.json' ) ) {
if ( fs . existsSync ( ` ${ cache . iguanaDir } /shepherd/cache- ${ req . query . pubkey } .json ` ) ) {
let _ data = fs . readFileSync ( cache . iguanaDir + '/shepherd/cache-' + req . query . pubkey + '.json' , 'utf8' ) ;
let _ data = fs . readFileSync ( ` ${ cache . iguanaDir } /shepherd/cache- ${ req . query . pubkey } .json ` , 'utf8' ) ;
if ( _ data ) {
if ( _ data ) {
inMemCache = JSON . parse ( _ data ) ;
inMemCache = JSON . parse ( _ data ) ;
_ data = _ data . replace ( 'waiting' , 'failed' ) ;
_ data = _ data . replace ( 'waiting' , 'failed' ) ;
@ -327,7 +327,7 @@ cache.one = function(req, res, next) {
inMemPubkey = pubkey ;
inMemPubkey = pubkey ;
callStack [ coin ] = 1 ;
callStack [ coin ] = 1 ;
console . log ( callsArray ) ;
console . log ( callsArray ) ;
console . log ( 'iguana core port ' + iguanaCorePort ) ;
console . log ( ` iguana core port ${ iguanaCorePort } ` ) ;
if ( ! sessionKey ) {
if ( ! sessionKey ) {
const errorObj = {
const errorObj = {
@ -354,7 +354,7 @@ cache.one = function(req, res, next) {
function fixJSON ( data ) {
function fixJSON ( data ) {
if ( data && data . length ) {
if ( data && data . length ) {
try {
try {
var parsedJSON = JSON . parse ( data ) ;
const parsedJSON = JSON . parse ( data ) ;
return parsedJSON ;
return parsedJSON ;
} catch ( e ) {
} catch ( e ) {
@ -362,7 +362,7 @@ cache.one = function(req, res, next) {
if ( e . toString ( ) . indexOf ( 'at position' ) > - 1 ) {
if ( e . toString ( ) . indexOf ( 'at position' ) > - 1 ) {
const errorPos = e . toString ( ) . split ( ' ' ) ;
const errorPos = e . toString ( ) . split ( ' ' ) ;
console . log ( 'JSON error ---> ' + data . substring ( errorPos [ errorPos . length - 1 ] - 20 , errorPos [ errorPos . length - 1 ] + 20 ) + ' | error sequence: ' + data . substring ( errorPos [ errorPos . length - 1 ] , errorPos [ errorPos . length - 1 ] + 1 ) ) ;
console . log ( ` JSON error ---> ${ data . substring ( errorPos [ errorPos . length - 1 ] - 20 , errorPos [ errorPos . length - 1 ] + 20 ) } | error sequence: ${ data . substring ( errorPos [ errorPos . length - 1 ] , errorPos [ errorPos . length - 1 ] + 1 ) } ` ) ;
console . log ( 'attempting to recover JSON data' ) ;
console . log ( 'attempting to recover JSON data' ) ;
return JSON . parse ( data . substring ( 0 , errorPos [ errorPos . length - 1 ] ) ) ;
return JSON . parse ( data . substring ( 0 , errorPos [ errorPos . length - 1 ] ) ) ;
}
}
@ -375,14 +375,13 @@ cache.one = function(req, res, next) {
}
}
}
}
if ( fs . existsSync ( cache . iguanaDir + '/shepherd/cache-' + pubkey + '.json' ) && coin !== 'all' ) {
if ( fs . existsSync ( ` ${ cache . iguanaDir } /shepherd/cache- ${ pubkey } .json ` ) && coin !== 'all' ) {
if ( inMemCache ) {
if ( inMemCache ) {
console . log ( 'cache one from mem' ) ;
console . log ( 'cache one from mem' ) ;
outObj = inMemCache ;
outObj = inMemCache ;
} else {
} else {
var _ file = fs . readFileSync ( cache . iguanaDir + '/shepherd/cache-' + pubkey + '.json' , 'utf8' ) ;
const _ file = fs . readFileSync ( ` ${ cache . iguanaDir } /shepherd/cache- ${ pubkey } .json ` , 'utf8' ) ;
console . log ( 'cache one from disk' ) ;
console . log ( 'cache one from disk' ) ;
//outObj = _file ? JSON.parse(_file) : {};
outObj = fixJSON ( _ file ) ;
outObj = fixJSON ( _ file ) ;
}
}
@ -419,23 +418,24 @@ cache.one = function(req, res, next) {
function execDEXRequests ( coin , address ) {
function execDEXRequests ( coin , address ) {
let dexUrls = {
let dexUrls = {
'listunspent' : 'http://' + cache . appConfig . host + ':' + iguanaCorePort + '/api/dex/listunspent?userpass=' + sessionKey + '&symbol=' + coin + '&address=' + address ,
'listunspent' : ` http:// ${ cache . appConfig . host } : ${ iguanaCorePort } /api/dex/listunspent?userpass= ${ sessionKey } &symbol= ${ coin } &address= ${ address } ` ,
'listtransactions' : 'http://' + cache . appConfig . host + ':' + iguanaCorePort + '/api/dex/listtransactions?userpass=' + sessionKey + '&count=100&skip=0&symbol=' + coin + '&address=' + address ,
'listtransactions' : ` http:// ${ cache . appConfig . host } : ${ iguanaCorePort } /api/dex/listtransactions?userpass= ${ sessionKey } &count=100&skip=0&symbol= ${ coin } &address= ${ address } ` ,
'getbalance' : 'http://' + cache . appConfig . host + ':' + iguanaCorePort + '/api/dex/getbalance?userpass=' + sessionKey + '&symbol=' + coin + '&address=' + address ,
'getbalance' : ` http:// ${ cache . appConfig . host } : ${ iguanaCorePort } /api/dex/getbalance?userpass= ${ sessionKey } &symbol= ${ coin } &address= ${ address } ` ,
'refresh' : 'http://' + cache . appConfig . host + ':' + iguanaCorePort + '/api/basilisk/refresh?userpass=' + sessionKey + '&symbol=' + coin + '&address=' + address
'refresh' : ` http:// ${ cache . appConfig . host } : ${ iguanaCorePort } /api/basilisk/refresh?userpass= ${ sessionKey } &symbol= ${ coin } &address= ${ address } `
} ,
} ,
_ dexUrls = { } ;
_ dexUrls = { } ;
for ( var a = 0 ; a < callsArray . length ; a ++ ) {
for ( let a = 0 ; a < callsArray . length ; a ++ ) {
_ dexUrls [ callsArray [ a ] ] = dexUrls [ callsArray [ a ] ] ;
_ dexUrls [ callsArray [ a ] ] = dexUrls [ callsArray [ a ] ] ;
}
}
if ( coin === 'BTC' || coin === 'SYS' ) {
if ( coin === 'BTC' ||
coin === 'SYS' ) {
delete _ dexUrls . refresh ;
delete _ dexUrls . refresh ;
delete _ dexUrls . getbalance ;
delete _ dexUrls . getbalance ;
}
}
console . log ( coin + ' address ' + address ) ;
console . log ( ` ${ coin } address ${ address } ` ) ;
if ( ! outObj . basilisk [ coin ] [ address ] ) {
if ( ! outObj . basilisk [ coin ] [ address ] ) {
outObj . basilisk [ coin ] [ address ] = { } ;
outObj . basilisk [ coin ] [ address ] = { } ;
@ -493,7 +493,7 @@ cache.one = function(req, res, next) {
} ) ;
} ) ;
outObj . basilisk [ coin ] [ address ] [ key ] . status = 'in progress' ;
outObj . basilisk [ coin ] [ address ] [ key ] . status = 'in progress' ;
request ( {
request ( {
url : mock ? 'http://localhost:17777/shepherd/mock?url=' + dexUrl : dexUrl ,
url : mock ? ` http://localhost:17777/shepherd/mock?url= ${ dexUrl } ` : dexUrl ,
method : 'GET'
method : 'GET'
} , function ( error , response , body ) {
} , function ( error , response , body ) {
if ( response &&
if ( response &&
@ -519,9 +519,35 @@ cache.one = function(req, res, next) {
const _ parsedJSON = JSON . parse ( body ) ;
const _ parsedJSON = JSON . parse ( body ) ;
if ( key === 'getbalance' &&
if ( key === 'getbalance' &&
coin === 'KMD' / * &&
coin === 'KMD' / * &&
( ( _ parsedJSON && _ parsedJSON . balance === 0 ) || _ parsedJSON === [ ] ) * / ) {
( ( _ parsedJSON && _ parsedJSON . balance === 0 ) || body === [ ] ) * / ) {
console . log ( 'fallback to kmd explorer' ) ;
console . log ( 'fallback to kmd explorer ======>' ) ;
//http://kmd.explorer.supernet.org/api/addr/RDbGxL8QYdEp8sMULaVZS2E6XThcTKT9Jd/?noTxList=1
request ( {
url : ` http://kmd.explorer.supernet.org/api/addr/ ${ address } /?noTxList=1 ` ,
method : 'GET'
} , function ( error , response , body ) {
if ( response &&
response . statusCode &&
response . statusCode === 200 ) {
console . log ( JSON . stringify ( body ) ) ;
/ * c a c h e . i o . e m i t ( ' m e s s a g e s ' , {
'message' : {
'shepherd' : {
'method' : 'cache-one' ,
'status' : 'in progress' ,
'iguanaAPI' : {
'method' : key ,
'coin' : coin ,
'address' : address ,
'status' : 'done' ,
'resp' : body
}
}
}
} ) ; * /
} else {
}
} ) ;
}
}
outObj . basilisk [ coin ] [ address ] [ key ] = { } ;
outObj . basilisk [ coin ] [ address ] [ key ] = { } ;
@ -531,7 +557,7 @@ cache.one = function(req, res, next) {
console . log ( dexUrl ) ;
console . log ( dexUrl ) ;
console . log ( body ) ;
console . log ( body ) ;
callStack [ coin ] -- ;
callStack [ coin ] -- ;
console . log ( coin + ' _stack len ' + callStack [ coin ] ) ;
console . log ( ` ${ coin } _stack len ${ callStack [ coin ] } ` ) ;
cache . io . emit ( 'messages' , {
cache . io . emit ( 'messages' , {
'message' : {
'message' : {
'shepherd' : {
'shepherd' : {
@ -555,7 +581,7 @@ cache.one = function(req, res, next) {
outObj . basilisk [ coin ] [ address ] [ key ] . timestamp = 1471620867 // add timestamp
outObj . basilisk [ coin ] [ address ] [ key ] . timestamp = 1471620867 // add timestamp
outObj . basilisk [ coin ] [ address ] [ key ] . status = 'done' ;
outObj . basilisk [ coin ] [ address ] [ key ] . status = 'done' ;
callStack [ coin ] -- ;
callStack [ coin ] -- ;
console . log ( coin + ' _stack len ' + callStack [ coin ] ) ;
console . log ( ` ${ coin } _stack len ${ callStack [ coin ] } ` ) ;
cache . io . emit ( 'messages' , {
cache . io . emit ( 'messages' , {
'message' : {
'message' : {
'shepherd' : {
'shepherd' : {
@ -572,9 +598,9 @@ cache.one = function(req, res, next) {
}
}
} ) ;
} ) ;
} else {
} else {
console . log ( key + ' is fresh, check back in ' + ( cacheGlobLifetime - checkTimestamp ( outObj . basilisk [ coin ] [ address ] [ key ] . timestamp ) ) + 's' ) ;
console . log ( ` ${ key } is fresh, check back in ${ ( cacheGlobLifetime - checkTimestamp ( outObj . basilisk [ coin ] [ address ] [ key ] . timestamp ) ) } s ` ) ;
callStack [ coin ] -- ;
callStack [ coin ] -- ;
console . log ( coin + ' _stack len ' + callStack [ coin ] ) ;
console . log ( ` ${ coin } _stack len ${ callStack [ coin ] } ` ) ;
cache . io . emit ( 'messages' , {
cache . io . emit ( 'messages' , {
'message' : {
'message' : {
'shepherd' : {
'shepherd' : {
@ -611,7 +637,7 @@ cache.one = function(req, res, next) {
writeCache ( ) ;
writeCache ( ) ;
const addrCount = outObj . basilisk [ coin ] . addresses ? outObj . basilisk [ coin ] . addresses . length : 0 ;
const addrCount = outObj . basilisk [ coin ] . addresses ? outObj . basilisk [ coin ] . addresses . length : 0 ;
var callsArrayBTC = callsArray . length ;
let callsArrayBTC = callsArray . length ;
if ( callsArray . indexOf ( 'getbalance' ) > - 1 ) {
if ( callsArray . indexOf ( 'getbalance' ) > - 1 ) {
callsArrayBTC -- ;
callsArrayBTC -- ;
@ -620,7 +646,7 @@ cache.one = function(req, res, next) {
callsArrayBTC -- ;
callsArrayBTC -- ;
}
}
callStack [ coin ] = callStack [ coin ] + addrCount * ( coin === 'BTC' || coin === 'SYS' ? callsArrayBTC : callsArray . length ) ;
callStack [ coin ] = callStack [ coin ] + addrCount * ( coin === 'BTC' || coin === 'SYS' ? callsArrayBTC : callsArray . length ) ;
console . log ( coin + ' stack len ' + callStack [ coin ] ) ;
console . log ( ` ${ coin } stack len ${ callStack [ coin ] } ` ) ;
cache . io . emit ( 'messages' , {
cache . io . emit ( 'messages' , {
'message' : {
'message' : {
@ -642,9 +668,9 @@ cache.one = function(req, res, next) {
if ( addresses ) {
if ( addresses ) {
parseAddresses ( coin , addresses ) ;
parseAddresses ( coin , addresses ) ;
} else {
} else {
const tempUrl = 'http://' + cache . appConfig . host + ':' + cache . appConfig . iguanaCorePort + '/api/bitcoinrpc/getaddressesbyaccount?userpass=' + sessionKey + '&coin=' + coin + '&account=*' ;
const tempUrl = ` http:// ${ cache . appConfig . host } : ${ cache . appConfig . iguanaCorePort } /api/bitcoinrpc/getaddressesbyaccount?userpass= ${ sessionKey } &coin= ${ coin } &account=* ` ;
request ( {
request ( {
url : mock ? 'http://localhost:17777/shepherd/mock?url=' + tempUrl : tempUrl ,
url : mock ? ` http://localhost:17777/shepherd/mock?url= ${ tempUrl } ` : tempUrl ,
method : 'GET'
method : 'GET'
} , function ( error , response , body ) {
} , function ( error , response , body ) {
if ( response &&
if ( response &&
@ -675,9 +701,9 @@ cache.one = function(req, res, next) {
} ) ;
} ) ;
if ( coin === 'all' ) {
if ( coin === 'all' ) {
const tempUrl = 'http://' + cache . appConfig . host + ':' + cache . appConfig . iguanaCorePort + '/api/InstantDEX/allcoins?userpass=' + sessionKey ;
const tempUrl = ` http:// ${ cache . appConfig . host } : ${ cache . appConfig . iguanaCorePort } /api/InstantDEX/allcoins?userpass= ${ sessionKey } ` ;
request ( {
request ( {
url : mock ? 'http://localhost:17777/shepherd/mock?url=' + tempUrl : tempUrl ,
url : mock ? ` http://localhost:17777/shepherd/mock?url= ${ tempUrl } ` : tempUrl ,
method : 'GET'
method : 'GET'
} , function ( error , response , body ) {
} , function ( error , response , body ) {
if ( response &&
if ( response &&
@ -737,15 +763,17 @@ cache.one = function(req, res, next) {
getAddresses ( coin ) ;
getAddresses ( coin ) ;
}
}
} else {
} else {
var callsArrayBTC = callsArray . length ; // restrict BTC and SYS only to listunspent and listtransactions calls
let callsArrayBTC = callsArray . length ; // restrict BTC and SYS only to listunspent and listtransactions calls
if ( callsArray . indexOf ( 'getbalance' ) > - 1 ) {
if ( callsArray . indexOf ( 'getbalance' ) > - 1 ) {
callsArrayBTC -- ;
callsArrayBTC -- ;
}
}
if ( callsArray . indexOf ( 'refresh' ) > - 1 ) {
if ( callsArray . indexOf ( 'refresh' ) > - 1 ) {
callsArrayBTC -- ;
callsArrayBTC -- ;
}
}
callStack [ coin ] = callStack [ coin ] + ( coin === 'BTC' || coin === 'SYS' ? callsArrayBTC : callsArray . length ) ;
callStack [ coin ] = callStack [ coin ] + ( coin === 'BTC' || coin === 'SYS' ? callsArrayBTC : callsArray . length ) ;
console . log ( coin + ' stack len ' + callStack [ coin ] ) ;
console . log ( ` ${ coin } stack len ${ callStack [ coin ] } ` ) ;
cache . io . emit ( 'messages' , {
cache . io . emit ( 'messages' , {
'message' : {
'message' : {