Source code for stoqlib.domain.station

# -*- coding: utf-8 -*-
# vi:si:et:sw=4:sts=4:ts=4

##
## Copyright (C) 2006 Async Open Source <http://www.async.com.br>
## All rights reserved
##
## This program is free software; you can redistribute it and/or modify
## it under the terms of the GNU Lesser General Public License as published by
## the Free Software Foundation; either version 2 of the License, or
## (at your option) any later version.
##
## This program is distributed in the hope that it will be useful,
## but WITHOUT ANY WARRANTY; without even the implied warranty of
## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
## GNU Lesser General Public License for more details.
##
## You should have received a copy of the GNU Lesser General Public License
## along with this program; if not, write to the Free Software
## Foundation, Inc., or visit: http://www.gnu.org/.
##
##  Author(s): Stoq Team <stoq-devel@async.com.br>
##
""" Station, a branch station per computer """

# pylint: enable=E1101

from storm.references import Reference
from zope.interface import implementer

from stoqlib.database.properties import UnicodeCol, BoolCol, IdCol
from stoqlib.domain.base import Domain
from stoqlib.domain.interfaces import IActive
from stoqlib.exceptions import StoqlibError
from stoqlib.lib.translation import stoqlib_gettext

_ = stoqlib_gettext


@implementer(IActive)
[docs]class BranchStation(Domain): """Defines a computer which access Stoqlib database and lives in a certain branch company """ __storm_table__ = 'branch_station' name = UnicodeCol() is_active = BoolCol(default=False) branch_id = IdCol() branch = Reference(branch_id, 'Branch.id') # Public @classmethod
[docs] def get_active_stations(cls, store): """Returns the currently active branch stations. :param store: a store :returns: a sequence of currently active stations """ return store.find(cls, is_active=True).order_by(cls.name)
@classmethod
[docs] def create(cls, store, branch, name): """Create a new station id for the current machine. Optionally a branch can be specified which will be set as the branch for created station. :param store: a store :param branch: the branch :param name: name of the station :returns: a BranchStation instance """ if cls.get_station(store, branch, name): raise StoqlibError( _(u"There is already a station registered as `%s'.") % name) return cls(name=name, is_active=True, branch=branch, store=store)
[docs] def check_station_exists(self, name): """Returns True if we already have a station with the given name """ # FIXME: We should allow computers with the same on different # branches. return self.check_unique_value_exists(BranchStation.name, name)
@classmethod
[docs] def get_station(cls, store, branch, name): """Fetches a station from a branch :param store: a store :param branch: the branch :param name: name of the station """ if branch is None: raise TypeError(u"BranchStation.get_station() requires a Branch") return store.find(cls, name=name, branch=branch).one()
# # IActive implementation # def inactivate(self): assert self.is_active, (u'This station is already inactive') self.is_active = False def activate(self): assert not self.is_active, (u'This station is already active') self.is_active = True def get_status_string(self): if self.is_active: return _(u'Active') return _(u'Inactive') # # Accessors #
[docs] def get_branch_name(self): """Returns the branch name """ return self.branch.get_description()