30 lines
1.1 KiB
Python
30 lines
1.1 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
from flectra import api, fields, models
|
|
from flectra.addons.bus.models.bus_presence import AWAY_TIMER
|
|
from flectra.addons.bus.models.bus_presence import DISCONNECTION_TIMER
|
|
|
|
|
|
class ResUsers(models.Model):
|
|
|
|
_inherit = "res.users"
|
|
|
|
im_status = fields.Char('IM Status', compute='_compute_im_status')
|
|
|
|
@api.multi
|
|
def _compute_im_status(self):
|
|
""" Compute the im_status of the users """
|
|
self.env.cr.execute("""
|
|
SELECT
|
|
user_id as id,
|
|
CASE WHEN age(now() AT TIME ZONE 'UTC', last_poll) > interval %s THEN 'offline'
|
|
WHEN age(now() AT TIME ZONE 'UTC', last_presence) > interval %s THEN 'away'
|
|
ELSE 'online'
|
|
END as status
|
|
FROM bus_presence
|
|
WHERE user_id IN %s
|
|
""", ("%s seconds" % DISCONNECTION_TIMER, "%s seconds" % AWAY_TIMER, tuple(self.ids)))
|
|
res = dict(((status['id'], status['status']) for status in self.env.cr.dictfetchall()))
|
|
for user in self:
|
|
user.im_status = res.get(user.id, 'offline')
|