2 Commits

Author SHA1 Message Date
23779ad6ad Fix Docno type 2026-01-29 13:13:43 +03:00
f23c4ffd1c Add isDM flag to Client and update FiscalRequest structure for DM support 2026-01-16 02:41:11 +03:00
4 changed files with 33 additions and 20 deletions

View File

@@ -9,6 +9,7 @@ import (
type Client struct { type Client struct {
token string token string
device string device string
isDM bool
resty *resty.Client resty *resty.Client
apiBaseURL string apiBaseURL string
fiscalEndpoint string fiscalEndpoint string
@@ -17,6 +18,7 @@ type Client struct {
func NewClient(token string) *Client { func NewClient(token string) *Client {
return &Client{ return &Client{
token: token, token: token,
isDM: false,
resty: resty.New(), resty: resty.New(),
apiBaseURL: "https://kasa.vchasno.ua/api/v3", apiBaseURL: "https://kasa.vchasno.ua/api/v3",
fiscalEndpoint: "/fiscal/execute", fiscalEndpoint: "/fiscal/execute",
@@ -38,6 +40,7 @@ func NewDMClient(token, dmURL, device string) *Client {
return &Client{ return &Client{
token: token, token: token,
device: device, device: device,
isDM: true,
resty: restyClient, resty: restyClient,
apiBaseURL: dmURL, apiBaseURL: dmURL,
fiscalEndpoint: "/dm/execute", fiscalEndpoint: "/dm/execute",

View File

@@ -20,6 +20,11 @@ func (e *APIError) Error() string {
func (c *Client) executeRequest(ctx context.Context, request FiscalRequest, response interface{}) error { func (c *Client) executeRequest(ctx context.Context, request FiscalRequest, response interface{}) error {
request.Device = c.device request.Device = c.device
if c.isDM {
request.Ver = 6
request.Type = 1
}
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)
@@ -72,7 +77,6 @@ func (c *Client) OpenShift(ctx context.Context, cashier string) (*SellResponse,
request := FiscalRequest{ request := FiscalRequest{
Fiscal: Fiscal{ Fiscal: Fiscal{
Task: TaskOpenShift, Task: TaskOpenShift,
Cashier: cashier,
}, },
} }
@@ -88,7 +92,6 @@ func (c *Client) CloseShift(ctx context.Context, cashier string) (*ZReportRespon
request := FiscalRequest{ request := FiscalRequest{
Fiscal: Fiscal{ Fiscal: Fiscal{
Task: TaskZReport, Task: TaskZReport,
Cashier: cashier,
}, },
} }

View File

@@ -1,8 +1,11 @@
package api package api
type FiscalRequest struct { type FiscalRequest struct {
Source string `json:"source"` Ver int `json:"ver,omitempty"`
Source string `json:"source,omitempty"`
Device string `json:"device,omitempty"` Device string `json:"device,omitempty"`
Tag string `json:"tag,omitempty"`
Type int `json:"type,omitempty"`
Userinfo Userinfo `json:"userinfo,omitempty"` Userinfo Userinfo `json:"userinfo,omitempty"`
Fiscal Fiscal `json:"fiscal"` Fiscal Fiscal `json:"fiscal"`
} }
@@ -14,7 +17,7 @@ type Userinfo struct {
type Fiscal struct { type Fiscal struct {
Task int `json:"task"` Task int `json:"task"`
Cashier string `json:"cashier"` Cashier string `json:"cashier,omitempty"`
Receipt *Receipt `json:"receipt,omitempty"` Receipt *Receipt `json:"receipt,omitempty"`
} }

View File

@@ -36,6 +36,7 @@ type SellInfo struct {
Fisid string `json:"fisid"` Fisid string `json:"fisid"`
Dataid int `json:"dataid"` Dataid int `json:"dataid"`
Doccode string `json:"doccode"` Doccode string `json:"doccode"`
Docno interface{} `json:"docno"`
Dt string `json:"dt"` Dt string `json:"dt"`
Cashier string `json:"cashier"` Cashier string `json:"cashier"`
Dtype int `json:"dtype"` Dtype int `json:"dtype"`
@@ -43,8 +44,11 @@ type SellInfo struct {
Isoffline bool `json:"isoffline"` Isoffline bool `json:"isoffline"`
Safe float64 `json:"safe"` Safe float64 `json:"safe"`
ShiftLink int `json:"shift_link"` ShiftLink int `json:"shift_link"`
Docno int `json:"docno"` ShiftPrevLink int `json:"shift_prev_link"`
ShiftID string `json:"shift_id"`
OpenShiftDt string `json:"open_shift_dt"`
Cancelid string `json:"cancelid,omitempty"` Cancelid string `json:"cancelid,omitempty"`
SafeStartShift float64 `json:"safe_start_shift"`
} }
type ZReportResponse struct { type ZReportResponse struct {
@@ -57,6 +61,7 @@ type ZReportInfo struct {
Fisid string `json:"fisid"` Fisid string `json:"fisid"`
Dataid int `json:"dataid"` Dataid int `json:"dataid"`
Doccode string `json:"doccode"` Doccode string `json:"doccode"`
Docno interface{} `json:"docno"`
Dt string `json:"dt"` Dt string `json:"dt"`
Cashier string `json:"cashier"` Cashier string `json:"cashier"`
Dtype int `json:"dtype"` Dtype int `json:"dtype"`
@@ -64,7 +69,6 @@ type ZReportInfo struct {
Isoffline bool `json:"isoffline"` Isoffline bool `json:"isoffline"`
Safe float64 `json:"safe"` Safe float64 `json:"safe"`
ShiftLink int `json:"shift_link"` ShiftLink int `json:"shift_link"`
Docno int `json:"docno"`
Receipt ZReportReceipt `json:"receipt"` Receipt ZReportReceipt `json:"receipt"`
Summary ZReportSummary `json:"summary"` Summary ZReportSummary `json:"summary"`
Taxes []ZReportTax `json:"taxes"` Taxes []ZReportTax `json:"taxes"`