forked from fossasia/open-event-server
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathuser_emails.py
More file actions
121 lines (102 loc) · 3.09 KB
/
user_emails.py
File metadata and controls
121 lines (102 loc) · 3.09 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
from flask_rest_jsonapi import ResourceDetail, ResourceList, ResourceRelationship
from app.api.bootstrap import api
from app.api.helpers.db import get_count, safe_query_kwargs
from app.api.helpers.errors import ConflictError
from app.api.helpers.utilities import require_relationship
from app.api.schema.user_email import UserEmailSchema
from app.models import db
from app.models.user import User
from app.models.user_email import UserEmail
class UserEmailListAdmin(ResourceList):
"""
Admin List for User Emails
"""
methods = [
'GET',
]
schema = UserEmailSchema
decorators = (api.has_permission('is_admin'),)
data_layer = {'session': db.session, 'model': UserEmail}
class UserEmailList(ResourceList):
"""
List User Emails for a user
"""
def query(self, view_kwargs):
"""
query method for Notifications list
:param view_kwargs:
:return:
"""
query_ = self.session.query(UserEmail)
if view_kwargs.get('user_id'):
user = safe_query_kwargs(User, view_kwargs, 'user_id')
query_ = query_.join(User).filter(User.id == user.id)
return query_
view_kwargs = True
decorators = (
api.has_permission(
'is_user_itself', fetch="user_id", model=UserEmail, methods="GET"
),
)
methods = [
"GET",
]
schema = UserEmailSchema
data_layer = {'session': db.session, 'model': UserEmail, 'methods': {'query': query}}
class UserEmailListPost(ResourceList):
"""
Create new alternate email for a user
"""
def before_post(self, args, kwargs, data):
"""
before post method to check for required relationship and proper permission
:param args:
:param kwargs:
:param data:
:return:
"""
require_relationship(['user'], data)
if (
get_count(
db.session.query(UserEmail.id).filter_by(
email_address=data.get('email-address'),
user_id=int(data['user']),
deleted_at=None,
)
)
> 0
):
raise ConflictError(
{'pointer': '/data/attributes/name'}, "Email already exists"
)
schema = UserEmailSchema
methods = [
'POST',
]
data_layer = {'session': db.session, 'model': UserEmail}
class UserEmailDetail(ResourceDetail):
"""
User Email detail by id
"""
schema = UserEmailSchema
decorators = (
api.has_permission(
'is_user_itself',
fetch='user_id',
fetch_as="user_id",
model=UserEmail,
methods="PATCH,DELETE",
),
)
data_layer = {'session': db.session, 'model': UserEmail}
class UserEmailRelationship(ResourceRelationship):
"""
User Email Relationship
"""
decorators = (
api.has_permission(
'is_user_itself', fetch='user_id', model=UserEmail, methods="GET"
),
)
schema = UserEmailSchema
data_layer = {'session': db.session, 'model': UserEmail}