2022-08-17 08:50:24 -07:00
import { INodeProperties } from 'n8n-workflow' ;
2021-07-10 04:15:14 -07:00
2021-12-03 00:44:16 -08:00
export const chargeOperations : INodeProperties [ ] = [
2021-07-10 04:15:14 -07:00
{
displayName : 'Operation' ,
name : 'operation' ,
type : 'options' ,
2022-05-20 14:47:24 -07:00
noDataExpression : true ,
2021-07-10 04:15:14 -07:00
default : 'get' ,
options : [
{
name : 'Create' ,
value : 'create' ,
description : 'Create a charge' ,
2022-07-10 13:50:51 -07:00
action : 'Create a charge' ,
2021-07-10 04:15:14 -07:00
} ,
{
name : 'Get' ,
value : 'get' ,
description : 'Get a charge' ,
2022-07-10 13:50:51 -07:00
action : 'Get a charge' ,
2021-07-10 04:15:14 -07:00
} ,
{
name : 'Get All' ,
value : 'getAll' ,
description : 'Get all charges' ,
2022-07-10 13:50:51 -07:00
action : 'Get all charges' ,
2021-07-10 04:15:14 -07:00
} ,
{
name : 'Update' ,
value : 'update' ,
description : 'Update a charge' ,
2022-07-10 13:50:51 -07:00
action : 'Update a charge' ,
2021-07-10 04:15:14 -07:00
} ,
] ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'charge' ] ,
2021-07-10 04:15:14 -07:00
} ,
} ,
} ,
2021-12-03 00:44:16 -08:00
] ;
2021-07-10 04:15:14 -07:00
2021-12-03 00:44:16 -08:00
export const chargeFields : INodeProperties [ ] = [
2021-07-10 04:15:14 -07:00
// ----------------------------------
// charge: create
// ----------------------------------
{
displayName : 'Customer ID' ,
name : 'customerId' ,
type : 'string' ,
required : true ,
default : '' ,
description : 'ID of the customer to be associated with this charge' ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'charge' ] ,
operation : [ 'create' ] ,
2021-07-10 04:15:14 -07:00
} ,
} ,
} ,
{
displayName : 'Amount' ,
name : 'amount' ,
type : 'number' ,
required : true ,
default : 0 ,
2022-08-17 08:50:24 -07:00
description :
'Amount in cents to be collected for this charge, e.g. enter <code>100</code> for $1.00' ,
2021-07-10 04:15:14 -07:00
typeOptions : {
minValue : 0 ,
maxValue : 99999999 ,
} ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'charge' ] ,
operation : [ 'create' ] ,
2021-07-10 04:15:14 -07:00
} ,
} ,
} ,
{
2022-06-03 10:23:49 -07:00
displayName : 'Currency Name or ID' ,
2021-07-10 04:15:14 -07:00
name : 'currency' ,
type : 'options' ,
typeOptions : {
loadOptionsMethod : 'getCurrencies' ,
} ,
required : true ,
default : '' ,
2022-08-17 08:50:24 -07:00
description :
'Three-letter ISO currency code, e.g. <code>USD</code> or <code>EUR</code>. It must be a <a href="https://stripe.com/docs/currencies">Stripe-supported currency</a>. Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>.' ,
2021-07-10 04:15:14 -07:00
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'charge' ] ,
operation : [ 'create' ] ,
2021-07-10 04:15:14 -07:00
} ,
} ,
} ,
{
displayName : 'Source ID' ,
name : 'source' ,
type : 'string' ,
required : true ,
default : '' ,
2022-08-17 08:50:24 -07:00
description : "ID of the customer's payment source to be charged" ,
2021-07-10 04:15:14 -07:00
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'charge' ] ,
operation : [ 'create' ] ,
2021-07-10 04:15:14 -07:00
} ,
} ,
} ,
{
displayName : 'Additional Fields' ,
name : 'additionalFields' ,
type : 'collection' ,
placeholder : 'Add Field' ,
default : { } ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'charge' ] ,
operation : [ 'create' ] ,
2021-07-10 04:15:14 -07:00
} ,
} ,
options : [
{
displayName : 'Description' ,
name : 'description' ,
type : 'string' ,
default : '' ,
description : 'Arbitrary text to describe the charge to create' ,
} ,
{
displayName : 'Metadata' ,
name : 'metadata' ,
type : 'fixedCollection' ,
default : [ ] ,
placeholder : 'Add Metadata Item' ,
description : 'Set of key-value pairs to attach to the charge to create' ,
typeOptions : {
multipleValues : true ,
} ,
options : [
{
displayName : 'Metadata Properties' ,
name : 'metadataProperties' ,
values : [
{
displayName : 'Key' ,
name : 'key' ,
type : 'string' ,
default : '' ,
} ,
{
displayName : 'Value' ,
name : 'value' ,
type : 'string' ,
default : '' ,
} ,
] ,
} ,
] ,
} ,
{
displayName : 'Receipt Email' ,
name : 'receipt_email' ,
type : 'string' ,
default : '' ,
description : 'Email address to which the receipt for this charge will be sent' ,
} ,
{
displayName : 'Shipping' ,
name : 'shipping' ,
type : 'fixedCollection' ,
description : 'Shipping information for the charge' ,
placeholder : 'Add Field' ,
typeOptions : {
multipleValues : true ,
} ,
default : [ ] ,
options : [
{
displayName : 'Shipping Properties' ,
name : 'shippingProperties' ,
values : [
{
displayName : 'Recipient Name' ,
name : 'name' ,
type : 'string' ,
description : 'Name of the person who will receive the shipment' ,
default : '' ,
} ,
{
displayName : 'Address' ,
name : 'address' ,
type : 'fixedCollection' ,
default : { } ,
placeholder : 'Add Field' ,
options : [
{
displayName : 'Details' ,
name : 'details' ,
values : [
{
displayName : 'Line 1' ,
name : 'line1' ,
description : 'Address line 1 (e.g. street, PO Box, or company name)' ,
type : 'string' ,
default : '' ,
} ,
{
displayName : 'Line 2' ,
name : 'line2' ,
description : 'Address line 2 (e.g. apartment, suite, unit, or building)' ,
type : 'string' ,
default : '' ,
} ,
{
displayName : 'City' ,
name : 'city' ,
description : 'City, district, suburb, town, or village' ,
type : 'string' ,
default : '' ,
} ,
{
displayName : 'State' ,
name : 'state' ,
description : 'State, county, province, or region' ,
type : 'string' ,
default : '' ,
} ,
{
displayName : 'Country' ,
name : 'country' ,
2022-08-17 08:50:24 -07:00
description :
'Two-letter country code (<a href="https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2">ISO 3166-1 alpha-2</a>)' ,
2021-07-10 04:15:14 -07:00
type : 'string' ,
default : '' ,
} ,
{
displayName : 'Postal Code' ,
name : 'postal_code' ,
description : 'ZIP or postal code' ,
type : 'string' ,
default : '' ,
} ,
] ,
} ,
] ,
} ,
] ,
} ,
] ,
} ,
] ,
} ,
// ----------------------------------
// charge: get
// ----------------------------------
{
displayName : 'Charge ID' ,
name : 'chargeId' ,
type : 'string' ,
required : true ,
default : '' ,
2022-05-06 14:01:25 -07:00
description : 'ID of the charge to retrieve' ,
2021-07-10 04:15:14 -07:00
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'charge' ] ,
operation : [ 'get' ] ,
2021-07-10 04:15:14 -07:00
} ,
} ,
} ,
// ----------------------------------
// charge: getAll
// ----------------------------------
{
displayName : 'Return All' ,
name : 'returnAll' ,
type : 'boolean' ,
default : false ,
description : 'Whether to return all results or only up to a given limit' ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'charge' ] ,
operation : [ 'getAll' ] ,
2021-07-10 04:15:14 -07:00
} ,
} ,
} ,
{
displayName : 'Limit' ,
name : 'limit' ,
type : 'number' ,
default : 50 ,
2022-05-06 14:01:25 -07:00
description : 'Max number of results to return' ,
2021-07-10 04:15:14 -07:00
typeOptions : {
minValue : 1 ,
maxValue : 1000 ,
} ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'charge' ] ,
operation : [ 'getAll' ] ,
returnAll : [ false ] ,
2021-07-10 04:15:14 -07:00
} ,
} ,
} ,
// ----------------------------------
// charge: update
// ----------------------------------
{
displayName : 'Charge ID' ,
name : 'chargeId' ,
type : 'string' ,
required : true ,
default : '' ,
description : 'ID of the charge to update' ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'charge' ] ,
operation : [ 'update' ] ,
2021-07-10 04:15:14 -07:00
} ,
} ,
} ,
{
displayName : 'Update Fields' ,
name : 'updateFields' ,
type : 'collection' ,
placeholder : 'Add Field' ,
default : { } ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'charge' ] ,
operation : [ 'update' ] ,
2021-07-10 04:15:14 -07:00
} ,
} ,
options : [
{
displayName : 'Description' ,
name : 'description' ,
type : 'string' ,
default : '' ,
description : 'Arbitrary text to describe the charge to update' ,
} ,
{
displayName : 'Metadata' ,
name : 'metadata' ,
type : 'fixedCollection' ,
2021-12-03 00:44:16 -08:00
default : { } ,
2021-07-10 04:15:14 -07:00
placeholder : 'Add Metadata Item' ,
description : 'Set of key-value pairs to attach to the charge to update' ,
typeOptions : {
multipleValues : true ,
} ,
options : [
{
displayName : 'Metadata Properties' ,
name : 'metadataProperties' ,
values : [
{
displayName : 'Key' ,
name : 'key' ,
type : 'string' ,
default : '' ,
} ,
{
displayName : 'Value' ,
name : 'value' ,
type : 'string' ,
default : '' ,
} ,
] ,
} ,
] ,
} ,
{
displayName : 'Receipt Email' ,
name : 'receipt_email' ,
type : 'string' ,
default : '' ,
description : 'The email address to which the receipt for this charge will be sent' ,
} ,
{
displayName : 'Shipping' ,
name : 'shipping' ,
type : 'fixedCollection' ,
2021-12-03 00:44:16 -08:00
default : { } ,
2021-07-10 04:15:14 -07:00
description : 'Shipping information for the charge' ,
placeholder : 'Add Field' ,
typeOptions : {
multipleValues : true ,
} ,
options : [
{
displayName : 'Shipping Properties' ,
name : 'shippingProperties' ,
default : { } ,
values : [
{
displayName : 'Recipient Name' ,
name : 'name' ,
type : 'string' ,
default : '' ,
} ,
{
displayName : 'Recipient Address' ,
name : 'address' ,
type : 'fixedCollection' ,
default : { } ,
placeholder : 'Add Address Details' ,
options : [
{
displayName : 'Details' ,
name : 'details' ,
values : [
{
displayName : 'Line 1' ,
name : 'line1' ,
description : 'Address line 1 (e.g. street, PO Box, or company name)' ,
type : 'string' ,
default : '' ,
} ,
{
displayName : 'Line 2' ,
name : 'line2' ,
description : 'Address line 2 (e.g. apartment, suite, unit, or building)' ,
type : 'string' ,
default : '' ,
} ,
{
displayName : 'City' ,
name : 'city' ,
description : 'City, district, suburb, town, or village' ,
type : 'string' ,
default : '' ,
} ,
{
displayName : 'State' ,
name : 'state' ,
description : 'State, county, province, or region' ,
type : 'string' ,
default : '' ,
} ,
{
displayName : 'Country' ,
name : 'country' ,
2022-08-17 08:50:24 -07:00
description :
'Two-letter country code (<a href="https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2">ISO 3166-1 alpha-2</a>)' ,
2021-07-10 04:15:14 -07:00
type : 'string' ,
default : '' ,
} ,
{
displayName : 'Postal Code' ,
name : 'postal_code' ,
description : 'ZIP or postal code' ,
type : 'string' ,
default : '' ,
} ,
] ,
} ,
] ,
} ,
] ,
} ,
] ,
} ,
] ,
} ,
2021-12-03 00:44:16 -08:00
] ;