mirror of
https://github.com/codeninjasllc/codecombat.git
synced 2025-01-22 04:09:47 -05:00
36 lines
1.3 KiB
CoffeeScript
36 lines
1.3 KiB
CoffeeScript
log = require 'winston'
|
|
mongoose = require 'mongoose'
|
|
plugins = require '../plugins/plugins'
|
|
utils = require '../lib/utils'
|
|
http = require 'http'
|
|
config = require '../../server_config'
|
|
|
|
AnalyticsLogEventSchema = new mongoose.Schema({
|
|
user: String #Actually a `mongoose.Schema.Types.ObjectId` but ...
|
|
event: String
|
|
properties: mongoose.Schema.Types.Mixed
|
|
}, {strict: false, versionKey: false})
|
|
|
|
AnalyticsLogEventSchema.index({event: 1, _id: -1})
|
|
AnalyticsLogEventSchema.index({event: 1, 'properties.level': 1})
|
|
AnalyticsLogEventSchema.index({event: 1, 'properties.levelID': 1})
|
|
AnalyticsLogEventSchema.index({user: 1, event: 1})
|
|
|
|
AnalyticsLogEventSchema.statics.logEvent = (user, event, properties={}) ->
|
|
unless user?
|
|
log.warn 'No user given to analytics logEvent.'
|
|
return
|
|
|
|
doc = new AnalyticsLogEvent
|
|
user: user
|
|
event: event
|
|
properties: properties
|
|
|
|
doc.save()
|
|
|
|
unless config.proxy
|
|
analyticsMongoose = mongoose.createConnection()
|
|
analyticsMongoose.open "mongodb://#{config.mongo.analytics_host}:#{config.mongo.analytics_port}/#{config.mongo.analytics_db}", (error) ->
|
|
log.error "Couldn't connect to analytics", error if error
|
|
|
|
module.exports = AnalyticsLogEvent = analyticsMongoose.model('analytics.log.event', AnalyticsLogEventSchema, config.mongo.analytics_collection)
|