diff --git a/oml/localnodes.py b/oml/localnodes.py index 4162e3d..fa6c4a2 100644 --- a/oml/localnodes.py +++ b/oml/localnodes.py @@ -141,12 +141,13 @@ class LocalNodesBase(Thread): if can_connect(data): self._nodes[data['id']] = data with db.session(): - u = user.models.User.get_or_create(data['id']) - u.info['username'] = data['username'] - u.info['local'] = data - u.update_name() - u.save() - state.nodes.queue('add', u.id) + u = user.models.User.get(data['id']) + if u: + u.info['username'] = data['username'] + u.info['local'] = data + u.update_name() + u.save() + state.nodes.queue('add', u.id) self.send() def get_ip(self): diff --git a/oml/user/api.py b/oml/user/api.py index 9049d77..6f9e939 100644 --- a/oml/user/api.py +++ b/oml/user/api.py @@ -83,8 +83,16 @@ def getUsers(data): } ''' users = [] + ids = set() for u in models.User.query.filter(models.User.id!=settings.USER_ID).all(): users.append(u.json()) + ids.add(u.id) + for id in state.nodes._local._nodes: + if id not in ids: + n = state.nodes._local._nodes[id].copy() + n['online'] = True + n['name'] = n['username'] + users.append(n) users.sort(key=lambda u: ox.sort_string(str(u.get('index', '')) + 'Z' + (u.get('name') or ''))) return { "users": users