add signIn mutation; create/update message only for auth user

This commit is contained in:
knst-kotov 2021-06-27 12:56:33 +00:00
parent 489f6b539a
commit 1c4e2cbb2c
2 changed files with 217 additions and 65 deletions

View File

@ -11,6 +11,9 @@ from peewee import *
import asyncio import asyncio
import auth_utils
type_defs = load_schema_from_path("schema.graphql") type_defs = load_schema_from_path("schema.graphql")
db = SqliteDatabase('discours.db') db = SqliteDatabase('discours.db')
@ -19,6 +22,16 @@ class User(Model):
username = CharField() username = CharField()
email = CharField() email = CharField()
createdAt = DateTimeField(default=datetime.now) 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: class Meta:
database = db database = db
@ -38,7 +51,11 @@ class Message(Model):
db.connect() db.connect()
db.create_tables([User, Message]) 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") only_user = User.get(User.username == "admin")
@ -65,17 +82,43 @@ def resolve_get_messages(_, info, count, page):
mutation = MutationType() 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") @mutation.field("createMessage")
def resolve_create_message(_, info, input): def resolve_create_message(_, info, input):
request = info.context["request"]
try: try:
user_id = auth_utils.authorize(request)
user = User.get(User.id == user_id)
new_message = Message.create( new_message = Message.create(
author = only_user, author = user,
body = input["body"], body = input["body"],
replyTo = input.get("replyTo") replyTo = input.get("replyTo")
) )
except Exception as err: except Exception as err:
return { return {
"status" : false, "status" : False,
"message" : err "message" : err
} }
@ -90,6 +133,17 @@ def resolve_create_message(_, info, input):
@mutation.field("updateMessage") @mutation.field("updateMessage")
def resolve_update_message(_, info, input): 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"] message_id = input["id"]
body = input["body"] body = input["body"]
@ -101,6 +155,12 @@ def resolve_update_message(_, info, input):
updated_message = all_messages[message_id] 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.body = body
#updated_message.updatedAt = datetime.now #updated_message.updatedAt = datetime.now
try: try:

View File

@ -1,62 +1,154 @@
scalar DateTime scalar DateTime
type User { type Like {
createdAt: DateTime! author: Int!
email: String id: Int!
emailConfirmed: Boolean shout: Int
id: Int! user: Int
muted: Boolean value: Int!
rating: Int }
updatedAt: DateTime!
username: String type createMessagePayload {
userpic: String status: Boolean!
userpicId: String error: String
wasOnlineAt: DateTime message: Message
} }
type Message { type deleteMessagePayload {
author: Int! status: Boolean!
body: String! error: String
createdAt: DateTime! }
id: Int!
replyTo: Int input MessageInput {
updatedAt: DateTime! body: String!
visibleForUsers: [Int] replyTo: Int
} }
type createMessagePayload { input updateMessageInput {
status: Boolean! id: Int!
error: String body: String!
message: Message }
}
type Message {
type deleteMessagePayload { author: Int!
status: Boolean! body: String!
error: String createdAt: DateTime!
} id: Int!
replyTo: Int
input MessageInput { updatedAt: DateTime!
body: String! visibleForUsers: [Int]
replyTo: Int }
}
type signInPayload {
input updateMessageInput { status: Boolean!
id: Int! error: String
body: String! token: String
} }
type Query { type Mutation {
getMessages(count: Int = 100, page: Int = 1): [Message!]! # message
} createMessage(input: MessageInput!): createMessagePayload!
updateMessage(input: updateMessageInput!): createMessagePayload!
type Mutation { deleteMessage(messageId: Int!): deleteMessagePayload!
createMessage(input: MessageInput!): createMessagePayload!
updateMessage(input: updateMessageInput!): createMessagePayload! # auth
deleteMessage(messageId: Int!): deleteMessagePayload! confirmEmail(token: String!): Token!
} invalidateAllTokens: Boolean!
invalidateTokenById(id: Int!): Boolean!
type Subscription { requestEmailConfirmation: User!
messageCreated: Message! requestPasswordReset(email: String!): Boolean!
messageUpdated: Message! resetPassword(password: String!, token: String!): Token!
messageDeleted: Message! 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
}