Compare commits
9 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 08c7556960 | |||
| d9bfa5ff7f | |||
|
|
b70e95ac5c | ||
| ac4f4670bb | |||
| 4a8b5cf0c5 | |||
| b33620f629 | |||
| 8006fd0935 | |||
| 4f9ca56157 | |||
| 328447f079 |
@@ -3,15 +3,28 @@ package api
|
||||
import "resty.dev/v3"
|
||||
|
||||
type Client struct {
|
||||
token string
|
||||
resty *resty.Client
|
||||
apiBaseURL string
|
||||
token string
|
||||
device string
|
||||
resty *resty.Client
|
||||
apiBaseURL string
|
||||
fiscalEndpoint string
|
||||
}
|
||||
|
||||
func NewClient(token string) *Client {
|
||||
return &Client{
|
||||
token: token,
|
||||
resty: resty.New(),
|
||||
apiBaseURL: "https://kasa.vchasno.ua/api/v3",
|
||||
token: token,
|
||||
resty: resty.New(),
|
||||
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,11 +8,18 @@ import (
|
||||
)
|
||||
|
||||
func (c *Client) executeRequest(ctx context.Context, request FiscalRequest, response interface{}) error {
|
||||
request.Device = c.device
|
||||
|
||||
reqJson, err := json.Marshal(request)
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to marshal request: %w", err)
|
||||
}
|
||||
|
||||
resp, err := c.resty.R().
|
||||
SetContext(ctx).
|
||||
SetHeader("Authorization", c.token).
|
||||
SetBody(request).
|
||||
Post(c.apiBaseURL + "/fiscal/execute")
|
||||
SetBody(reqJson).
|
||||
Post(c.apiBaseURL + c.fiscalEndpoint)
|
||||
|
||||
if err != nil {
|
||||
return fmt.Errorf("request failed: %w", err)
|
||||
@@ -71,15 +78,16 @@ func (c *Client) CloseShift(ctx context.Context, cashier string) (*ZReportRespon
|
||||
}
|
||||
|
||||
type SellParams struct {
|
||||
Cashier string
|
||||
Source string
|
||||
Rows []ReceiptRow
|
||||
Pays []ReceiptPay
|
||||
Userinfo *Userinfo
|
||||
Cashier string
|
||||
Source string
|
||||
Rows []ReceiptRow
|
||||
Pays []ReceiptPay
|
||||
Userinfo *Userinfo
|
||||
CommentUP string
|
||||
}
|
||||
|
||||
func (c *Client) Sell(ctx context.Context, params SellParams) (*SellResponse, error) {
|
||||
receipt := NewReceipt(params.Rows, params.Pays)
|
||||
receipt := NewReceipt(params.Rows, params.Pays, params.CommentUP)
|
||||
|
||||
request := FiscalRequest{
|
||||
Source: params.Source,
|
||||
|
||||
@@ -39,13 +39,14 @@ func CalculateReceiptSum(rows []ReceiptRow) float64 {
|
||||
return sum
|
||||
}
|
||||
|
||||
func NewReceipt(rows []ReceiptRow, pays []ReceiptPay) Receipt {
|
||||
func NewReceipt(rows []ReceiptRow, pays []ReceiptPay, commentUp string) Receipt {
|
||||
return Receipt{
|
||||
Sum: CalculateReceiptSum(rows),
|
||||
Round: 0.00,
|
||||
Disc: 0,
|
||||
DiscType: 0,
|
||||
Rows: rows,
|
||||
Pays: pays,
|
||||
Sum: CalculateReceiptSum(rows),
|
||||
Round: 0.00,
|
||||
CommentUp: commentUp,
|
||||
Disc: 0,
|
||||
DiscType: 0,
|
||||
Rows: rows,
|
||||
Pays: pays,
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,6 +2,7 @@ package api
|
||||
|
||||
type FiscalRequest struct {
|
||||
Source string `json:"source"`
|
||||
Device string `json:"device,omitempty"`
|
||||
Userinfo Userinfo `json:"userinfo,omitempty"`
|
||||
Fiscal Fiscal `json:"fiscal"`
|
||||
}
|
||||
|
||||
@@ -7,9 +7,10 @@ import (
|
||||
|
||||
func ExampleBasicUsage() {
|
||||
client := NewClient(Config{
|
||||
Token: "your-token",
|
||||
Cashier: "Иванов",
|
||||
Source: "parking",
|
||||
Token: "your-token",
|
||||
Cashier: "Иванов",
|
||||
Source: "parking",
|
||||
CustomURL: "DM URL/",
|
||||
})
|
||||
|
||||
ctx := context.Background()
|
||||
|
||||
56
vchasno.go
56
vchasno.go
@@ -26,10 +26,12 @@ type Client struct {
|
||||
}
|
||||
|
||||
type Config struct {
|
||||
Token string
|
||||
Cashier string
|
||||
Source string
|
||||
Defaults *DefaultParams
|
||||
Token string
|
||||
Cashier string
|
||||
Source string
|
||||
Defaults *DefaultParams
|
||||
CustomURL string
|
||||
Device string
|
||||
}
|
||||
|
||||
type DefaultParams struct {
|
||||
@@ -65,8 +67,15 @@ func NewClient(config Config) *Client {
|
||||
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{
|
||||
api: api.NewClient(config.Token),
|
||||
api: apicfg,
|
||||
cashier: config.Cashier,
|
||||
source: config.Source,
|
||||
defaults: defaults,
|
||||
@@ -99,6 +108,7 @@ type SellParams struct {
|
||||
PayType int
|
||||
CardParams *CardParams
|
||||
Userinfo *api.Userinfo
|
||||
CommentUP string
|
||||
}
|
||||
|
||||
type CardParams struct {
|
||||
@@ -158,6 +168,11 @@ func (b *SellParamsBuilder) Comment(comment string) *SellParamsBuilder {
|
||||
return b
|
||||
}
|
||||
|
||||
func (b *SellParamsBuilder) CommentUp(commentUp string) *SellParamsBuilder {
|
||||
b.params.CommentUP = commentUp
|
||||
return b
|
||||
}
|
||||
|
||||
func (b *SellParamsBuilder) PayCash() *SellParamsBuilder {
|
||||
b.params.PayType = PayTypeCash
|
||||
b.params.CardParams = nil
|
||||
@@ -241,11 +256,12 @@ func (c *Client) Sell(ctx context.Context, params SellParams) (*api.SellResponse
|
||||
}
|
||||
|
||||
return c.api.Sell(ctx, api.SellParams{
|
||||
Cashier: c.cashier,
|
||||
Source: c.source,
|
||||
Rows: []api.ReceiptRow{row},
|
||||
Pays: []api.ReceiptPay{pay},
|
||||
Userinfo: params.Userinfo,
|
||||
Cashier: c.cashier,
|
||||
Source: c.source,
|
||||
Rows: []api.ReceiptRow{row},
|
||||
Pays: []api.ReceiptPay{pay},
|
||||
Userinfo: params.Userinfo,
|
||||
CommentUP: params.CommentUP,
|
||||
})
|
||||
}
|
||||
|
||||
@@ -267,3 +283,23 @@ func (c *Client) QuickSellNamed(ctx context.Context, name string, price float64)
|
||||
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