Compare commits
3 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 08c7556960 | |||
| d9bfa5ff7f | |||
|
|
b70e95ac5c |
@@ -4,8 +4,10 @@ import "resty.dev/v3"
|
|||||||
|
|
||||||
type Client struct {
|
type Client struct {
|
||||||
token string
|
token string
|
||||||
|
device string
|
||||||
resty *resty.Client
|
resty *resty.Client
|
||||||
apiBaseURL string
|
apiBaseURL string
|
||||||
|
fiscalEndpoint string
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewClient(token string) *Client {
|
func NewClient(token string) *Client {
|
||||||
@@ -13,5 +15,16 @@ func NewClient(token string) *Client {
|
|||||||
token: token,
|
token: token,
|
||||||
resty: resty.New(),
|
resty: resty.New(),
|
||||||
apiBaseURL: "https://kasa.vchasno.ua/api/v3",
|
apiBaseURL: "https://kasa.vchasno.ua/api/v3",
|
||||||
|
fiscalEndpoint: "/fiscal/execute",
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewDMClient(token, dmURL, device string) *Client {
|
||||||
|
return &Client{
|
||||||
|
token: token,
|
||||||
|
device: device,
|
||||||
|
resty: resty.New(),
|
||||||
|
apiBaseURL: dmURL,
|
||||||
|
fiscalEndpoint: "/dm/fiscal",
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,7 +8,8 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func (c *Client) executeRequest(ctx context.Context, request FiscalRequest, response interface{}) error {
|
func (c *Client) executeRequest(ctx context.Context, request FiscalRequest, response interface{}) error {
|
||||||
//execute request with json body in request
|
request.Device = c.device
|
||||||
|
|
||||||
reqJson, err := json.Marshal(request)
|
reqJson, err := json.Marshal(request)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("failed to marshal request: %w", err)
|
return fmt.Errorf("failed to marshal request: %w", err)
|
||||||
@@ -18,7 +19,7 @@ func (c *Client) executeRequest(ctx context.Context, request FiscalRequest, resp
|
|||||||
SetContext(ctx).
|
SetContext(ctx).
|
||||||
SetHeader("Authorization", c.token).
|
SetHeader("Authorization", c.token).
|
||||||
SetBody(reqJson).
|
SetBody(reqJson).
|
||||||
Post(c.apiBaseURL + "/fiscal/execute")
|
Post(c.apiBaseURL + c.fiscalEndpoint)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("request failed: %w", err)
|
return fmt.Errorf("request failed: %w", err)
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ package api
|
|||||||
|
|
||||||
type FiscalRequest struct {
|
type FiscalRequest struct {
|
||||||
Source string `json:"source"`
|
Source string `json:"source"`
|
||||||
|
Device string `json:"device,omitempty"`
|
||||||
Userinfo Userinfo `json:"userinfo,omitempty"`
|
Userinfo Userinfo `json:"userinfo,omitempty"`
|
||||||
Fiscal Fiscal `json:"fiscal"`
|
Fiscal Fiscal `json:"fiscal"`
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -10,6 +10,7 @@ func ExampleBasicUsage() {
|
|||||||
Token: "your-token",
|
Token: "your-token",
|
||||||
Cashier: "Иванов",
|
Cashier: "Иванов",
|
||||||
Source: "parking",
|
Source: "parking",
|
||||||
|
CustomURL: "DM URL/",
|
||||||
})
|
})
|
||||||
|
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
|
|||||||
31
vchasno.go
31
vchasno.go
@@ -30,6 +30,8 @@ type Config struct {
|
|||||||
Cashier string
|
Cashier string
|
||||||
Source string
|
Source string
|
||||||
Defaults *DefaultParams
|
Defaults *DefaultParams
|
||||||
|
CustomURL string
|
||||||
|
Device string
|
||||||
}
|
}
|
||||||
|
|
||||||
type DefaultParams struct {
|
type DefaultParams struct {
|
||||||
@@ -65,8 +67,15 @@ func NewClient(config Config) *Client {
|
|||||||
defaults.DefaultTimeout = 30 * time.Second
|
defaults.DefaultTimeout = 30 * time.Second
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var apicfg *api.Client
|
||||||
|
if config.CustomURL == "" {
|
||||||
|
apicfg = api.NewClient(config.Token)
|
||||||
|
} else {
|
||||||
|
apicfg = api.NewDMClient(config.Token, config.CustomURL, config.Device)
|
||||||
|
}
|
||||||
|
|
||||||
return &Client{
|
return &Client{
|
||||||
api: api.NewClient(config.Token),
|
api: apicfg,
|
||||||
cashier: config.Cashier,
|
cashier: config.Cashier,
|
||||||
source: config.Source,
|
source: config.Source,
|
||||||
defaults: defaults,
|
defaults: defaults,
|
||||||
@@ -274,3 +283,23 @@ func (c *Client) QuickSellNamed(ctx context.Context, name string, price float64)
|
|||||||
Price: price,
|
Price: price,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *Client) ZeroReceipt(ctx context.Context) (*api.SellResponse, error) {
|
||||||
|
return c.api.Sell(ctx, api.SellParams{
|
||||||
|
Cashier: c.cashier,
|
||||||
|
Source: c.source,
|
||||||
|
Rows: []api.ReceiptRow{},
|
||||||
|
Pays: []api.ReceiptPay{},
|
||||||
|
CommentUP: "Нульовий чек",
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Client) ZeroReceiptWithTimeout(timeout time.Duration) (*api.SellResponse, error) {
|
||||||
|
ctx, cancel := context.WithTimeout(context.Background(), timeout)
|
||||||
|
defer cancel()
|
||||||
|
return c.ZeroReceipt(ctx)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Client) ZeroReceiptDefault() (*api.SellResponse, error) {
|
||||||
|
return c.ZeroReceiptWithTimeout(c.defaults.DefaultTimeout)
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user