refactor(helcim): use helper in unused admin endpoints
This commit is contained in:
parent
0d792c7c70
commit
130e5bfa9f
4 changed files with 29 additions and 113 deletions
|
|
@ -1,42 +1,18 @@
|
|||
// Create a new Helcim payment plan
|
||||
const HELCIM_API_BASE = 'https://api.helcim.com/v2'
|
||||
import { createHelcimPlan } from '../../utils/helcim.js'
|
||||
|
||||
export default defineEventHandler(async (event) => {
|
||||
try {
|
||||
await requireAdmin(event)
|
||||
const config = useRuntimeConfig(event)
|
||||
const body = await validateBody(event, helcimCreatePlanSchema)
|
||||
|
||||
const helcimToken = config.helcimApiToken
|
||||
|
||||
|
||||
const response = await fetch(`${HELCIM_API_BASE}/payment-plans`, {
|
||||
method: 'POST',
|
||||
headers: {
|
||||
'accept': 'application/json',
|
||||
'content-type': 'application/json',
|
||||
'api-token': helcimToken
|
||||
},
|
||||
body: JSON.stringify({
|
||||
planName: body.name,
|
||||
planAmount: parseFloat(body.amount),
|
||||
planFrequency: body.frequency, // 'monthly', 'weekly', 'biweekly', etc.
|
||||
planCurrency: body.currency || 'CAD'
|
||||
})
|
||||
const planData = await createHelcimPlan({
|
||||
planName: body.name,
|
||||
planAmount: parseFloat(body.amount),
|
||||
planFrequency: body.frequency,
|
||||
planCurrency: body.currency || 'CAD'
|
||||
})
|
||||
|
||||
if (!response.ok) {
|
||||
const errorText = await response.text()
|
||||
console.error('Failed to create payment plan:', response.status, errorText)
|
||||
|
||||
throw createError({
|
||||
statusCode: response.status,
|
||||
statusMessage: 'Payment plan creation failed'
|
||||
})
|
||||
}
|
||||
|
||||
const planData = await response.json()
|
||||
|
||||
return {
|
||||
success: true,
|
||||
plan: planData
|
||||
|
|
|
|||
|
|
@ -1,35 +1,17 @@
|
|||
// Get Helcim payment plans
|
||||
const HELCIM_API_BASE = 'https://api.helcim.com/v2'
|
||||
import { listHelcimPlans } from '../../utils/helcim.js'
|
||||
|
||||
export default defineEventHandler(async (event) => {
|
||||
try {
|
||||
await requireAdmin(event)
|
||||
const config = useRuntimeConfig(event)
|
||||
const helcimToken = config.helcimApiToken
|
||||
|
||||
const response = await fetch(`${HELCIM_API_BASE}/payment-plans`, {
|
||||
method: 'GET',
|
||||
headers: {
|
||||
'accept': 'application/json',
|
||||
'api-token': helcimToken
|
||||
}
|
||||
})
|
||||
|
||||
if (!response.ok) {
|
||||
console.error('Failed to fetch payment plans:', response.status, response.statusText)
|
||||
throw createError({
|
||||
statusCode: response.status,
|
||||
statusMessage: 'Failed to fetch payment plans'
|
||||
})
|
||||
}
|
||||
|
||||
const plansData = await response.json()
|
||||
|
||||
|
||||
const plansData = await listHelcimPlans()
|
||||
|
||||
return {
|
||||
success: true,
|
||||
plans: plansData
|
||||
}
|
||||
|
||||
|
||||
} catch (error) {
|
||||
if (error.statusCode) throw error
|
||||
console.error('Error fetching Helcim payment plans:', error)
|
||||
|
|
@ -38,4 +20,4 @@ export default defineEventHandler(async (event) => {
|
|||
statusMessage: 'An unexpected error occurred'
|
||||
})
|
||||
}
|
||||
})
|
||||
})
|
||||
|
|
|
|||
|
|
@ -1,35 +1,17 @@
|
|||
// Get existing Helcim subscriptions to understand the format
|
||||
const HELCIM_API_BASE = 'https://api.helcim.com/v2'
|
||||
import { listHelcimSubscriptions } from '../../utils/helcim.js'
|
||||
|
||||
export default defineEventHandler(async (event) => {
|
||||
try {
|
||||
await requireAdmin(event)
|
||||
const config = useRuntimeConfig(event)
|
||||
const helcimToken = config.helcimApiToken
|
||||
|
||||
const response = await fetch(`${HELCIM_API_BASE}/subscriptions`, {
|
||||
method: 'GET',
|
||||
headers: {
|
||||
'accept': 'application/json',
|
||||
'api-token': helcimToken
|
||||
}
|
||||
})
|
||||
|
||||
if (!response.ok) {
|
||||
console.error('Failed to fetch subscriptions:', response.status, response.statusText)
|
||||
throw createError({
|
||||
statusCode: response.status,
|
||||
statusMessage: 'Failed to fetch subscriptions'
|
||||
})
|
||||
}
|
||||
|
||||
const subscriptionsData = await response.json()
|
||||
|
||||
|
||||
const subscriptionsData = await listHelcimSubscriptions()
|
||||
|
||||
return {
|
||||
success: true,
|
||||
subscriptions: subscriptionsData
|
||||
}
|
||||
|
||||
|
||||
} catch (error) {
|
||||
if (error.statusCode) throw error
|
||||
console.error('Error fetching Helcim subscriptions:', error)
|
||||
|
|
@ -38,4 +20,4 @@ export default defineEventHandler(async (event) => {
|
|||
statusMessage: 'An unexpected error occurred'
|
||||
})
|
||||
}
|
||||
})
|
||||
})
|
||||
|
|
|
|||
|
|
@ -1,48 +1,24 @@
|
|||
// Update customer billing address
|
||||
import { requireAuth } from '../../utils/auth.js'
|
||||
|
||||
const HELCIM_API_BASE = 'https://api.helcim.com/v2'
|
||||
import { updateHelcimCustomer } from '../../utils/helcim.js'
|
||||
|
||||
export default defineEventHandler(async (event) => {
|
||||
try {
|
||||
await requireAuth(event)
|
||||
const config = useRuntimeConfig(event)
|
||||
const body = await validateBody(event, helcimUpdateBillingSchema)
|
||||
|
||||
const { billingAddress } = body
|
||||
|
||||
const helcimToken = config.helcimApiToken
|
||||
|
||||
// Update customer billing address in Helcim
|
||||
const response = await fetch(`${HELCIM_API_BASE}/customers/${body.customerId}`, {
|
||||
method: 'PATCH',
|
||||
headers: {
|
||||
'accept': 'application/json',
|
||||
'content-type': 'application/json',
|
||||
'api-token': helcimToken
|
||||
},
|
||||
body: JSON.stringify({
|
||||
billingAddress: {
|
||||
name: billingAddress.name,
|
||||
street1: billingAddress.street,
|
||||
city: billingAddress.city,
|
||||
province: billingAddress.province || billingAddress.state,
|
||||
country: billingAddress.country,
|
||||
postalCode: billingAddress.postalCode
|
||||
}
|
||||
})
|
||||
const customerData = await updateHelcimCustomer(body.customerId, {
|
||||
billingAddress: {
|
||||
name: billingAddress.name,
|
||||
street1: billingAddress.street,
|
||||
city: billingAddress.city,
|
||||
province: billingAddress.province || billingAddress.state,
|
||||
country: billingAddress.country,
|
||||
postalCode: billingAddress.postalCode
|
||||
}
|
||||
})
|
||||
|
||||
if (!response.ok) {
|
||||
const errorText = await response.text()
|
||||
console.error('Billing address update failed:', response.status, errorText)
|
||||
throw createError({
|
||||
statusCode: response.status,
|
||||
statusMessage: 'Billing update failed'
|
||||
})
|
||||
}
|
||||
|
||||
const customerData = await response.json()
|
||||
|
||||
return {
|
||||
success: true,
|
||||
|
|
@ -56,4 +32,4 @@ export default defineEventHandler(async (event) => {
|
|||
statusMessage: 'An unexpected error occurred'
|
||||
})
|
||||
}
|
||||
})
|
||||
})
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue