add signIn mutation; create/update message only for auth user
This commit is contained in:
parent
489f6b539a
commit
1c4e2cbb2c
|
@ -11,6 +11,9 @@ from peewee import *
|
|||
|
||||
import asyncio
|
||||
|
||||
import auth_utils
|
||||
|
||||
|
||||
type_defs = load_schema_from_path("schema.graphql")
|
||||
|
||||
db = SqliteDatabase('discours.db')
|
||||
|
@ -19,6 +22,16 @@ class User(Model):
|
|||
username = CharField()
|
||||
email = CharField()
|
||||
createdAt = DateTimeField(default=datetime.now)
|
||||
muted = BooleanField(default=False)
|
||||
rating = IntegerField(default=0)
|
||||
# roles =
|
||||
updatedAt = DateTimeField(default=datetime.now)
|
||||
username = CharField()
|
||||
userpic = CharField(default="")
|
||||
userpicId = CharField(default="")
|
||||
wasOnlineAt = DateTimeField(default=datetime.now)
|
||||
|
||||
password = CharField()
|
||||
|
||||
class Meta:
|
||||
database = db
|
||||
|
@ -38,7 +51,11 @@ class Message(Model):
|
|||
db.connect()
|
||||
db.create_tables([User, Message])
|
||||
|
||||
#only_user = User.create(username = "admin", email = "knst.kotov@gmail.com")
|
||||
#only_user = User.create(
|
||||
# username = "admin",
|
||||
# email = "knst.kotov@gmail.com",
|
||||
# password = auth_utils.password_to_hash("12345")
|
||||
#)
|
||||
only_user = User.get(User.username == "admin")
|
||||
|
||||
|
||||
|
@ -65,17 +82,43 @@ def resolve_get_messages(_, info, count, page):
|
|||
|
||||
mutation = MutationType()
|
||||
|
||||
@mutation.field("signIn")
|
||||
def resolve_sign_in(_, info, email, password):
|
||||
try:
|
||||
user = User.get(User.email == email)
|
||||
except DoesNotExist as err:
|
||||
return {
|
||||
"status" : False,
|
||||
"error" : "invalid username or password"
|
||||
}
|
||||
|
||||
if auth_utils.verify_password(password, user.password) :
|
||||
return {
|
||||
"status" : True,
|
||||
"token" : auth_utils.jwt_encode(user)
|
||||
}
|
||||
|
||||
return {
|
||||
"status" : False,
|
||||
"error" : "invalid username or password"
|
||||
}
|
||||
|
||||
@mutation.field("createMessage")
|
||||
def resolve_create_message(_, info, input):
|
||||
request = info.context["request"]
|
||||
|
||||
try:
|
||||
user_id = auth_utils.authorize(request)
|
||||
user = User.get(User.id == user_id)
|
||||
|
||||
new_message = Message.create(
|
||||
author = only_user,
|
||||
author = user,
|
||||
body = input["body"],
|
||||
replyTo = input.get("replyTo")
|
||||
)
|
||||
except Exception as err:
|
||||
return {
|
||||
"status" : false,
|
||||
"status" : False,
|
||||
"message" : err
|
||||
}
|
||||
|
||||
|
@ -90,6 +133,17 @@ def resolve_create_message(_, info, input):
|
|||
|
||||
@mutation.field("updateMessage")
|
||||
def resolve_update_message(_, info, input):
|
||||
request = info.context["request"]
|
||||
|
||||
try:
|
||||
user_id = auth_utils.authorize(request)
|
||||
user = User.get(User.id == user_id)
|
||||
except Exception as err:
|
||||
return {
|
||||
"status" : False,
|
||||
"message" : err
|
||||
}
|
||||
|
||||
message_id = input["id"]
|
||||
body = input["body"]
|
||||
|
||||
|
@ -101,6 +155,12 @@ def resolve_update_message(_, info, input):
|
|||
|
||||
updated_message = all_messages[message_id]
|
||||
|
||||
if updated_message.author != user:
|
||||
return {
|
||||
"status" : False,
|
||||
"error" : "update this message denied"
|
||||
}
|
||||
|
||||
updated_message.body = body
|
||||
#updated_message.updatedAt = datetime.now
|
||||
try:
|
||||
|
|
136
schema.graphql
136
schema.graphql
|
@ -1,27 +1,11 @@
|
|||
scalar DateTime
|
||||
|
||||
type User {
|
||||
createdAt: DateTime!
|
||||
email: String
|
||||
emailConfirmed: Boolean
|
||||
id: Int!
|
||||
muted: Boolean
|
||||
rating: Int
|
||||
updatedAt: DateTime!
|
||||
username: String
|
||||
userpic: String
|
||||
userpicId: String
|
||||
wasOnlineAt: DateTime
|
||||
}
|
||||
|
||||
type Message {
|
||||
type Like {
|
||||
author: Int!
|
||||
body: String!
|
||||
createdAt: DateTime!
|
||||
id: Int!
|
||||
replyTo: Int
|
||||
updatedAt: DateTime!
|
||||
visibleForUsers: [Int]
|
||||
shout: Int
|
||||
user: Int
|
||||
value: Int!
|
||||
}
|
||||
|
||||
type createMessagePayload {
|
||||
|
@ -45,18 +29,126 @@ input updateMessageInput {
|
|||
body: String!
|
||||
}
|
||||
|
||||
type Query {
|
||||
getMessages(count: Int = 100, page: Int = 1): [Message!]!
|
||||
type Message {
|
||||
author: Int!
|
||||
body: String!
|
||||
createdAt: DateTime!
|
||||
id: Int!
|
||||
replyTo: Int
|
||||
updatedAt: DateTime!
|
||||
visibleForUsers: [Int]
|
||||
}
|
||||
|
||||
type signInPayload {
|
||||
status: Boolean!
|
||||
error: String
|
||||
token: String
|
||||
}
|
||||
|
||||
type Mutation {
|
||||
# message
|
||||
createMessage(input: MessageInput!): createMessagePayload!
|
||||
updateMessage(input: updateMessageInput!): createMessagePayload!
|
||||
deleteMessage(messageId: Int!): deleteMessagePayload!
|
||||
|
||||
# auth
|
||||
confirmEmail(token: String!): Token!
|
||||
invalidateAllTokens: Boolean!
|
||||
invalidateTokenById(id: Int!): Boolean!
|
||||
requestEmailConfirmation: User!
|
||||
requestPasswordReset(email: String!): Boolean!
|
||||
resetPassword(password: String!, token: String!): Token!
|
||||
signIn(email: String!, password: String!): signInPayload!
|
||||
signUp(email: String!, password: String!, username: String): User!
|
||||
|
||||
# shout
|
||||
createShout(body: String!, replyTo: [Int], title: String, versionOf: [Int], visibleForRoles: [Int], visibleForUsers: [Int]): Message!
|
||||
deleteShout(shoutId: Int!): Message!
|
||||
rateShout(value: Int!): Boolean!
|
||||
|
||||
# profile
|
||||
rateUser(value: Int!): Boolean!
|
||||
updateOnlineStatus: Boolean!
|
||||
updateUsername(username: String!): User!
|
||||
}
|
||||
|
||||
type Query {
|
||||
getCurrentUser: User!
|
||||
getMessages(count: Int = 100, page: Int = 1): [Message!]!
|
||||
getOnline: [User!]!
|
||||
getShoutRating(shout: Int): Int!
|
||||
getTokens: [Token!]!
|
||||
getUserById(id: Int!): User!
|
||||
getUserRating(shout: Int): Int!
|
||||
isUsernameFree(username: String!): Boolean!
|
||||
shoutsByAuthor(author: Int): [Shout]!
|
||||
shoutsByReplyTo(shout: Int): [Shout]!
|
||||
shoutsByTags(tags: [String]): [Shout]!
|
||||
shoutsByTime(time: DateTime): [Shout]!
|
||||
topAuthors: [User]!
|
||||
topShouts: [Shout]!
|
||||
}
|
||||
|
||||
type Role {
|
||||
id: Int!
|
||||
name: String!
|
||||
}
|
||||
|
||||
type Shout {
|
||||
author: Int!
|
||||
body: String!
|
||||
createdAt: DateTime!
|
||||
deletedAt: DateTime
|
||||
deletedBy: Int
|
||||
id: Int!
|
||||
rating: Int
|
||||
published: DateTime! # if there is no published field - it is not published
|
||||
replyTo: Int # another shout
|
||||
tags: [String]
|
||||
title: String
|
||||
updatedAt: DateTime!
|
||||
versionOf: Int
|
||||
visibleForRoles: [Role]!
|
||||
visibleForUsers: [Int]
|
||||
}
|
||||
|
||||
type Proposal {
|
||||
body: String!
|
||||
shout: Int!
|
||||
range: String # full / 0:2340
|
||||
author: Int!
|
||||
createdAt: DateTime!
|
||||
}
|
||||
|
||||
type Subscription {
|
||||
messageCreated: Message!
|
||||
messageUpdated: Message!
|
||||
messageDeleted: Message!
|
||||
onlineUpdated: [User!]!
|
||||
shoutUpdated: Shout!
|
||||
userUpdated: User!
|
||||
}
|
||||
|
||||
type Token {
|
||||
createdAt: DateTime!
|
||||
expiresAt: DateTime
|
||||
id: Int!
|
||||
ownerId: Int!
|
||||
usedAt: DateTime
|
||||
value: String!
|
||||
}
|
||||
|
||||
type User {
|
||||
createdAt: DateTime!
|
||||
email: String
|
||||
emailConfirmed: Boolean
|
||||
id: Int!
|
||||
muted: Boolean
|
||||
rating: Int
|
||||
roles: [Role!]!
|
||||
updatedAt: DateTime!
|
||||
username: String
|
||||
userpic: String
|
||||
userpicId: String
|
||||
wasOnlineAt: DateTime
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue
Block a user