Skip to content

Commit

Permalink
cct exports api doc
Browse files Browse the repository at this point in the history
  • Loading branch information
madangopal122 committed Nov 7, 2024
1 parent a65e9f3 commit 25494a5
Show file tree
Hide file tree
Showing 4 changed files with 239 additions and 0 deletions.
2 changes: 2 additions & 0 deletions src/admin/openapi.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -353,6 +353,8 @@ paths:
$ref: paths/admin@[email protected]
/admin/corporate_card_transactions/unmatch:
$ref: paths/admin@[email protected]
/admin/corporate_card_transactions/exports:
$ref: paths/admin@[email protected]

/admin/virtual_cards:
$ref: paths/admin@virtual_cards.yaml
Expand Down
46 changes: 46 additions & 0 deletions src/admin/paths/admin@[email protected]
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
post:
tags:
- Corporate Card Transactions
summary: Create Corproate Card Transactions Export
description: |
Create Corporate Card Transactions Export Request.
operationId: corporate_card_transactions_exports_post
requestBody:
required: true
content:
application/json:
schema:
type: object
properties:
data:
$ref: '../../components/schemas/corporate_card_transactions_exports.yaml#/corporate_card_transactions_exports_in'
required:
- data
responses:
'200':
description: OK
content:
application/json:
schema:
type: object
properties:
data:
$ref: '../../components/schemas/corporate_card_transactions_exports.yaml#/corporate_card_transactions_exports_out'
'400':
description: Bad request
content:
application/json:
schema:
$ref: '../../components/schemas/400.yaml'
'401':
description: Unauthorized request
content:
application/json:
schema:
$ref: '../../components/schemas/401.yaml'
'403':
description: Forbidden
content:
application/json:
schema:
$ref: '../../components/schemas/403.yaml'
167 changes: 167 additions & 0 deletions src/components/schemas/corporate_card_transactions_exports.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,167 @@
corporate_card_transactions_export_config_column_formula:
type: object
properties:
function:
type: string
example: parse-format-time
parameters:
type: array
items:
anyOf:
- type: object
- type: string
- type: number
- type: integer
- type: boolean
example:
- function: field
parameters: ['spent_at']
- yyyy-MM-dd'T'HH:mm:ss
- dd-MM-yyyy
- error in date formatting
description: |
Export column formula is a expression that is used to transform the data. Refer https://help.fylehq.com/en/articles/4422306-advanced-export-formulas for more details.
corporate_card_transactions_export_config:
type: object
additionalProperties: true
properties:
type:
type: string
enum:
- xlsx
- csv
description: |
Type of the export file.
example: csv
is_header_visible:
type: boolean
description: |
Whether to show the header in the export file. Only required for CSV and XLSX exports.
example: true
separate_line_items_entry:
type: object
properties:
enabled:
type: boolean
description: |
Whether to show the double rows for each line item in the export file.
example: false
debit_entries_only:
type: array
items:
type: string
description: |
Configure which columns to show for debit entries.
example: ['debit_amount']
credit_entries_only:
type: array
items:
type: string
description: |
Configure which columns to show for credit entries.
example: ['credit_amount']
description: |
Configure how to show the double rows for each line item in the export file, if enabled. Only required for CSV and XLSX exports.
columns:
type: array
items:
type: object
properties:
name:
type: string
description: |
Name of the column.
example: Spent Date
formula:
allOf:
- $ref: '#/corporate_card_transactions_export_config_column_formula'
description: |
Formula to transform the data in the column.
description: |
Configure the columns to show in the export file. Only required for CSV and XLSX exports.
corporate_card_transactions_exports_in:
type: object
additionalProperties: false
required:
- query_params
- notify_emails
- config
properties:
query_params:
allOf:
- $ref: './fields.yaml#/query_params'
nullable: false
notify_emails:
type: array
nullable: false
items:
$ref: './fields.yaml#/email'
description: |
List of emails to notify when the export is ready.
config:
allOf:
- $ref: '#/corporate_card_transactions_export_config'
nullable: false
description: |
Configuration for the export.
corporate_card_transactions_exports_out:
type: object
additionalProperties: false
properties:
created_at:
$ref: './fields.yaml#/created_at'
updated_at:
$ref: './fields.yaml#/updated_at'
id:
allOf:
- $ref: './fields.yaml#/id_string'
example: refilumWHrlPf7K
org_id:
$ref: './fields.yaml#/org_id'
user_id:
$ref: './fields.yaml#/user_id'
query_params:
allOf:
- $ref: './fields.yaml#/query_params'
nullable: false
notify_emails:
type: array
nullable: false
items:
$ref: './fields.yaml#/email'
config:
allOf:
- $ref: '#/corporate_card_transactions_export_config'
nullable: false
file_id:
anyOf:
- $ref: './fields.yaml#/null_field'
- $ref: './fields.yaml#/id_string'
nullable: true
example: filumVIrlPf7K
state:
type: string
nullable: false
enum:
- PENDING
- PROCESSING
- COMPLETED
- FAILED
description: |
Status of the export.
example: PENDING
processed_at:
$ref: './fields.yaml#/processed_at'
nullable: true
completed_at:
$ref: './fields.yaml#/completed_at'
nullable: true
failed_at:
$ref: './fields.yaml#/failed_at'
nullable: true
24 changes: 24 additions & 0 deletions src/components/schemas/fields.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -99,6 +99,30 @@ updated_at:
Signifies when this object was updated in [ISO8601 format](https://xml2rfc.tools.ietf.org/public/rfc/html/rfc3339.html#anchor14).
example: '2020-06-11T13:14:55.201598+00:00'

processed_at:
type: string
format: date-time
nullable: true
description: |
Signifies when this was processed in [ISO8601 format](https://xml2rfc.tools.ietf.org/public/rfc/html/rfc3339.html#anchor14).
example: '2020-06-11T13:14:55.201598+00:00'

completed_at:
type: string
format: date-time
nullable: true
description: |
Signifies when this was completed in [ISO8601 format](https://xml2rfc.tools.ietf.org/public/rfc/html/rfc3339.html#anchor14).
example: '2020-06-11T13:14:55.201598+00:00'

failed_at:
type: string
format: date-time
nullable: true
description: |
Signifies when this was failed in [ISO8601 format](https://xml2rfc.tools.ietf.org/public/rfc/html/rfc3339.html#anchor14).
example: '2020-06-11T13:14:55.201598+00:00'

is_enabled:
type: boolean
description: |
Expand Down

0 comments on commit 25494a5

Please sign in to comment.