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:
Hannes Heine 2023-03-28 02:14:10 +02:00 committed by GitHub
commit 184de4672e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 12 additions and 34 deletions

View File

@ -1,10 +0,0 @@
import { ArgsType, Field } from 'type-graphql'
@ArgsType()
export default class SubscribeNewsletterArgs {
@Field(() => String)
email: string
@Field(() => String)
language: string
}

View File

@ -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)
} }
} }

View File

@ -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',
},
}) })
}) })

View File

@ -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)

View File

@ -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
} }
` `