mirror of
https://github.com/Ocelot-Social-Community/Ocelot-Social.git
synced 2025-12-13 07:46:06 +00:00
notify user when role in group changed
This commit is contained in:
parent
1501bcb06c
commit
35f3da9984
@ -73,6 +73,17 @@ const handleLeaveGroup = async (resolve, root, args, context, resolveInfo) => {
|
|||||||
return user
|
return user
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const handleChangeGroupMemberRole = async (resolve, root, args, context, resolveInfo) => {
|
||||||
|
const { groupId, userId } = args
|
||||||
|
const user = await resolve(root, args, context, resolveInfo)
|
||||||
|
if (user) {
|
||||||
|
await publishNotifications(context, [
|
||||||
|
notifyMemberOfGroup(groupId, userId, 'changed_group_member_role', context),
|
||||||
|
])
|
||||||
|
}
|
||||||
|
return user
|
||||||
|
}
|
||||||
|
|
||||||
const handleContentDataOfPost = async (resolve, root, args, context, resolveInfo) => {
|
const handleContentDataOfPost = async (resolve, root, args, context, resolveInfo) => {
|
||||||
const idsOfUsers = extractMentionedUsers(args.content)
|
const idsOfUsers = extractMentionedUsers(args.content)
|
||||||
const post = await resolve(root, args, context, resolveInfo)
|
const post = await resolve(root, args, context, resolveInfo)
|
||||||
@ -148,6 +159,37 @@ const notifyOwnersOfGroup = async (groupId, userId, reason, context) => {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const notifyMemberOfGroup = async (groupId, userId, reason, context) => {
|
||||||
|
const cypher = `
|
||||||
|
MATCH (group:Group { id: $groupId })<-[membership:MEMBER_OF]-(user:User { id: $userId })
|
||||||
|
WITH user, group
|
||||||
|
MERGE (group)-[notification:NOTIFIED {reason: $reason}]->(user)
|
||||||
|
WITH group, user, notification
|
||||||
|
SET notification.read = FALSE
|
||||||
|
SET notification.createdAt = COALESCE(notification.createdAt, toString(datetime()))
|
||||||
|
SET notification.updatedAt = toString(datetime())
|
||||||
|
SET notification.relatedUserId = $userId
|
||||||
|
RETURN notification {.*, from: group, to: properties(user)}
|
||||||
|
`
|
||||||
|
const session = context.driver.session()
|
||||||
|
const writeTxResultPromise = session.writeTransaction(async (transaction) => {
|
||||||
|
const notificationTransactionResponse = await transaction.run(cypher, {
|
||||||
|
groupId,
|
||||||
|
reason,
|
||||||
|
userId,
|
||||||
|
})
|
||||||
|
return notificationTransactionResponse.records.map((record) => record.get('notification'))
|
||||||
|
})
|
||||||
|
try {
|
||||||
|
const notifications = await writeTxResultPromise
|
||||||
|
return notifications
|
||||||
|
} catch (error) {
|
||||||
|
throw new Error(error)
|
||||||
|
} finally {
|
||||||
|
session.close()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const notifyUsersOfMention = async (label, id, idsOfUsers, reason, context) => {
|
const notifyUsersOfMention = async (label, id, idsOfUsers, reason, context) => {
|
||||||
if (!(idsOfUsers && idsOfUsers.length)) return []
|
if (!(idsOfUsers && idsOfUsers.length)) return []
|
||||||
await validateNotifyUsers(label, reason)
|
await validateNotifyUsers(label, reason)
|
||||||
@ -244,5 +286,6 @@ export default {
|
|||||||
UpdateComment: handleContentDataOfComment,
|
UpdateComment: handleContentDataOfComment,
|
||||||
JoinGroup: handleJoinGroup,
|
JoinGroup: handleJoinGroup,
|
||||||
LeaveGroup: handleLeaveGroup,
|
LeaveGroup: handleLeaveGroup,
|
||||||
|
ChangeGroupMemberRole: handleChangeGroupMemberRole,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|||||||
@ -7,7 +7,7 @@ import {
|
|||||||
createGroupMutation,
|
createGroupMutation,
|
||||||
joinGroupMutation,
|
joinGroupMutation,
|
||||||
leaveGroupMutation,
|
leaveGroupMutation,
|
||||||
// changeGroupMemberRoleMutation,
|
changeGroupMemberRoleMutation,
|
||||||
// removeUserFromGroupMutation,
|
// removeUserFromGroupMutation,
|
||||||
} from '../../graphql/groups'
|
} from '../../graphql/groups'
|
||||||
|
|
||||||
@ -763,5 +763,54 @@ describe('notifications', () => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
describe('user role in group changes', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
authenticatedUser = await notifiedUser.toJson()
|
||||||
|
await mutate({
|
||||||
|
mutation: joinGroupMutation(),
|
||||||
|
variables: {
|
||||||
|
groupId: 'closed-group',
|
||||||
|
userId: authenticatedUser.id,
|
||||||
|
},
|
||||||
|
})
|
||||||
|
authenticatedUser = await groupOwner.toJson()
|
||||||
|
await mutate({
|
||||||
|
mutation: changeGroupMemberRoleMutation(),
|
||||||
|
variables: {
|
||||||
|
groupId: 'closed-group',
|
||||||
|
userId: 'you',
|
||||||
|
roleInGroup: 'admin',
|
||||||
|
},
|
||||||
|
})
|
||||||
|
authenticatedUser = await notifiedUser.toJson()
|
||||||
|
})
|
||||||
|
|
||||||
|
it('has notification in database', async () => {
|
||||||
|
await expect(
|
||||||
|
query({
|
||||||
|
query: notificationQuery,
|
||||||
|
}),
|
||||||
|
).resolves.toMatchObject({
|
||||||
|
data: {
|
||||||
|
notifications: [
|
||||||
|
{
|
||||||
|
read: false,
|
||||||
|
reason: 'changed_group_member_role',
|
||||||
|
createdAt: expect.any(String),
|
||||||
|
from: {
|
||||||
|
__typename: 'Group',
|
||||||
|
id: 'closed-group',
|
||||||
|
},
|
||||||
|
relatedUser: {
|
||||||
|
id: 'you',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
errors: undefined,
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@ -24,6 +24,7 @@ enum NotificationReason {
|
|||||||
commented_on_post
|
commented_on_post
|
||||||
user_joined_group
|
user_joined_group
|
||||||
user_left_group
|
user_left_group
|
||||||
|
changed_group_member_role
|
||||||
}
|
}
|
||||||
|
|
||||||
type Query {
|
type Query {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user