Django Library PaTT
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

access.py 9.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. import logging
  2. from .models import Task, Project, Comment, TASKSTATE_CHOICES, TASKS_IN_WORK, PROJECTS_IN_WORK, PRIO_CHOICES
  3. try:
  4. from config import APP_NAME as ROOT_LOGGER_NAME
  5. except ImportError:
  6. ROOT_LOGGER_NAME = 'root'
  7. logger = logging.getLogger(ROOT_LOGGER_NAME).getChild(__name__)
  8. def read_attachment(request, rel_path):
  9. item_type, item_id = rel_path.split('/')[1:3]
  10. try:
  11. item_id = int(item_id)
  12. except ValueError:
  13. return False
  14. if item_type == 'task':
  15. acc = acc_task(Task.objects.get(id=item_id), request.user)
  16. return acc.read
  17. elif item_type == 'comment':
  18. acc = acc_task(Comment.objects.get(id=item_id).task, request.user)
  19. return acc.read_comments
  20. elif item_type == 'project':
  21. acc = acc_project(Project.objects.get(id=item_id), request.user)
  22. return acc.read
  23. else:
  24. return False
  25. def modify_attachment(request, rel_path):
  26. item_type, item_id = rel_path.split('/')[1:3]
  27. try:
  28. item_id = int(item_id)
  29. except ValueError:
  30. return False
  31. if item_type == 'task':
  32. acc = acc_task(Task.objects.get(id=item_id), request.user)
  33. return acc.modify or acc.modify_limited
  34. elif item_type == 'comment':
  35. comment = Comment.objects.get(id=item_id)
  36. acc = acc_task(comment.task, request.user)
  37. return request.user == comment.user or acc.modify_comment
  38. elif item_type == 'project':
  39. acc = acc_project(Project.objects.get(id=item_id), request.user)
  40. return acc.modify or acc.modify_limited
  41. else:
  42. return False
  43. class acc_task(object):
  44. def __init__(self, task, user):
  45. self.task = task
  46. self.user = user
  47. self.__read__ = None
  48. self.__modify__ = None
  49. self.__modify_limited__ = None
  50. self.__add_comment__ = None
  51. self.__modify_comment__ = None
  52. self.user_has_leader_rights = user in task.project.role_leader.all() and user.is_staff
  53. self.user_has_memeber_rights = user in task.project.role_member.all() and user.is_staff
  54. self.user_has_visitor_rights = user in task.project.role_visitor.all() and user.is_staff
  55. self.user_has_role_rights = self.user_has_leader_rights or self.user_has_memeber_rights or self.user_has_visitor_rights
  56. self.user_is_assigned_user = user == task.assigned_user
  57. @property
  58. def read(self):
  59. if self.__read__ is None:
  60. if self.user.is_superuser:
  61. logger.debug('acc_task.read: Access granted (Task #%d). User is Superuser.', self.task.id)
  62. self.__read__ = True
  63. elif self.user_is_assigned_user and self.task.state in TASKS_IN_WORK:
  64. logger.debug('acc_task.read: Access granted (Task #%d). User is Taskowner and taskstate is open or finished.', self.task.id)
  65. self.__read__ = True
  66. elif self.user_has_role_rights:
  67. logger.debug('acc_task.read: Access granted (Task #%d). User has a role and is Staff.', self.task.id)
  68. self.__read__ = True
  69. else:
  70. logger.debug('acc_task.read: Access denied (Task #%d).', self.task.id)
  71. self.__read__ = False
  72. return self.__read__
  73. @property
  74. def read_comments(self):
  75. return self.read
  76. @property
  77. def modify_limited(self):
  78. if self.__modify_limited__ is None:
  79. if self.user_is_assigned_user and self.user.is_staff and self.task.state in TASKS_IN_WORK:
  80. logger.debug('acc_task.modify_limited: Access granted (Task #%d). User is Taskowner and taskstate is open or finished.', self.task.id)
  81. self.__modify_limited__ = True
  82. else:
  83. logger.debug('acc_task.modify_limited: Access denied (Task #%d).', self.task.id)
  84. self.__modify_limited__ = False
  85. return self.__modify_limited__
  86. @property
  87. def modify(self):
  88. if self.__modify__ is None:
  89. if self.user.is_superuser:
  90. logger.debug('acc_task.modify: Access granted (Task #%d). User is Superuser.', self.task.id)
  91. self.__modify__ = True
  92. elif self.user_has_leader_rights:
  93. logger.debug('acc_task.modify: Access granted (Task #%d). User is Projectleader and staff.', self.task.id)
  94. self.__modify__ = True
  95. else:
  96. logger.debug('acc_task.modify: Access denied (Task #%d).', self.task.id)
  97. self.__modify__ = False
  98. return self.__modify__
  99. @property
  100. def add_comments(self):
  101. if self.__add_comment__ is None:
  102. if self.user.is_superuser:
  103. logger.debug('acc_task.add_comments: Access granted (Task #%d). User is Superuser.', self.task.id)
  104. self.__add_comment__ = True
  105. elif (self.user_has_leader_rights or self.user_has_memeber_rights) and self.task.state in TASKS_IN_WORK:
  106. logger.debug('acc_task.add_comments: Access granted (Task #%d). User is Staff, has role in the project and the task state is open or finished.', self.task.id)
  107. self.__add_comment__ = True
  108. else:
  109. logger.debug('acc_task.add_comments: Access denied (Task #%d).', self.task.id)
  110. self.__add_comment__ = False
  111. return self.__add_comment__
  112. @property
  113. def modify_comment(self):
  114. if self.__modify_comment__ is None:
  115. if self.user.is_superuser:
  116. logger.debug('acc_task.modify_comment: Access granted (Task #%d). User is Superuser.', self.task.id)
  117. self.__modify_comment__ = True
  118. elif self.user_has_leader_rights:
  119. logger.debug('acc_task.modify_comment: Access granted (Task #%d). User is Projectleader.', self.task.id)
  120. self.__modify_comment__ = True
  121. else:
  122. logger.debug('acc_task.modify_comment: Access denied (Task #%d).', self.task.id)
  123. self.__modify_comment__ = False
  124. return self.__modify_comment__
  125. @property
  126. def allowed_targetstates(self):
  127. if self.modify:
  128. rv = [state[0] for state in TASKSTATE_CHOICES]
  129. elif self.modify_limited:
  130. rv = list(TASKS_IN_WORK)
  131. else:
  132. return []
  133. rv.pop(rv.index(self.task.state))
  134. rv.sort()
  135. rv.reverse()
  136. return rv
  137. @property
  138. def allowed_targetpriority(self):
  139. if self.modify:
  140. rv = [prio[0] for prio in PRIO_CHOICES]
  141. rv.pop(rv.index(self.task.priority))
  142. rv.sort()
  143. rv.reverse()
  144. return rv
  145. return []
  146. class acc_project(object):
  147. def __init__(self, project, user):
  148. self.project = project
  149. self.user = user
  150. self.__modify__ = None
  151. self.user_has_leader_rights = user in project.role_leader.all() and user.is_staff
  152. self.user_has_memeber_rights = user in project.role_member.all() and user.is_staff
  153. self.user_has_visitor_rights = user in project.role_visitor.all() and user.is_staff
  154. self.user_has_role_rights = self.user_has_leader_rights or self.user_has_memeber_rights or self.user_has_visitor_rights
  155. @property
  156. def read(self):
  157. if self.user.is_superuser:
  158. logger.debug('acc_project.read: Access granted (Project #%d). User is Superuser.', self.project.id)
  159. return True
  160. elif self.user_has_leader_rights:
  161. logger.debug('acc_project.read: Access granted (Project #%d). User is projectleader.', self.project.id)
  162. return True
  163. elif self.user_has_role_rights and self.project.state in PROJECTS_IN_WORK:
  164. logger.debug('acc_project.read: Access granted (Project #%d). User has a role and project is in work.', self.project.id)
  165. return True
  166. elif len(self.project.task_set.filter(assigned_user=self.user, state__in=TASKS_IN_WORK)) > 0:
  167. logger.debug('acc_project.read: Access granted (Project #%d). User has open tasks.', self.project.id)
  168. return True
  169. else:
  170. logger.debug('acc_project.read: Access denied (Project #%d). User is not authenticated.', self.project.id)
  171. return False
  172. @property
  173. def modify(self):
  174. if self.__modify__ is None:
  175. if self.user.is_superuser:
  176. logger.debug('acc_project.modify: Access granted (Project #%d). User is Superuser.', self.project.id)
  177. self.__modify__ = True
  178. elif self.user in self.project.role_leader.all() and self.user.is_staff:
  179. logger.debug('acc_project.modify: Access granted (Project #%d). User is Projectleader.', self.project.id)
  180. self.__modify__ = True
  181. else:
  182. logger.debug('acc_project.modify: Access denied (Project #%d).', self.project.id)
  183. self.__modify__ = False
  184. return self.__modify__
  185. def create_task_possible(user):
  186. return len(Project.objects.filter(role_leader__in=[user])) + len(Project.objects.filter(role_member__in=[user])) > 0 and user.is_staff
  187. def create_project_possible(user):
  188. return user.is_superuser