Entity.py 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. #!/usr/bin/env python3
  2. # Contest Management System - http://cms-dev.github.io/
  3. # Copyright © 2011-2013 Luca Wehrstedt <luca.wehrstedt@gmail.com>
  4. #
  5. # This program is free software: you can redistribute it and/or modify
  6. # it under the terms of the GNU Affero General Public License as
  7. # published by the Free Software Foundation, either version 3 of the
  8. # License, or (at your option) any later version.
  9. #
  10. # This program is distributed in the hope that it will be useful,
  11. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. # GNU Affero General Public License for more details.
  14. #
  15. # You should have received a copy of the GNU Affero General Public License
  16. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  17. class InvalidKey(Exception):
  18. """Exception raised in case of invalid key."""
  19. pass
  20. class InvalidData(Exception):
  21. """Exception raised in case of invalid data."""
  22. pass
  23. class Entity:
  24. """Base virtual class which all entities should extend.
  25. Provide some virtual methods that other classes should implement.
  26. """
  27. def set(self, data):
  28. """Set all properties using the given data.
  29. Accept the data format used on the HTTP interface.
  30. data (dict): the properties of the entity, in the "external"
  31. format
  32. Raise InvalidData if not able to parse the data argument.
  33. """
  34. pass
  35. def get(self):
  36. """Get all properties.
  37. Produce the data format used on the HTTP interface.
  38. return (dict): the properties of the entity, in the "external"
  39. format
  40. """
  41. pass
  42. def consistent(self, stores):
  43. """Check if the entity is consistent.
  44. Verify that all references to other entities are correct (i.e.
  45. those entities actually exist).
  46. stores ({str: Store}): a dict of Stores that can be used to
  47. validate references to other entities.
  48. return (bool): the result of this check
  49. """
  50. return True