mirror of
https://github.com/Ocelot-Social-Community/Ocelot-Social.git
synced 2025-12-13 07:46:06 +00:00
handle seen prop
This commit is contained in:
parent
2ea77b784d
commit
9f1f028454
@ -32,3 +32,11 @@ export const messageQuery = () => {
|
|||||||
}
|
}
|
||||||
`
|
`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export const markMessagesAsSeen = () => {
|
||||||
|
return gql`
|
||||||
|
mutation ($messageIds: [String!]) {
|
||||||
|
MarkMessagesAsSeen(messageIds: $messageIds)
|
||||||
|
}
|
||||||
|
`
|
||||||
|
}
|
||||||
|
|||||||
@ -463,6 +463,7 @@ export default shield(
|
|||||||
saveCategorySettings: isAuthenticated,
|
saveCategorySettings: isAuthenticated,
|
||||||
CreateRoom: isAuthenticated,
|
CreateRoom: isAuthenticated,
|
||||||
CreateMessage: isAuthenticated,
|
CreateMessage: isAuthenticated,
|
||||||
|
MarkMessagesAsSeen: isAuthenticated,
|
||||||
},
|
},
|
||||||
User: {
|
User: {
|
||||||
email: or(isMyOwn, isAdmin),
|
email: or(isMyOwn, isAdmin),
|
||||||
|
|||||||
@ -2,7 +2,7 @@ import { createTestClient } from 'apollo-server-testing'
|
|||||||
import Factory, { cleanDatabase } from '../../db/factories'
|
import Factory, { cleanDatabase } from '../../db/factories'
|
||||||
import { getNeode, getDriver } from '../../db/neo4j'
|
import { getNeode, getDriver } from '../../db/neo4j'
|
||||||
import { createRoomMutation } from '../../graphql/rooms'
|
import { createRoomMutation } from '../../graphql/rooms'
|
||||||
import { createMessageMutation, messageQuery } from '../../graphql/messages'
|
import { createMessageMutation, messageQuery, markMessagesAsSeen } from '../../graphql/messages'
|
||||||
import createServer from '../../server'
|
import createServer from '../../server'
|
||||||
|
|
||||||
const driver = getDriver()
|
const driver = getDriver()
|
||||||
@ -323,4 +323,74 @@ describe('Message', () => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
describe('marks massges as seen', () => {
|
||||||
|
describe('unauthenticated', () => {
|
||||||
|
beforeAll(() => {
|
||||||
|
authenticatedUser = null
|
||||||
|
})
|
||||||
|
|
||||||
|
it('throws authorization error', async () => {
|
||||||
|
await expect(
|
||||||
|
mutate({
|
||||||
|
mutation: markMessagesAsSeen(),
|
||||||
|
variables: {
|
||||||
|
messageIds: ['some-id'],
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
).resolves.toMatchObject({
|
||||||
|
errors: [{ message: 'Not Authorized!' }],
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('authenticated', () => {
|
||||||
|
const messageIds: string[] = []
|
||||||
|
beforeAll(async () => {
|
||||||
|
authenticatedUser = await otherChattingUser.toJson()
|
||||||
|
const msgs = await query({
|
||||||
|
query: messageQuery(),
|
||||||
|
variables: {
|
||||||
|
roomId,
|
||||||
|
},
|
||||||
|
})
|
||||||
|
msgs.data.Message.forEach((m) => messageIds.push(m.id))
|
||||||
|
})
|
||||||
|
|
||||||
|
it('returns true', async () => {
|
||||||
|
await expect(
|
||||||
|
mutate({
|
||||||
|
mutation: markMessagesAsSeen(),
|
||||||
|
variables: {
|
||||||
|
messageIds,
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
).resolves.toMatchObject({
|
||||||
|
errors: undefined,
|
||||||
|
data: {
|
||||||
|
MarkMessagesAsSeen: true,
|
||||||
|
},
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('has seen prop set to true', async () => {
|
||||||
|
await expect(
|
||||||
|
query({
|
||||||
|
query: messageQuery(),
|
||||||
|
variables: {
|
||||||
|
roomId,
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
).resolves.toMatchObject({
|
||||||
|
data: {
|
||||||
|
Message: [
|
||||||
|
expect.objectContaining({ seen: true }),
|
||||||
|
expect.objectContaining({ seen: true }),
|
||||||
|
expect.objectContaining({ seen: true }),
|
||||||
|
],
|
||||||
|
},
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@ -89,6 +89,29 @@ export default {
|
|||||||
session.close()
|
session.close()
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
MarkMessagesAsSeen: async (_parent, params, context, _resolveInfo) => {
|
||||||
|
const { messageIds } = params
|
||||||
|
const session = context.driver.session()
|
||||||
|
const writeTxResultPromise = session.writeTransaction(async (transaction) => {
|
||||||
|
const setSeenCypher = `
|
||||||
|
MATCH (m:Message) WHERE m.id IN $messageIds
|
||||||
|
SET m.seen = true
|
||||||
|
RETURN m { .* }
|
||||||
|
`
|
||||||
|
const setSeenTxResponse = await transaction.run(setSeenCypher, {
|
||||||
|
messageIds,
|
||||||
|
})
|
||||||
|
const messages = await setSeenTxResponse.records.map((record) => record.get('m'))
|
||||||
|
return messages
|
||||||
|
})
|
||||||
|
try {
|
||||||
|
await writeTxResultPromise
|
||||||
|
// send subscription to author to updated the messages
|
||||||
|
return true
|
||||||
|
} finally {
|
||||||
|
session.close()
|
||||||
|
}
|
||||||
|
},
|
||||||
},
|
},
|
||||||
Message: {
|
Message: {
|
||||||
...Resolver('Message', {
|
...Resolver('Message', {
|
||||||
|
|||||||
@ -27,6 +27,8 @@ type Mutation {
|
|||||||
roomId: ID!
|
roomId: ID!
|
||||||
content: String!
|
content: String!
|
||||||
): Message
|
): Message
|
||||||
|
|
||||||
|
MarkMessagesAsSeen(messageIds: [String!]): Boolean
|
||||||
}
|
}
|
||||||
|
|
||||||
type Query {
|
type Query {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user