mirror of
https://github.com/IT4Change/gradido.git
synced 2025-12-13 07:45:54 +00:00
Merge pull request #2885 from gradido/2785-remove-email-from-subscribe-unsubscribe
fix(backend): subscription get's email and languages from user
This commit is contained in:
commit
184de4672e
@ -1,10 +0,0 @@
|
|||||||
import { ArgsType, Field } from 'type-graphql'
|
|
||||||
|
|
||||||
@ArgsType()
|
|
||||||
export default class SubscribeNewsletterArgs {
|
|
||||||
@Field(() => String)
|
|
||||||
email: string
|
|
||||||
|
|
||||||
@Field(() => String)
|
|
||||||
language: string
|
|
||||||
}
|
|
||||||
@ -1,7 +1,5 @@
|
|||||||
/* eslint-disable @typescript-eslint/no-unsafe-return */
|
/* eslint-disable @typescript-eslint/no-unsafe-return */
|
||||||
import { Resolver, Query, Authorized, Arg, Mutation, Args } from 'type-graphql'
|
import { Resolver, Query, Authorized, Arg, Mutation, Ctx } from 'type-graphql'
|
||||||
|
|
||||||
import SubscribeNewsletterArgs from '@arg/SubscribeNewsletterArgs'
|
|
||||||
|
|
||||||
import {
|
import {
|
||||||
getKlickTippUser,
|
getKlickTippUser,
|
||||||
@ -10,6 +8,7 @@ import {
|
|||||||
klicktippSignIn,
|
klicktippSignIn,
|
||||||
} from '@/apis/KlicktippController'
|
} from '@/apis/KlicktippController'
|
||||||
import { RIGHTS } from '@/auth/RIGHTS'
|
import { RIGHTS } from '@/auth/RIGHTS'
|
||||||
|
import { Context, getUser } from '@/server/context'
|
||||||
|
|
||||||
@Resolver()
|
@Resolver()
|
||||||
export class KlicktippResolver {
|
export class KlicktippResolver {
|
||||||
@ -27,15 +26,15 @@ export class KlicktippResolver {
|
|||||||
|
|
||||||
@Authorized([RIGHTS.UNSUBSCRIBE_NEWSLETTER])
|
@Authorized([RIGHTS.UNSUBSCRIBE_NEWSLETTER])
|
||||||
@Mutation(() => Boolean)
|
@Mutation(() => Boolean)
|
||||||
async unsubscribeNewsletter(@Arg('email') email: string): Promise<boolean> {
|
async unsubscribeNewsletter(@Ctx() context: Context): Promise<boolean> {
|
||||||
return await unsubscribe(email)
|
const user = getUser(context)
|
||||||
|
return unsubscribe(user.emailContact.email)
|
||||||
}
|
}
|
||||||
|
|
||||||
@Authorized([RIGHTS.SUBSCRIBE_NEWSLETTER])
|
@Authorized([RIGHTS.SUBSCRIBE_NEWSLETTER])
|
||||||
@Mutation(() => Boolean)
|
@Mutation(() => Boolean)
|
||||||
async subscribeNewsletter(
|
async subscribeNewsletter(@Ctx() context: Context): Promise<boolean> {
|
||||||
@Args() { email, language }: SubscribeNewsletterArgs,
|
const user = getUser(context)
|
||||||
): Promise<boolean> {
|
return klicktippSignIn(user.emailContact.email, user.language)
|
||||||
return await klicktippSignIn(email, language)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -60,9 +60,6 @@ describe('UserCard_Newsletter', () => {
|
|||||||
it('calls the unsubscribe mutation', () => {
|
it('calls the unsubscribe mutation', () => {
|
||||||
expect(mockAPIcall).toBeCalledWith({
|
expect(mockAPIcall).toBeCalledWith({
|
||||||
mutation: unsubscribeNewsletter,
|
mutation: unsubscribeNewsletter,
|
||||||
variables: {
|
|
||||||
email: 'peter@lustig.de',
|
|
||||||
},
|
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -89,10 +86,6 @@ describe('UserCard_Newsletter', () => {
|
|||||||
it('calls the subscribe mutation', () => {
|
it('calls the subscribe mutation', () => {
|
||||||
expect(mockAPIcall).toBeCalledWith({
|
expect(mockAPIcall).toBeCalledWith({
|
||||||
mutation: subscribeNewsletter,
|
mutation: subscribeNewsletter,
|
||||||
variables: {
|
|
||||||
email: 'peter@lustig.de',
|
|
||||||
language: 'de',
|
|
||||||
},
|
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|||||||
@ -41,10 +41,6 @@ export default {
|
|||||||
this.$apollo
|
this.$apollo
|
||||||
.mutate({
|
.mutate({
|
||||||
mutation: this.newsletterState ? subscribeNewsletter : unsubscribeNewsletter,
|
mutation: this.newsletterState ? subscribeNewsletter : unsubscribeNewsletter,
|
||||||
variables: {
|
|
||||||
email: this.$store.state.email,
|
|
||||||
language: this.newsletterState ? this.$store.state.language : undefined,
|
|
||||||
},
|
|
||||||
})
|
})
|
||||||
.then(() => {
|
.then(() => {
|
||||||
this.$store.commit('newsletterState', this.newsletterState)
|
this.$store.commit('newsletterState', this.newsletterState)
|
||||||
|
|||||||
@ -1,14 +1,14 @@
|
|||||||
import gql from 'graphql-tag'
|
import gql from 'graphql-tag'
|
||||||
|
|
||||||
export const subscribeNewsletter = gql`
|
export const subscribeNewsletter = gql`
|
||||||
mutation($email: String!, $language: String!) {
|
mutation {
|
||||||
subscribeNewsletter(email: $email, language: $language)
|
subscribeNewsletter
|
||||||
}
|
}
|
||||||
`
|
`
|
||||||
|
|
||||||
export const unsubscribeNewsletter = gql`
|
export const unsubscribeNewsletter = gql`
|
||||||
mutation($email: String!) {
|
mutation {
|
||||||
unsubscribeNewsletter(email: $email)
|
unsubscribeNewsletter
|
||||||
}
|
}
|
||||||
`
|
`
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user