server/python/django2/renkanmanager/models.py
author durandn
Tue, 04 Oct 2016 12:38:50 +0200
changeset 639 30b673cb13ee
parent 626 112912309726
child 662 df0060476f35
permissions -rw-r--r--
increment renkanmanager version
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
     1
'''
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
     2
Created on Jul 17, 2014
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
     3
Reworked in December, 2015
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
     4
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
     5
@author: tc, nd
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
     6
'''
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
     7
import uuid, logging, json, datetime
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
     8
from django.conf import settings
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
     9
from django.db import models, transaction
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    10
from django.core.exceptions import ValidationError
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    11
from django.utils import timezone, dateparse
611
f0f07e2b841f serverside: translation + timestamp handling + logging
durandn
parents: 610
diff changeset
    12
from django.utils.translation import ugettext_lazy as _
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
    13
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
    14
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    15
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    16
logger = logging.getLogger(__name__)
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
    17
auth_user_model = getattr(settings, 'AUTH_USER_MODEL', 'auth.User')
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
    18
626
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    19
# Copy the content of a révision.
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    20
# This will return a map (not a serialized) to allow further treatment
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    21
# This changes the ids of the project, nodes, views and edges but NOT users
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    22
#
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    23
def content_copy(content_str): #TODO: ??? Extract this in another class, like a RevisionManager ???
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    24
    node_ids_map = {}
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    25
    content = json.loads(content_str)
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    26
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    27
    content['id'] = str(uuid.uuid4())
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    28
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    29
    #nodes
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    30
    for node in content.get('nodes', []):
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    31
        id_key = 'id' if 'id' in node else '_id'
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    32
        node_ids_map[node[id_key]] = node['id'] = str(uuid.uuid4())
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    33
        node.pop('_id', None)
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    34
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    35
    for edge in content.get('edges', []):
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    36
        edge['id'] = str(uuid.uuid4())
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    37
        edge.pop('_id', None)
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    38
        edge['from'] = node_ids_map[edge['from']]
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    39
        edge['to'] = node_ids_map[edge['to']]
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    40
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    41
    for view in content.get('views', []):
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    42
        view['id'] = str(uuid.uuid4())
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    43
        view.pop('_id', None)
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    44
        view['hidden_nodes'] = [ node_ids_map[n] for n in view.get('hidden_nodes', [])]
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    45
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    46
    for user in content.get('users', []):
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    47
        if '_id' in user:
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    48
            user['id'] = user.pop('_id')
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    49
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    50
    return content
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    51
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
    52
class Workspace(models.Model):
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
    53
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
    54
    workspace_guid = models.UUIDField(default=uuid.uuid4, editable=False, unique=True, blank=False, null=False)
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
    55
    title = models.CharField(max_length=1024, null=True)
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
    56
    creator = models.ForeignKey(auth_user_model, blank=True, null=True, related_name="workspace_creator")
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
    57
    creation_date = models.DateTimeField(auto_now_add=True)
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
    58
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
    59
    @property
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
    60
    def renkan_count(self):
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
    61
        return self.renkans.all().count()
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
    62
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
    63
    class Meta:
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
    64
        app_label = 'renkanmanager'
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
    65
        permissions = (
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
    66
            ('view_workspace', 'Can view workspace'),
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
    67
        )
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
    68
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    69
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    70
class RenkanManager(models.Manager):
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
    71
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    72
    @transaction.atomic
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    73
    def create_renkan(self, creator, title='', content='', source_revision=None, workspace = None):
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    74
        new_renkan = Renkan()
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    75
        new_renkan.creator = creator
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
    76
        new_renkan_workspace_guid = None
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    77
        new_renkan_title = title
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    78
        new_renkan_content = content
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    79
        if workspace is not None:
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    80
            new_renkan.workspace = workspace
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    81
            new_renkan_workspace_guid = workspace.workspace_guid
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    82
        if source_revision is not None:
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    83
            new_renkan.source_revision = source_revision
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    84
            if not title:
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    85
                new_renkan_title = source_revision.title
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    86
            new_renkan_content = source_revision.content
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    87
        new_renkan.save()
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
    88
        creation_date =  timezone.now()
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    89
        initial_revision = Revision(parent_renkan=new_renkan)
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
    90
        initial_revision.title = new_renkan_title if new_renkan_title else "Untitled Renkan"
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
    91
        initial_revision.creation_date = creation_date
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
    92
        initial_revision.modification_date = creation_date
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    93
        initial_revision.creator = creator
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    94
        initial_revision.last_updated_by = creator
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
    95
        if new_renkan_content:
626
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    96
            new_renkan_content_dict = content_copy(new_renkan.validate_json_content(new_renkan_content))
112912309726 ensure that we change the ids of elements when copying/creating a new renkan
ymh <ymh.work@gmail.com>
parents: 621
diff changeset
    97
            new_renkan_content_dict["id"] = str(new_renkan.renkan_guid)
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
    98
            new_renkan_content_dict["created"] = str(creation_date)
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
    99
            new_renkan_content_dict["updated"] = str(creation_date)
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   100
        else:
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   101
            new_renkan_content_dict = {
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   102
                "id": str(new_renkan.renkan_guid),
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   103
                "title": initial_revision.title,
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   104
                "description": "",
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   105
                "created": str(creation_date),
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   106
                "updated": str(creation_date),
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   107
                "edges": [],
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   108
                "nodes": [],
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   109
                "users": [],
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   110
                "space_id": str(new_renkan_workspace_guid),
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   111
                "views": []
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   112
            }
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   113
        initial_revision.content = json.dumps(new_renkan_content_dict)
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   114
        initial_revision.save()
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   115
        return new_renkan
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   116
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   117
class Renkan(models.Model):
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   118
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   119
    renkan_guid = models.UUIDField(default=uuid.uuid4, editable=False, unique=True, blank=False, null=False)
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   120
    workspace = models.ForeignKey('renkanmanager.Workspace', null=True, blank=True, on_delete=models.CASCADE, related_name="renkans")
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   121
    current_revision = models.ForeignKey('renkanmanager.Revision', null=True, blank=True, on_delete=models.SET_NULL, related_name='+')
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   122
    source_revision = models.ForeignKey('renkanmanager.Revision', null=True, blank=True, on_delete=models.SET_NULL, related_name='copies')
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   123
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   124
    creator = models.ForeignKey(auth_user_model, blank=True, null=True, related_name="renkan_creator")
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   125
    creation_date = models.DateTimeField(auto_now_add=True)
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   126
    state = models.IntegerField(default=1)
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   127
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   128
    objects = RenkanManager()
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   129
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   130
    @property
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   131
    def revision_count(self):
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   132
        return self.revisions.all().count()
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   133
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   134
    @property
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   135
    def workspace_guid(self):
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   136
        return self.workspace and self.workspace.workspace_guid
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   137
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   138
    @property
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   139
    def current_revision_guid(self):
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   140
        return self.current_revision and self.current_revision.revision_guid
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   141
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   142
    @property
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   143
    def source_revision_guid(self):
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   144
        return self.source_revision and self.source_revision.revision_guid
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   145
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   146
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   147
    @property
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   148
    def is_copy(self):
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   149
        return bool(self.source_revision)
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   150
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   151
    # Current revision title
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   152
    @property
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   153
    def title(self):
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   154
        return self.current_revision and self.current_revision.title or ''
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   155
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   156
    # Current revision content
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   157
    @property
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   158
    def content(self):
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   159
        return self.current_revision and self.current_revision.content or ''
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   160
611
f0f07e2b841f serverside: translation + timestamp handling + logging
durandn
parents: 610
diff changeset
   161
    def __str__(self):
621
192ce5938726 Correct renkan manager admin
ymh <ymh.work@gmail.com>
parents: 618
diff changeset
   162
        return str(self.renkan_guid)
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   163
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   164
    @transaction.atomic
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   165
    def save_renkan(self, updator, timestamp="", title="", content="", create_new_revision=False):
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   166
        """
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   167
            Saves over current revision or saves a new revision entirely.
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   168
            Timestamp must be the current revision modification_date.
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   169
        """
618
3051b847c124 validation_timestamp and create_new_revision are not part of the data. move them to query parameters
ymh <ymh.work@gmail.com>
parents: 616
diff changeset
   170
        if (not timestamp) or ((self.current_revision is not None) and timestamp != self.current_revision.modification_date):
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   171
            logger.error("SAVING RENKAN: provided timestamp is %r, which isn't current revision modification_date %r", timestamp, self.current_revision.modification_date)
611
f0f07e2b841f serverside: translation + timestamp handling + logging
durandn
parents: 610
diff changeset
   172
            raise ValidationError(_("Cannot save, provided timestamp is invalid"))
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   173
        else:
618
3051b847c124 validation_timestamp and create_new_revision are not part of the data. move them to query parameters
ymh <ymh.work@gmail.com>
parents: 616
diff changeset
   174
            dt_timestamp = timestamp
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   175
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   176
        if create_new_revision:
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   177
            revision_to_update = Revision(parent_renkan=self)
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   178
            revision_to_update.creator = updator
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   179
        else:
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   180
            revision_to_update = Revision.objects.select_for_update().get(id=self.current_revision.id)
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   181
610
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   182
        updated_content = self.validate_json_content(content) if content else current_revision.content
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   183
        updated_content_dict = json.loads(updated_content)
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   184
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   185
        # If title is passed as arg to the method, update the title in the json
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   186
        if title:
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   187
            updated_title = title
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   188
            updated_content_dict["title"] = title
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   189
        # If it is not, we use the one in the json instead
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   190
        else:
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   191
            updated_title = updated_content_dict["title"]
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   192
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   193
        revision_to_update.modification_date = timezone.now()
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   194
        updated_content_dict["updated"] = str(revision_to_update.modification_date)
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   195
        updated_content = json.dumps(updated_content_dict)
609
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   196
        revision_to_update.title = updated_title
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   197
        revision_to_update.content = updated_content
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   198
        if dt_timestamp == revision_to_update.modification_date:
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   199
            revision_to_update.modification_date += datetime.resolution
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   200
        revision_to_update.last_updated_by = updator
854a027c80ff models refactoring to use ForeignKey fields + associated migrations
durandn
parents: 589
diff changeset
   201
        revision_to_update.save()
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   202
        self.save()
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   203
610
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   204
    def validate_json_content(self, content):
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   205
        """
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   206
            Checks that the json content is valid (keys and structures), raise a ValidationError if format is wrong or value is wrong (for ids),
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   207
            if a key is missing, autocompletes with the empty default value
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   208
610
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   209
            Returns the validated json string
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   210
        """
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   211
        try:
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   212
            content_to_validate_dict = json.loads(content)
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   213
        except ValueError:
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   214
            raise ValidationError("Provided content to create Renkan is not a JSON-serializable")
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   215
        if "id" not in content_to_validate_dict or content_to_validate_dict["id"] == "" :
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   216
            content_to_validate_dict["id"] = str(self.renkan_guid)
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   217
        if "title" not in content_to_validate_dict:
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   218
            content_to_validate_dict["title"] = ""
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   219
        if "description" not in content_to_validate_dict:
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   220
            content_to_validate_dict["description"] = ""
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   221
        if "created" not in content_to_validate_dict:
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   222
            content_to_validate_dict["description"] = ""
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   223
        if "updated" not in content_to_validate_dict:
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   224
            content_to_validate_dict["description"] = ""
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   225
        expected_workspace_id = str(self.workspace.workspace_guid) if self.workspace is not None else ""
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   226
        if "space_id" not in content_to_validate_dict:
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   227
            content_to_validate_dict["space_id"] = expected_workspace_id
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   228
        if "nodes" not in content_to_validate_dict:
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   229
            content_to_validate_dict["nodes"] = []
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   230
        if "edges" not in content_to_validate_dict:
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   231
            content_to_validate_dict["edges"] = []
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   232
        if "views" not in content_to_validate_dict:
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   233
            content_to_validate_dict["views"] = []
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   234
        if "users" not in content_to_validate_dict:
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   235
            content_to_validate_dict["users"] = []
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   236
610
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   237
        if type(content_to_validate_dict["nodes"]) is not list:
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   238
            raise ValidationError("Provided content has an invalid 'nodes' key: not a list")
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   239
        if type(content_to_validate_dict["edges"]) is not list:
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   240
            raise ValidationError("Provided content has an invalid 'edges' key: not a list")
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   241
        if type(content_to_validate_dict["views"]) is not list:
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   242
            raise ValidationError("Provided content has an invalid 'views' key: not a list")
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   243
        if type(content_to_validate_dict["users"]) is not list:
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   244
            raise ValidationError("Provided content has an invalid 'users' key: not a list")
b9edc1c1538a reworked views and serializers to pass and take into account the "validation timestamp" to the model + refactored models to have a content validation method + adapted tests
durandn
parents: 609
diff changeset
   245
        return json.dumps(content_to_validate_dict)
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   246
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   247
    class Meta:
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   248
        app_label = 'renkanmanager'
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   249
        permissions = (
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   250
            ('view_renkan', 'Can view renkan'),
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   251
        )
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   252
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   253
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   254
class Revision(models.Model):
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   255
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   256
    revision_guid = models.UUIDField(default=uuid.uuid4, editable=False, unique=True, blank=False, null=False)
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   257
    parent_renkan = models.ForeignKey('renkanmanager.Renkan', on_delete=models.CASCADE, related_name="revisions")
588
95536fa18d0d Minor adjustements to properly interact with Renkan client
durandn
parents: 587
diff changeset
   258
    title = models.CharField(max_length=1024, null=True, blank=True)
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   259
    content = models.TextField(blank=True, null=True)
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   260
    creator = models.ForeignKey(auth_user_model, blank=True, null=True, related_name="revision_creator")
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   261
    last_updated_by = models.ForeignKey(auth_user_model, blank=True, null=True, related_name="revision_last_updated_by")
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   262
    creation_date = models.DateTimeField(auto_now_add=True, editable=False)
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   263
    modification_date = models.DateTimeField()
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   264
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   265
    @property
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   266
    def parent_renkan_guid(self):
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   267
        return self.parent_renkan and self.parent_renkan.renkan_guid
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   268
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   269
    @property
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   270
    def is_current_revision(self):
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   271
        return self == self.parent_renkan.current_revision
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   272
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   273
    class Meta:
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   274
        app_label = 'renkanmanager'
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   275
        ordering = ['-modification_date']
587
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   276
        permissions = (
fb0041aa74d3 transfer work on renkanmanager into a renkan/server/python2 folder: reworked models, implemented simple API basic permissions, wrote tests
durandn
parents:
diff changeset
   277
            ('view_revision', 'Can view revision'),
614
23416a833ca8 Change guid fields to more optimal type + migration
ymh <ymh.work@gmail.com>
parents: 611
diff changeset
   278
        )
615
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   279
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   280
    def __str__(self):
f3875fbe206a redo foreign key for renkanmanager, optimize property access, correct unit tests
ymh <ymh.work@gmail.com>
parents: 614
diff changeset
   281
        return str(self.revision_guid)