Skip to content

Latest commit

 

History

History
210 lines (164 loc) · 13.6 KB

README.md

File metadata and controls

210 lines (164 loc) · 13.6 KB

Purchaseorders

(Accounting.Purchaseorders)

Overview

Available Operations

  • List - List PurchaseOrders
  • Create - Create Purchase Orders
  • Retrieve - Retrieve Purchase Orders

List

List PurchaseOrders

Example Usage

package main

import(
	gosdk "github.com/panoratech/go-sdk"
	"context"
	"log"
)

func main() {
    s := gosdk.New(
        gosdk.WithSecurity("<YOUR_API_KEY_HERE>"),
    )

    ctx := context.Background()
    res, err := s.Accounting.Purchaseorders.List(ctx, "<value>", gosdk.Bool(true), gosdk.Float64(10), gosdk.String("1b8b05bb-5273-4012-b520-8657b0b90874"))
    if err != nil {
        log.Fatal(err)
    }
    if res.Object != nil {
                for {
            // handle items
        
            res, err = res.Next()
        
            if err != nil {
                // handle error
            }
        
            if res == nil {
                break
            }
        }
        
    }
}

Parameters

Parameter Type Required Description Example
ctx context.Context ✔️ The context to use for the request.
xConnectionToken string ✔️ The connection token
remoteData *bool Set to true to include data from the original software. true
limit *float64 Set to get the number of records. 10
cursor *string Set to get the number of records after this cursor. 1b8b05bb-5273-4012-b520-8657b0b90874
opts []operations.Option The options for this request.

Response

*operations.ListAccountingPurchaseOrderResponse, error

Errors

Error Type Status Code Content Type
sdkerrors.SDKError 4XX, 5XX */*

Create

Create Purchase Orders in any supported Accounting software

Example Usage

package main

import(
	gosdk "github.com/panoratech/go-sdk"
	"context"
	"github.com/panoratech/go-sdk/types"
	"github.com/panoratech/go-sdk/models/components"
	"log"
)

func main() {
    s := gosdk.New(
        gosdk.WithSecurity("<YOUR_API_KEY_HERE>"),
    )

    ctx := context.Background()
    res, err := s.Accounting.Purchaseorders.Create(ctx, "<value>", components.UnifiedAccountingPurchaseorderInput{
        Status: gosdk.String("Pending"),
        IssueDate: types.MustNewTimeFromString("2024-06-15T12:00:00Z"),
        PurchaseOrderNumber: gosdk.String("PO-001"),
        DeliveryDate: types.MustNewTimeFromString("2024-07-15T12:00:00Z"),
        DeliveryAddress: gosdk.String("801f9ede-c698-4e66-a7fc-48d19eebaa4f"),
        Customer: gosdk.String("801f9ede-c698-4e66-a7fc-48d19eebaa4f"),
        Vendor: gosdk.String("801f9ede-c698-4e66-a7fc-48d19eebaa4f"),
        Memo: gosdk.String("Purchase order for Q3 inventory"),
        CompanyID: gosdk.String("801f9ede-c698-4e66-a7fc-48d19eebaa4f"),
        TotalAmount: gosdk.Float64(100000),
        Currency: gosdk.String("USD"),
        ExchangeRate: gosdk.String("1.2"),
        TrackingCategories: []string{
            "801f9ede-c698-4e66-a7fc-48d19eebaa4f",
        },
        AccountingPeriodID: gosdk.String("801f9ede-c698-4e66-a7fc-48d19eebaa4f"),
        LineItems: []components.LineItem{
            components.LineItem{
                Name: gosdk.String("Net Income"),
                Value: gosdk.Float64(100000),
                Type: gosdk.String("Operating Activities"),
                ParentItem: gosdk.String("801f9ede-c698-4e66-a7fc-48d19eebaa4f"),
                RemoteID: gosdk.String("report_item_1234"),
                RemoteGeneratedAt: types.MustNewTimeFromString("2024-07-01T12:00:00Z"),
                CompanyInfoID: gosdk.String("801f9ede-c698-4e66-a7fc-48d19eebaa4f"),
                CreatedAt: types.MustNewTimeFromString("2024-06-15T12:00:00Z"),
                ModifiedAt: types.MustNewTimeFromString("2024-06-15T12:00:00Z"),
            },
        },
        FieldMappings: &components.UnifiedAccountingPurchaseorderInputFieldMappings{},
    }, gosdk.Bool(false))
    if err != nil {
        log.Fatal(err)
    }
    if res.UnifiedAccountingPurchaseorderOutput != nil {
        // handle response
    }
}

Parameters

Parameter Type Required Description Example
ctx context.Context ✔️ The context to use for the request.
xConnectionToken string ✔️ The connection token
unifiedAccountingPurchaseorderInput components.UnifiedAccountingPurchaseorderInput ✔️ N/A
remoteData *bool Set to true to include data from the original Accounting software. false
opts []operations.Option The options for this request.

Response

*operations.CreateAccountingPurchaseOrderResponse, error

Errors

Error Type Status Code Content Type
sdkerrors.SDKError 4XX, 5XX */*

Retrieve

Retrieve Purchase Orders from any connected Accounting software

Example Usage

package main

import(
	gosdk "github.com/panoratech/go-sdk"
	"context"
	"log"
)

func main() {
    s := gosdk.New(
        gosdk.WithSecurity("<YOUR_API_KEY_HERE>"),
    )

    ctx := context.Background()
    res, err := s.Accounting.Purchaseorders.Retrieve(ctx, "<value>", "801f9ede-c698-4e66-a7fc-48d19eebaa4f", gosdk.Bool(false))
    if err != nil {
        log.Fatal(err)
    }
    if res.UnifiedAccountingPurchaseorderOutput != nil {
        // handle response
    }
}

Parameters

Parameter Type Required Description Example
ctx context.Context ✔️ The context to use for the request.
xConnectionToken string ✔️ The connection token
id string ✔️ id of the purchaseorder you want to retrieve. 801f9ede-c698-4e66-a7fc-48d19eebaa4f
remoteData *bool Set to true to include data from the original Accounting software. false
opts []operations.Option The options for this request.

Response

*operations.RetrieveAccountingPurchaseOrderResponse, error

Errors

Error Type Status Code Content Type
sdkerrors.SDKError 4XX, 5XX */*