mirror of
https://github.com/IT4Change/gradido.git
synced 2025-12-13 07:45:54 +00:00
Merge branch 'master' into 2882-feature-distingue-communities-and-communities_federation-in-database
This commit is contained in:
commit
464cdcf7aa
@ -18,6 +18,7 @@ export const klicktippSignIn = async (
|
|||||||
firstName?: string,
|
firstName?: string,
|
||||||
lastName?: string,
|
lastName?: string,
|
||||||
): Promise<boolean> => {
|
): Promise<boolean> => {
|
||||||
|
if (!CONFIG.KLICKTIPP) return true
|
||||||
const fields = {
|
const fields = {
|
||||||
fieldFirstName: firstName,
|
fieldFirstName: firstName,
|
||||||
fieldLastName: lastName,
|
fieldLastName: lastName,
|
||||||
@ -28,12 +29,14 @@ export const klicktippSignIn = async (
|
|||||||
}
|
}
|
||||||
|
|
||||||
export const signout = async (email: string, language: string): Promise<boolean> => {
|
export const signout = async (email: string, language: string): Promise<boolean> => {
|
||||||
|
if (!CONFIG.KLICKTIPP) return true
|
||||||
const apiKey = language === 'de' ? CONFIG.KLICKTIPP_APIKEY_DE : CONFIG.KLICKTIPP_APIKEY_EN
|
const apiKey = language === 'de' ? CONFIG.KLICKTIPP_APIKEY_DE : CONFIG.KLICKTIPP_APIKEY_EN
|
||||||
const result = await klicktippConnector.signoff(apiKey, email)
|
const result = await klicktippConnector.signoff(apiKey, email)
|
||||||
return result
|
return result
|
||||||
}
|
}
|
||||||
|
|
||||||
export const unsubscribe = async (email: string): Promise<boolean> => {
|
export const unsubscribe = async (email: string): Promise<boolean> => {
|
||||||
|
if (!CONFIG.KLICKTIPP) return true
|
||||||
const isLogin = await loginKlicktippUser()
|
const isLogin = await loginKlicktippUser()
|
||||||
if (isLogin) {
|
if (isLogin) {
|
||||||
return await klicktippConnector.unsubscribe(email)
|
return await klicktippConnector.unsubscribe(email)
|
||||||
@ -42,6 +45,7 @@ export const unsubscribe = async (email: string): Promise<boolean> => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export const getKlickTippUser = async (email: string): Promise<any> => {
|
export const getKlickTippUser = async (email: string): Promise<any> => {
|
||||||
|
if (!CONFIG.KLICKTIPP) return true
|
||||||
const isLogin = await loginKlicktippUser()
|
const isLogin = await loginKlicktippUser()
|
||||||
if (isLogin) {
|
if (isLogin) {
|
||||||
const subscriberId = await klicktippConnector.subscriberSearch(email)
|
const subscriberId = await klicktippConnector.subscriberSearch(email)
|
||||||
@ -52,14 +56,17 @@ export const getKlickTippUser = async (email: string): Promise<any> => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export const loginKlicktippUser = async (): Promise<boolean> => {
|
export const loginKlicktippUser = async (): Promise<boolean> => {
|
||||||
|
if (!CONFIG.KLICKTIPP) return true
|
||||||
return await klicktippConnector.login(CONFIG.KLICKTIPP_USER, CONFIG.KLICKTIPP_PASSWORD)
|
return await klicktippConnector.login(CONFIG.KLICKTIPP_USER, CONFIG.KLICKTIPP_PASSWORD)
|
||||||
}
|
}
|
||||||
|
|
||||||
export const logoutKlicktippUser = async (): Promise<boolean> => {
|
export const logoutKlicktippUser = async (): Promise<boolean> => {
|
||||||
|
if (!CONFIG.KLICKTIPP) return true
|
||||||
return await klicktippConnector.logout()
|
return await klicktippConnector.logout()
|
||||||
}
|
}
|
||||||
|
|
||||||
export const untagUser = async (email: string, tagId: string): Promise<boolean> => {
|
export const untagUser = async (email: string, tagId: string): Promise<boolean> => {
|
||||||
|
if (!CONFIG.KLICKTIPP) return true
|
||||||
const isLogin = await loginKlicktippUser()
|
const isLogin = await loginKlicktippUser()
|
||||||
if (isLogin) {
|
if (isLogin) {
|
||||||
return await klicktippConnector.untag(email, tagId)
|
return await klicktippConnector.untag(email, tagId)
|
||||||
@ -68,6 +75,7 @@ export const untagUser = async (email: string, tagId: string): Promise<boolean>
|
|||||||
}
|
}
|
||||||
|
|
||||||
export const tagUser = async (email: string, tagIds: string): Promise<boolean> => {
|
export const tagUser = async (email: string, tagIds: string): Promise<boolean> => {
|
||||||
|
if (!CONFIG.KLICKTIPP) return true
|
||||||
const isLogin = await loginKlicktippUser()
|
const isLogin = await loginKlicktippUser()
|
||||||
if (isLogin) {
|
if (isLogin) {
|
||||||
return await klicktippConnector.tag(email, tagIds)
|
return await klicktippConnector.tag(email, tagIds)
|
||||||
@ -76,6 +84,7 @@ export const tagUser = async (email: string, tagIds: string): Promise<boolean> =
|
|||||||
}
|
}
|
||||||
|
|
||||||
export const getKlicktippTagMap = async () => {
|
export const getKlicktippTagMap = async () => {
|
||||||
|
if (!CONFIG.KLICKTIPP) return true
|
||||||
const isLogin = await loginKlicktippUser()
|
const isLogin = await loginKlicktippUser()
|
||||||
if (isLogin) {
|
if (isLogin) {
|
||||||
return await klicktippConnector.tagIndex()
|
return await klicktippConnector.tagIndex()
|
||||||
|
|||||||
@ -5,8 +5,6 @@ export enum RIGHTS {
|
|||||||
COMMUNITIES = 'COMMUNITIES',
|
COMMUNITIES = 'COMMUNITIES',
|
||||||
LIST_GDT_ENTRIES = 'LIST_GDT_ENTRIES',
|
LIST_GDT_ENTRIES = 'LIST_GDT_ENTRIES',
|
||||||
EXIST_PID = 'EXIST_PID',
|
EXIST_PID = 'EXIST_PID',
|
||||||
GET_KLICKTIPP_USER = 'GET_KLICKTIPP_USER',
|
|
||||||
GET_KLICKTIPP_TAG_MAP = 'GET_KLICKTIPP_TAG_MAP',
|
|
||||||
UNSUBSCRIBE_NEWSLETTER = 'UNSUBSCRIBE_NEWSLETTER',
|
UNSUBSCRIBE_NEWSLETTER = 'UNSUBSCRIBE_NEWSLETTER',
|
||||||
SUBSCRIBE_NEWSLETTER = 'SUBSCRIBE_NEWSLETTER',
|
SUBSCRIBE_NEWSLETTER = 'SUBSCRIBE_NEWSLETTER',
|
||||||
TRANSACTION_LIST = 'TRANSACTION_LIST',
|
TRANSACTION_LIST = 'TRANSACTION_LIST',
|
||||||
|
|||||||
@ -9,8 +9,6 @@ export const ROLE_USER = new Role('user', [
|
|||||||
RIGHTS.BALANCE,
|
RIGHTS.BALANCE,
|
||||||
RIGHTS.LIST_GDT_ENTRIES,
|
RIGHTS.LIST_GDT_ENTRIES,
|
||||||
RIGHTS.EXIST_PID,
|
RIGHTS.EXIST_PID,
|
||||||
RIGHTS.GET_KLICKTIPP_USER,
|
|
||||||
RIGHTS.GET_KLICKTIPP_TAG_MAP,
|
|
||||||
RIGHTS.UNSUBSCRIBE_NEWSLETTER,
|
RIGHTS.UNSUBSCRIBE_NEWSLETTER,
|
||||||
RIGHTS.SUBSCRIBE_NEWSLETTER,
|
RIGHTS.SUBSCRIBE_NEWSLETTER,
|
||||||
RIGHTS.TRANSACTION_LIST,
|
RIGHTS.TRANSACTION_LIST,
|
||||||
|
|||||||
8
backend/src/event/EVENT_NEWSLETTER_SUBSCRIBE.ts
Normal file
8
backend/src/event/EVENT_NEWSLETTER_SUBSCRIBE.ts
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
import { Event as DbEvent } from '@entity/Event'
|
||||||
|
import { User as DbUser } from '@entity/User'
|
||||||
|
|
||||||
|
import { Event } from './Event'
|
||||||
|
import { EventType } from './EventType'
|
||||||
|
|
||||||
|
export const EVENT_NEWSLETTER_SUBSCRIBE = async (user: DbUser): Promise<DbEvent> =>
|
||||||
|
Event(EventType.NEWSLETTER_SUBSCRIBE, user, user).save()
|
||||||
8
backend/src/event/EVENT_NEWSLETTER_UNSUBSCRIBE.ts
Normal file
8
backend/src/event/EVENT_NEWSLETTER_UNSUBSCRIBE.ts
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
import { Event as DbEvent } from '@entity/Event'
|
||||||
|
import { User as DbUser } from '@entity/User'
|
||||||
|
|
||||||
|
import { Event } from './Event'
|
||||||
|
import { EventType } from './EventType'
|
||||||
|
|
||||||
|
export const EVENT_NEWSLETTER_UNSUBSCRIBE = async (user: DbUser): Promise<DbEvent> =>
|
||||||
|
Event(EventType.NEWSLETTER_UNSUBSCRIBE, user, user).save()
|
||||||
@ -21,6 +21,8 @@ export enum EventType {
|
|||||||
EMAIL_ADMIN_CONFIRMATION = 'EMAIL_ADMIN_CONFIRMATION',
|
EMAIL_ADMIN_CONFIRMATION = 'EMAIL_ADMIN_CONFIRMATION',
|
||||||
EMAIL_CONFIRMATION = 'EMAIL_CONFIRMATION',
|
EMAIL_CONFIRMATION = 'EMAIL_CONFIRMATION',
|
||||||
EMAIL_FORGOT_PASSWORD = 'EMAIL_FORGOT_PASSWORD',
|
EMAIL_FORGOT_PASSWORD = 'EMAIL_FORGOT_PASSWORD',
|
||||||
|
NEWSLETTER_SUBSCRIBE = 'NEWSLETTER_SUBSCRIBE',
|
||||||
|
NEWSLETTER_UNSUBSCRIBE = 'NEWSLETTER_UNSUBSCRIBE',
|
||||||
TRANSACTION_SEND = 'TRANSACTION_SEND',
|
TRANSACTION_SEND = 'TRANSACTION_SEND',
|
||||||
TRANSACTION_RECEIVE = 'TRANSACTION_RECEIVE',
|
TRANSACTION_RECEIVE = 'TRANSACTION_RECEIVE',
|
||||||
TRANSACTION_LINK_CREATE = 'TRANSACTION_LINK_CREATE',
|
TRANSACTION_LINK_CREATE = 'TRANSACTION_LINK_CREATE',
|
||||||
|
|||||||
@ -21,6 +21,8 @@ export { EVENT_EMAIL_ACCOUNT_MULTIREGISTRATION } from './EVENT_EMAIL_ACCOUNT_MUL
|
|||||||
export { EVENT_EMAIL_ADMIN_CONFIRMATION } from './EVENT_EMAIL_ADMIN_CONFIRMATION'
|
export { EVENT_EMAIL_ADMIN_CONFIRMATION } from './EVENT_EMAIL_ADMIN_CONFIRMATION'
|
||||||
export { EVENT_EMAIL_CONFIRMATION } from './EVENT_EMAIL_CONFIRMATION'
|
export { EVENT_EMAIL_CONFIRMATION } from './EVENT_EMAIL_CONFIRMATION'
|
||||||
export { EVENT_EMAIL_FORGOT_PASSWORD } from './EVENT_EMAIL_FORGOT_PASSWORD'
|
export { EVENT_EMAIL_FORGOT_PASSWORD } from './EVENT_EMAIL_FORGOT_PASSWORD'
|
||||||
|
export { EVENT_NEWSLETTER_SUBSCRIBE } from './EVENT_NEWSLETTER_SUBSCRIBE'
|
||||||
|
export { EVENT_NEWSLETTER_UNSUBSCRIBE } from './EVENT_NEWSLETTER_UNSUBSCRIBE'
|
||||||
export { EVENT_TRANSACTION_SEND } from './EVENT_TRANSACTION_SEND'
|
export { EVENT_TRANSACTION_SEND } from './EVENT_TRANSACTION_SEND'
|
||||||
export { EVENT_TRANSACTION_RECEIVE } from './EVENT_TRANSACTION_RECEIVE'
|
export { EVENT_TRANSACTION_RECEIVE } from './EVENT_TRANSACTION_RECEIVE'
|
||||||
export { EVENT_TRANSACTION_LINK_CREATE } from './EVENT_TRANSACTION_LINK_CREATE'
|
export { EVENT_TRANSACTION_LINK_CREATE } from './EVENT_TRANSACTION_LINK_CREATE'
|
||||||
|
|||||||
138
backend/src/graphql/resolver/KlicktippResolver.test.ts
Normal file
138
backend/src/graphql/resolver/KlicktippResolver.test.ts
Normal file
@ -0,0 +1,138 @@
|
|||||||
|
/* eslint-disable @typescript-eslint/no-unsafe-argument */
|
||||||
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
||||||
|
/* eslint-disable @typescript-eslint/no-unsafe-assignment */
|
||||||
|
/* eslint-disable @typescript-eslint/no-unsafe-call */
|
||||||
|
/* eslint-disable @typescript-eslint/no-unsafe-member-access */
|
||||||
|
import { Event as DbEvent } from '@entity/Event'
|
||||||
|
import { UserContact } from '@entity/UserContact'
|
||||||
|
import { GraphQLError } from 'graphql'
|
||||||
|
|
||||||
|
import { cleanDB, resetToken, testEnvironment } from '@test/helpers'
|
||||||
|
import { logger, i18n as localization } from '@test/testSetup'
|
||||||
|
|
||||||
|
import { EventType } from '@/event/Events'
|
||||||
|
import { userFactory } from '@/seeds/factory/user'
|
||||||
|
import { login, subscribeNewsletter, unsubscribeNewsletter } from '@/seeds/graphql/mutations'
|
||||||
|
import { bibiBloxberg } from '@/seeds/users/bibi-bloxberg'
|
||||||
|
|
||||||
|
let testEnv: any, mutate: any, con: any
|
||||||
|
|
||||||
|
beforeAll(async () => {
|
||||||
|
testEnv = await testEnvironment(logger, localization)
|
||||||
|
mutate = testEnv.mutate
|
||||||
|
con = testEnv.con
|
||||||
|
await cleanDB()
|
||||||
|
})
|
||||||
|
|
||||||
|
afterAll(async () => {
|
||||||
|
await cleanDB()
|
||||||
|
await con.close()
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('KlicktippResolver', () => {
|
||||||
|
beforeAll(async () => {
|
||||||
|
await userFactory(testEnv, bibiBloxberg)
|
||||||
|
})
|
||||||
|
|
||||||
|
afterAll(async () => {
|
||||||
|
await cleanDB()
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('subscribeNewsletter', () => {
|
||||||
|
describe('unauthenticated', () => {
|
||||||
|
it('returns an error', async () => {
|
||||||
|
const { errors: errorObjects }: { errors: [GraphQLError] } = await mutate({
|
||||||
|
mutation: subscribeNewsletter,
|
||||||
|
})
|
||||||
|
|
||||||
|
expect(errorObjects).toEqual([new GraphQLError('401 Unauthorized')])
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('authenticated', () => {
|
||||||
|
beforeAll(async () => {
|
||||||
|
await mutate({
|
||||||
|
mutation: login,
|
||||||
|
variables: { email: 'bibi@bloxberg.de', password: 'Aa12345_' },
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
afterAll(() => {
|
||||||
|
resetToken()
|
||||||
|
})
|
||||||
|
|
||||||
|
it('calls API', async () => {
|
||||||
|
const {
|
||||||
|
data: { subscribeNewsletter: isSubscribed },
|
||||||
|
}: { data: { subscribeNewsletter: boolean } } = await mutate({
|
||||||
|
mutation: subscribeNewsletter,
|
||||||
|
})
|
||||||
|
|
||||||
|
expect(isSubscribed).toEqual(true)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('stores the NEWSLETTER_SUBSCRIBE event in the database', async () => {
|
||||||
|
const userConatct = await UserContact.findOneOrFail(
|
||||||
|
{ email: 'bibi@bloxberg.de' },
|
||||||
|
{ relations: ['user'] },
|
||||||
|
)
|
||||||
|
await expect(DbEvent.find()).resolves.toContainEqual(
|
||||||
|
expect.objectContaining({
|
||||||
|
type: EventType.NEWSLETTER_SUBSCRIBE,
|
||||||
|
affectedUserId: userConatct.user.id,
|
||||||
|
actingUserId: userConatct.user.id,
|
||||||
|
}),
|
||||||
|
)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('unsubscribeNewsletter', () => {
|
||||||
|
describe('unauthenticated', () => {
|
||||||
|
it('returns an error', async () => {
|
||||||
|
const { errors: errorObjects }: { errors: [GraphQLError] } = await mutate({
|
||||||
|
mutation: unsubscribeNewsletter,
|
||||||
|
})
|
||||||
|
|
||||||
|
expect(errorObjects).toEqual([new GraphQLError('401 Unauthorized')])
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('authenticated', () => {
|
||||||
|
beforeAll(async () => {
|
||||||
|
await mutate({
|
||||||
|
mutation: login,
|
||||||
|
variables: { email: 'bibi@bloxberg.de', password: 'Aa12345_' },
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
afterAll(() => {
|
||||||
|
resetToken()
|
||||||
|
})
|
||||||
|
|
||||||
|
it('calls API', async () => {
|
||||||
|
const {
|
||||||
|
data: { unsubscribeNewsletter: isUnsubscribed },
|
||||||
|
}: { data: { unsubscribeNewsletter: boolean } } = await mutate({
|
||||||
|
mutation: unsubscribeNewsletter,
|
||||||
|
})
|
||||||
|
|
||||||
|
expect(isUnsubscribed).toEqual(true)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('stores the NEWSLETTER_UNSUBSCRIBE event in the database', async () => {
|
||||||
|
const userConatct = await UserContact.findOneOrFail(
|
||||||
|
{ email: 'bibi@bloxberg.de' },
|
||||||
|
{ relations: ['user'] },
|
||||||
|
)
|
||||||
|
await expect(DbEvent.find()).resolves.toContainEqual(
|
||||||
|
expect.objectContaining({
|
||||||
|
type: EventType.NEWSLETTER_UNSUBSCRIBE,
|
||||||
|
affectedUserId: userConatct.user.id,
|
||||||
|
actingUserId: userConatct.user.id,
|
||||||
|
}),
|
||||||
|
)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
@ -1,33 +1,17 @@
|
|||||||
/* eslint-disable @typescript-eslint/no-unsafe-return */
|
import { Resolver, Authorized, Mutation, Ctx } from 'type-graphql'
|
||||||
import { Resolver, Query, Authorized, Arg, Mutation, Ctx } from 'type-graphql'
|
|
||||||
|
|
||||||
import {
|
import { unsubscribe, klicktippSignIn } from '@/apis/KlicktippController'
|
||||||
getKlickTippUser,
|
|
||||||
getKlicktippTagMap,
|
|
||||||
unsubscribe,
|
|
||||||
klicktippSignIn,
|
|
||||||
} from '@/apis/KlicktippController'
|
|
||||||
import { RIGHTS } from '@/auth/RIGHTS'
|
import { RIGHTS } from '@/auth/RIGHTS'
|
||||||
|
import { EVENT_NEWSLETTER_SUBSCRIBE, EVENT_NEWSLETTER_UNSUBSCRIBE } from '@/event/Events'
|
||||||
import { Context, getUser } from '@/server/context'
|
import { Context, getUser } from '@/server/context'
|
||||||
|
|
||||||
@Resolver()
|
@Resolver()
|
||||||
export class KlicktippResolver {
|
export class KlicktippResolver {
|
||||||
@Authorized([RIGHTS.GET_KLICKTIPP_USER])
|
|
||||||
@Query(() => String)
|
|
||||||
async getKlicktippUser(@Arg('email') email: string): Promise<string> {
|
|
||||||
return await getKlickTippUser(email)
|
|
||||||
}
|
|
||||||
|
|
||||||
@Authorized([RIGHTS.GET_KLICKTIPP_TAG_MAP])
|
|
||||||
@Query(() => String)
|
|
||||||
async getKlicktippTagMap(): Promise<string> {
|
|
||||||
return await getKlicktippTagMap()
|
|
||||||
}
|
|
||||||
|
|
||||||
@Authorized([RIGHTS.UNSUBSCRIBE_NEWSLETTER])
|
@Authorized([RIGHTS.UNSUBSCRIBE_NEWSLETTER])
|
||||||
@Mutation(() => Boolean)
|
@Mutation(() => Boolean)
|
||||||
async unsubscribeNewsletter(@Ctx() context: Context): Promise<boolean> {
|
async unsubscribeNewsletter(@Ctx() context: Context): Promise<boolean> {
|
||||||
const user = getUser(context)
|
const user = getUser(context)
|
||||||
|
await EVENT_NEWSLETTER_UNSUBSCRIBE(user)
|
||||||
return unsubscribe(user.emailContact.email)
|
return unsubscribe(user.emailContact.email)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -35,6 +19,7 @@ export class KlicktippResolver {
|
|||||||
@Mutation(() => Boolean)
|
@Mutation(() => Boolean)
|
||||||
async subscribeNewsletter(@Ctx() context: Context): Promise<boolean> {
|
async subscribeNewsletter(@Ctx() context: Context): Promise<boolean> {
|
||||||
const user = getUser(context)
|
const user = getUser(context)
|
||||||
|
await EVENT_NEWSLETTER_SUBSCRIBE(user)
|
||||||
return klicktippSignIn(user.emailContact.email, user.language)
|
return klicktippSignIn(user.emailContact.email, user.language)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -7,8 +7,7 @@ import { MiddlewareFn } from 'type-graphql'
|
|||||||
|
|
||||||
import { KlickTipp } from '@model/KlickTipp'
|
import { KlickTipp } from '@model/KlickTipp'
|
||||||
|
|
||||||
import { /* klicktippSignIn, */ getKlickTippUser } from '@/apis/KlicktippController'
|
import { getKlickTippUser } from '@/apis/KlicktippController'
|
||||||
import { CONFIG } from '@/config'
|
|
||||||
import { klickTippLogger as logger } from '@/server/logger'
|
import { klickTippLogger as logger } from '@/server/logger'
|
||||||
|
|
||||||
// export const klicktippRegistrationMiddleware: MiddlewareFn = async (
|
// export const klicktippRegistrationMiddleware: MiddlewareFn = async (
|
||||||
@ -32,15 +31,13 @@ export const klicktippNewsletterStateMiddleware: MiddlewareFn = async (
|
|||||||
// eslint-disable-next-line n/callback-return
|
// eslint-disable-next-line n/callback-return
|
||||||
const result = await next()
|
const result = await next()
|
||||||
let klickTipp = new KlickTipp({ status: 'Unsubscribed' })
|
let klickTipp = new KlickTipp({ status: 'Unsubscribed' })
|
||||||
if (CONFIG.KLICKTIPP) {
|
try {
|
||||||
try {
|
const klickTippUser = await getKlickTippUser(result.email)
|
||||||
const klickTippUser = await getKlickTippUser(result.email)
|
if (klickTippUser) {
|
||||||
if (klickTippUser) {
|
klickTipp = new KlickTipp(klickTippUser)
|
||||||
klickTipp = new KlickTipp(klickTippUser)
|
|
||||||
}
|
|
||||||
} catch (err) {
|
|
||||||
logger.error(`There is no user for (email='${result.email}') ${err}`)
|
|
||||||
}
|
}
|
||||||
|
} catch (err) {
|
||||||
|
logger.error(`There is no user for (email='${result.email}') ${err}`)
|
||||||
}
|
}
|
||||||
result.klickTipp = klickTipp
|
result.klickTipp = klickTipp
|
||||||
return result
|
return result
|
||||||
|
|||||||
@ -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