增加了加入小组的功能
This commit is contained in:
@@ -22,7 +22,6 @@ class Migration(migrations.Migration):
|
|||||||
('join_group_setting', models.IntegerField()),
|
('join_group_setting', models.IntegerField()),
|
||||||
('visible', models.BooleanField(default=True)),
|
('visible', models.BooleanField(default=True)),
|
||||||
('admin', models.ForeignKey(related_name='my_groups', to=settings.AUTH_USER_MODEL)),
|
('admin', models.ForeignKey(related_name='my_groups', to=settings.AUTH_USER_MODEL)),
|
||||||
('members', models.ManyToManyField(to=settings.AUTH_USER_MODEL)),
|
|
||||||
],
|
],
|
||||||
options={
|
options={
|
||||||
'db_table': 'group',
|
'db_table': 'group',
|
||||||
@@ -42,4 +41,21 @@ class Migration(migrations.Migration):
|
|||||||
'db_table': 'join_group_request',
|
'db_table': 'join_group_request',
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='UserGroupRelation',
|
||||||
|
fields=[
|
||||||
|
('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)),
|
||||||
|
('join_time', models.DateTimeField(auto_now_add=True)),
|
||||||
|
('group', models.ForeignKey(to='group.Group')),
|
||||||
|
('user', models.ForeignKey(to=settings.AUTH_USER_MODEL)),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'db_table': 'user_group_relation',
|
||||||
|
},
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='group',
|
||||||
|
name='members',
|
||||||
|
field=models.ManyToManyField(to=settings.AUTH_USER_MODEL, through='group.UserGroupRelation'),
|
||||||
|
),
|
||||||
]
|
]
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ class Group(models.Model):
|
|||||||
admin = models.ForeignKey(User, related_name="my_groups")
|
admin = models.ForeignKey(User, related_name="my_groups")
|
||||||
# 0是公开 1是需要申请后加入 2是不允许任何人加入
|
# 0是公开 1是需要申请后加入 2是不允许任何人加入
|
||||||
join_group_setting = models.IntegerField()
|
join_group_setting = models.IntegerField()
|
||||||
members = models.ManyToManyField(User)
|
members = models.ManyToManyField(User, through="UserGroupRelation")
|
||||||
# 解散小组后,这一项改为False
|
# 解散小组后,这一项改为False
|
||||||
visible = models.BooleanField(default=True)
|
visible = models.BooleanField(default=True)
|
||||||
|
|
||||||
@@ -19,6 +19,15 @@ class Group(models.Model):
|
|||||||
db_table = "group"
|
db_table = "group"
|
||||||
|
|
||||||
|
|
||||||
|
class UserGroupRelation(models.Model):
|
||||||
|
group = models.ForeignKey(Group)
|
||||||
|
user = models.ForeignKey(User)
|
||||||
|
join_time = models.DateTimeField(auto_now_add=True)
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
db_table = "user_group_relation"
|
||||||
|
|
||||||
|
|
||||||
class JoinGroupRequest(models.Model):
|
class JoinGroupRequest(models.Model):
|
||||||
group = models.ForeignKey(User)
|
group = models.ForeignKey(User)
|
||||||
user = models.ForeignKey(User, related_name="my_join_group_requests")
|
user = models.ForeignKey(User, related_name="my_join_group_requests")
|
||||||
|
|||||||
@@ -24,4 +24,4 @@ class JoinGroupRequestSerializer(serializers.Serializer):
|
|||||||
class GroupSerializer(serializers.ModelSerializer):
|
class GroupSerializer(serializers.ModelSerializer):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Group
|
model = Group
|
||||||
exclude = ["members"]
|
exclude = ["members"]
|
||||||
|
|||||||
@@ -5,8 +5,9 @@ from rest_framework.views import APIView
|
|||||||
|
|
||||||
from utils.shortcuts import error_response, serializer_invalid_response, success_response, paginate
|
from utils.shortcuts import error_response, serializer_invalid_response, success_response, paginate
|
||||||
from account.models import REGULAR_USER, ADMIN, SUPER_ADMIN
|
from account.models import REGULAR_USER, ADMIN, SUPER_ADMIN
|
||||||
|
from account.decorators import login_required
|
||||||
|
|
||||||
from .models import Group, JoinGroupRequest
|
from .models import Group, JoinGroupRequest, UserGroupRelation
|
||||||
from .serializers import (CreateGroupSerializer, EditGroupSerializer,
|
from .serializers import (CreateGroupSerializer, EditGroupSerializer,
|
||||||
JoinGroupRequestSerializer, GroupSerializer)
|
JoinGroupRequestSerializer, GroupSerializer)
|
||||||
|
|
||||||
@@ -53,6 +54,8 @@ class GroupAdminAPIView(APIView):
|
|||||||
def get(self, request):
|
def get(self, request):
|
||||||
"""
|
"""
|
||||||
查询小组列表或者单个小组的信息
|
查询小组列表或者单个小组的信息
|
||||||
|
---
|
||||||
|
response_serializer: GroupSerializer
|
||||||
"""
|
"""
|
||||||
group_id = request.GET.get("group_id", None)
|
group_id = request.GET.get("group_id", None)
|
||||||
if group_id:
|
if group_id:
|
||||||
@@ -69,4 +72,32 @@ class GroupAdminAPIView(APIView):
|
|||||||
groups = Group.objects.filter(visible=True)
|
groups = Group.objects.filter(visible=True)
|
||||||
else:
|
else:
|
||||||
groups = Group.objects.filter(admin=request.user, visible=True)
|
groups = Group.objects.filter(admin=request.user, visible=True)
|
||||||
return paginate(request, groups, GroupSerializer)
|
return paginate(request, groups, GroupSerializer)
|
||||||
|
|
||||||
|
|
||||||
|
def join_group(user, group):
|
||||||
|
return UserGroupRelation.objects.create(user=user, group=group)
|
||||||
|
|
||||||
|
|
||||||
|
class JoinGroupAPIView(APIView):
|
||||||
|
@login_required
|
||||||
|
def post(self, request):
|
||||||
|
serializer = JoinGroupRequestSerializer(data=request.data)
|
||||||
|
if serializer.is_valid():
|
||||||
|
data = serializer.data
|
||||||
|
try:
|
||||||
|
group = Grouo.objects.get(id=data["group"])
|
||||||
|
except Group.DesoNotExist:
|
||||||
|
return error_response(u"小组不存在")
|
||||||
|
if group.join_group_setting == 0:
|
||||||
|
join_group(request.user, group)
|
||||||
|
return success_response(u"你已经成功的加入该小组")
|
||||||
|
elif group.join_group_setting == 1:
|
||||||
|
return success_response(u"申请提交成功,请等待审核")
|
||||||
|
elif group.join_group_setting == 2:
|
||||||
|
return error_response(u"该小组不允许任何人加入")
|
||||||
|
else:
|
||||||
|
return serializer_invalid_response(serializer)
|
||||||
|
|
||||||
|
def get(self, request):
|
||||||
|
pass
|
||||||
Reference in New Issue
Block a user