Skip to content

Commit

Permalink
adds merchant & pos operations
Browse files Browse the repository at this point in the history
  • Loading branch information
Alican Akkus authored and Alican Akkus committed Dec 1, 2023
1 parent 1720346 commit 2dbdbec
Show file tree
Hide file tree
Showing 6 changed files with 506 additions and 2 deletions.
2 changes: 2 additions & 0 deletions adapter/craftgate.go
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,7 @@ type Client struct {
Hook *Hook
Masterpass *Masterpass
BankAccountTracking *BankAccountTracking
Merchant *Merchant
}

func New(apiKey, apiSecret, baseURL string, opts ...ClientOption) (*Client, error) {
Expand Down Expand Up @@ -121,6 +122,7 @@ func newClient(apiKey, secretKey string) *Client {
client.Hook = &Hook{Client: client}
client.Masterpass = &Masterpass{Client: client}
client.BankAccountTracking = &BankAccountTracking{Client: client}
client.Merchant = &Merchant{Client: client}

return client
}
Expand Down
176 changes: 176 additions & 0 deletions adapter/merchant.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,176 @@
package adapter

import (
"context"
"fmt"
"net/http"
)

type Merchant struct {
Client *Client
}

func (api *Merchant) CreateMerchantPos(ctx context.Context, request CreateMerchantPosRequest) (*MerchantPosResponse, error) {
newRequest, err := api.Client.NewRequest(ctx, http.MethodPost, "/merchant/v1/merchant-poses", request)

if err != nil {
return nil, err
}

response := &Response[MerchantPosResponse]{}
err = api.Client.Do(ctx, newRequest, response)
if err != nil {
return nil, err
}
return response.Data, nil
}

func (api *Merchant) RetrieveMerchantPos(ctx context.Context, id int64) (*MerchantPosResponse, error) {
newRequest, err := api.Client.NewRequest(ctx, http.MethodGet, fmt.Sprintf("/merchant/v1/merchant-poses/%d", id), nil)

if err != nil {
return nil, err
}

response := &Response[MerchantPosResponse]{}
err = api.Client.Do(ctx, newRequest, response)
if err != nil {
return nil, err
}
return response.Data, nil
}

func (api *Merchant) SearchMerchantPos(ctx context.Context, request SearchMerchantPosRequest) (*DataResponse[MerchantPosResponse], error) {
newRequest, err := api.Client.NewRequest(ctx, http.MethodGet, "/merchant/v1/merchant-poses", request)

if err != nil {
return nil, err
}

response := &Response[DataResponse[MerchantPosResponse]]{}
err = api.Client.Do(ctx, newRequest, response)
if err != nil {
return nil, err
}
return response.Data, nil
}

func (api *Merchant) UpdateMerchantPosStatus(ctx context.Context, id int64, status PosStatus) error {
newRequest, err := api.Client.NewRequest(ctx, http.MethodPut, fmt.Sprintf("/merchant/v1/merchant-poses/%d/status/%s", id, status), nil)

if err != nil {
return err
}

response := &Void{}
err = api.Client.Do(ctx, newRequest, response)
if err != nil {
return err
}
return nil
}

func (api *Merchant) DeleteMerchantPosStatus(ctx context.Context, id int64) error {
newRequest, err := api.Client.NewRequest(ctx, http.MethodDelete, fmt.Sprintf("/merchant/v1/merchant-poses/%d", id), nil)

if err != nil {
return err
}

response := &Void{}
err = api.Client.Do(ctx, newRequest, response)
if err != nil {
return err
}
return nil
}

func (api *Merchant) RetrieveMerchantPosCommissions(ctx context.Context, id int64) (*DataResponse[MerchantPosCommissionResponse], error) {
newRequest, err := api.Client.NewRequest(ctx, http.MethodGet, fmt.Sprintf("/merchant/v1/merchant-poses/%d/commissions", id), nil)

if err != nil {
return nil, err
}

response := &Response[DataResponse[MerchantPosCommissionResponse]]{}
err = api.Client.Do(ctx, newRequest, response)
if err != nil {
return nil, err
}
return response.Data, nil
}

func (api *Merchant) UpdateMerchantPosCommissions(ctx context.Context, id int64, request CreateMerchantPosCommissionRequest) (*DataResponse[MerchantPosCommissionResponse], error) {
newRequest, err := api.Client.NewRequest(ctx, http.MethodPost, fmt.Sprintf("/merchant/v1/merchant-poses/%d/commissions", id), request)

if err != nil {
return nil, err
}

response := &Response[DataResponse[MerchantPosCommissionResponse]]{}
err = api.Client.Do(ctx, newRequest, response)
if err != nil {
return nil, err
}
return response.Data, nil
}

//func (api *Onboarding) UpdateMember(ctx context.Context, id int64, request UpdateMemberRequest) (*MemberResponse, error) {
// newRequest, err := api.Client.NewRequest(ctx, http.MethodPut, fmt.Sprintf("/onboarding/v1/members/%d", id), request)
// if err != nil {
// return nil, err
// }
//
// response := &Response[MemberResponse]{}
// err = api.Client.Do(ctx, newRequest, response)
// if err != nil {
// return nil, err
// }
//
// return response.Data, nil
//}
//
//func (api *Onboarding) RetrieveMember(ctx context.Context, id int64) (*MemberResponse, error) {
// newRequest, err := api.Client.NewRequest(ctx, http.MethodGet, fmt.Sprintf("/onboarding/v1/members/%d", id), nil)
// if err != nil {
// return nil, err
// }
//
// response := &Response[MemberResponse]{}
// err = api.Client.Do(ctx, newRequest, response)
// if err != nil {
// return nil, err
// }
//
// return response.Data, nil
//}
//
//func (api *Onboarding) SearchMembers(ctx context.Context, request SearchMembersRequest) (*DataResponse[MemberResponse], error) {
// newRequest, err := api.Client.NewRequest(ctx, http.MethodGet, "/onboarding/v1/members", request)
// if err != nil {
// return nil, err
// }
//
// response := &Response[DataResponse[MemberResponse]]{}
// err = api.Client.Do(ctx, newRequest, response)
// if err != nil {
// return nil, err
// }
//
// return response.Data, nil
//}
//
//func (api *Onboarding) CreateMerchant(ctx context.Context, request CreateMerchantRequest) (*CreateMerchantResponse, error) {
// newRequest, err := api.Client.NewRequest(ctx, http.MethodPost, "/onboarding/v1/merchants", request)
//
// if err != nil {
// return nil, err
// }
//
// response := &Response[CreateMerchantResponse]{}
// err = api.Client.Do(ctx, newRequest, response)
// if err != nil {
// return nil, err
// }
// return response.Data, nil
//}
Loading

0 comments on commit 2dbdbec

Please sign in to comment.