Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 23779ad6ad | |||
| f23c4ffd1c |
@@ -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",
|
||||||
|
|||||||
@@ -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)
|
||||||
@@ -71,8 +76,7 @@ func (c *Client) executeRequest(ctx context.Context, request FiscalRequest, resp
|
|||||||
func (c *Client) OpenShift(ctx context.Context, cashier string) (*SellResponse, error) {
|
func (c *Client) OpenShift(ctx context.Context, cashier string) (*SellResponse, error) {
|
||||||
request := FiscalRequest{
|
request := FiscalRequest{
|
||||||
Fiscal: Fiscal{
|
Fiscal: Fiscal{
|
||||||
Task: TaskOpenShift,
|
Task: TaskOpenShift,
|
||||||
Cashier: cashier,
|
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -87,8 +91,7 @@ func (c *Client) OpenShift(ctx context.Context, cashier string) (*SellResponse,
|
|||||||
func (c *Client) CloseShift(ctx context.Context, cashier string) (*ZReportResponse, error) {
|
func (c *Client) CloseShift(ctx context.Context, cashier string) (*ZReportResponse, error) {
|
||||||
request := FiscalRequest{
|
request := FiscalRequest{
|
||||||
Fiscal: Fiscal{
|
Fiscal: Fiscal{
|
||||||
Task: TaskZReport,
|
Task: TaskZReport,
|
||||||
Cashier: cashier,
|
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -32,19 +32,23 @@ type SellResponse struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type SellInfo struct {
|
type SellInfo struct {
|
||||||
Task int `json:"task"`
|
Task int `json:"task"`
|
||||||
Fisid string `json:"fisid"`
|
Fisid string `json:"fisid"`
|
||||||
Dataid int `json:"dataid"`
|
Dataid int `json:"dataid"`
|
||||||
Doccode string `json:"doccode"`
|
Doccode string `json:"doccode"`
|
||||||
Dt string `json:"dt"`
|
Docno interface{} `json:"docno"`
|
||||||
Cashier string `json:"cashier"`
|
Dt string `json:"dt"`
|
||||||
Dtype int `json:"dtype"`
|
Cashier string `json:"cashier"`
|
||||||
Isprint int `json:"isprint"`
|
Dtype int `json:"dtype"`
|
||||||
Isoffline bool `json:"isoffline"`
|
Isprint int `json:"isprint"`
|
||||||
Safe float64 `json:"safe"`
|
Isoffline bool `json:"isoffline"`
|
||||||
ShiftLink int `json:"shift_link"`
|
Safe float64 `json:"safe"`
|
||||||
Docno int `json:"docno"`
|
ShiftLink int `json:"shift_link"`
|
||||||
Cancelid string `json:"cancelid,omitempty"`
|
ShiftPrevLink int `json:"shift_prev_link"`
|
||||||
|
ShiftID string `json:"shift_id"`
|
||||||
|
OpenShiftDt string `json:"open_shift_dt"`
|
||||||
|
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"`
|
||||||
|
|||||||
Reference in New Issue
Block a user