fiscalapi
Version:
SDK de Node.js para FiscalAPI
112 lines • 12.2 kB
JavaScript
import { BaseFiscalapiService } from './base-fiscalapi-service';
/**
* Implementación del servicio de facturas
*/
export class InvoiceService extends BaseFiscalapiService {
/**
* Crea una nueva instancia del servicio de facturas
* @param {IFiscalapiHttpClient} httpClient - Cliente HTTP
* @param {string} apiVersion - Versión de la API
*/
constructor(httpClient, apiVersion) {
super(httpClient, 'invoices', apiVersion);
this.INCOME_ENDPOINT = 'income';
this.CREDIT_NOTE_ENDPOINT = 'credit-note';
this.PAYMENT_ENDPOINT = 'payment';
}
/**
* @inheritdoc
*/
async create(requestModel) {
if (!requestModel) {
throw new Error('requestModel cannot be null');
}
let endpoint;
switch (requestModel.typeCode) {
case 'I':
endpoint = this.INCOME_ENDPOINT;
break;
case 'E':
endpoint = this.CREDIT_NOTE_ENDPOINT;
break;
case 'P':
endpoint = this.PAYMENT_ENDPOINT;
break;
default:
throw new Error(`Unsupported invoice type: ${requestModel.typeCode}`);
}
return await this.executeRequest({
path: endpoint,
data: requestModel,
method: 'POST',
});
}
/**
* Cancela una factura
* @param {CancelInvoiceRequest} request - Solicitud para cancelar factura
* @returns {Promise<ApiResponse<CancelInvoiceResponse>>} Respuesta de la cancelación
*/
async cancel(request) {
if (!request) {
throw new Error('request cannot be null');
}
return await this.executeRequest({
data: request,
method: 'DELETE',
});
}
/**
* Obtiene el PDF de una factura
* @param {CreatePdfRequest} request - Solicitud para crear PDF
* @returns {Promise<ApiResponse<FileResponse>>} Respuesta con el archivo PDF
*/
async getPdf(request) {
if (!request) {
throw new Error('request cannot be null');
}
return await this.executeRequest({
path: 'pdf',
data: request,
method: 'POST',
});
}
/**
* Obtiene el XML de una factura
* @param {string} id - ID de la factura
* @returns {Promise<ApiResponse<FileResponse>>} Respuesta con el archivo XML
*/
async getXml(id) {
if (!id || id.trim() === '') {
throw new Error('id cannot be null or empty');
}
return await this.executeRequest({
path: `${id}/xml`,
method: 'GET',
});
}
/**
* Envía una factura por correo electrónico
* @param {SendInvoiceRequest} request - Solicitud para enviar factura
* @returns {Promise<ApiResponse<boolean>>} Resultado de la operación
*/
async send(request) {
return await this.executeRequest({
path: 'send',
data: request,
method: 'POST',
});
}
/**
* Obtiene el estado de una factura
* @param {InvoiceStatusRequest} request - Solicitud para consultar estado
* @returns {Promise<ApiResponse<InvoiceStatusResponse>>} Respuesta con el estado de la factura
*/
async getStatus(request) {
return await this.executeRequest({
path: 'status',
data: request,
method: 'POST',
});
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"invoice-service.js","sourceRoot":"","sources":["../../../src/services/invoice-service.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAYhE;;GAEG;AACH,MAAM,OAAO,cAAe,SAAQ,oBAA6B;IAK/D;;;;OAIG;IACH,YAAY,UAAgC,EAAE,UAAkB;QAC9D,KAAK,CAAC,UAAU,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;QAV3B,oBAAe,GAAG,QAAQ,CAAC;QAC3B,yBAAoB,GAAG,aAAa,CAAC;QACrC,qBAAgB,GAAG,SAAS,CAAC;IAS9C,CAAC;IAED;;OAEG;IACO,KAAK,CAAC,MAAM,CAAC,YAAqB;QAC1C,IAAI,CAAC,YAAY,EAAE,CAAC;YAClB,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAC;QACjD,CAAC;QAED,IAAI,QAAgB,CAAC;QAErB,QAAQ,YAAY,CAAC,QAAQ,EAAE,CAAC;YAC9B,KAAK,GAAG;gBACN,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC;gBAChC,MAAM;YACR,KAAK,GAAG;gBACN,QAAQ,GAAG,IAAI,CAAC,oBAAoB,CAAC;gBACrC,MAAM;YACR,KAAK,GAAG;gBACN,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC;gBACjC,MAAM;YACR;gBACE,MAAM,IAAI,KAAK,CAAC,6BAA6B,YAAY,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC1E,CAAC;QAEC,OAAO,MAAM,IAAI,CAAC,cAAc,CAAmB;YACjD,IAAI,EAAC,QAAQ;YACb,IAAI,EAAC,YAAY;YACjB,MAAM,EAAC,MAAM;SACd,CAAC,CAAC;IACP,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,MAAM,CAAC,OAA6B;QACxC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;QAC5C,CAAC;QAED,OAAO,MAAM,IAAI,CAAC,cAAc,CAA8C;YAC5E,IAAI,EAAC,OAAO;YACZ,MAAM,EAAC,QAAQ;SAChB,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,MAAM,CAAC,OAAyB;QACpC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;QAC5C,CAAC;QACD,OAAO,MAAM,IAAI,CAAC,cAAc,CAAiC;YAC/D,IAAI,EAAC,KAAK;YACV,IAAI,EAAC,OAAO;YACZ,MAAM,EAAC,MAAM;SACd,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,MAAM,CAAC,EAAU;QAErB,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;YAC5B,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;QAChD,CAAC;QAED,OAAO,MAAM,IAAI,CAAC,cAAc,CAAuB;YACrD,IAAI,EAAC,GAAG,EAAE,MAAM;YAChB,MAAM,EAAE,KAAK;SACd,CAAC,CAAC;IAEL,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,IAAI,CAAC,OAA2B;QACpC,OAAO,MAAM,IAAI,CAAC,cAAc,CAA8B;YAC5D,IAAI,EAAC,MAAM;YACX,IAAI,EAAC,OAAO;YACZ,MAAM,EAAC,MAAM;SACd,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,SAAS,CAAC,OAA6B;QACvC,OAAO,MAAM,IAAI,CAAC,cAAc,CAA8C;YAC9E,IAAI,EAAC,QAAQ;YACb,IAAI,EAAC,OAAO;YACZ,MAAM,EAAC,MAAM;SACd,CAAC,CAAC;IACP,CAAC;CACF","sourcesContent":["import { IFiscalapiHttpClient } from '../http/fiscalapi-http-client.interface';\nimport { ApiResponse } from '../common/api-response';\nimport { FileResponse } from '../common/file-response';\nimport { BaseFiscalapiService } from './base-fiscalapi-service';\nimport { IInvoiceService } from '../abstractions/invoice-service.interface';\nimport { \n  Invoice, \n  CancelInvoiceRequest, \n  CancelInvoiceResponse, \n  CreatePdfRequest, \n  SendInvoiceRequest,\n  InvoiceStatusRequest,\n  InvoiceStatusResponse\n} from '../models/invoice';\n\n/**\n * Implementación del servicio de facturas\n */\nexport class InvoiceService extends BaseFiscalapiService<Invoice> implements IInvoiceService {\n  private readonly INCOME_ENDPOINT = 'income';\n  private readonly CREDIT_NOTE_ENDPOINT = 'credit-note';\n  private readonly PAYMENT_ENDPOINT = 'payment';\n\n  /**\n   * Crea una nueva instancia del servicio de facturas\n   * @param {IFiscalapiHttpClient} httpClient - Cliente HTTP\n   * @param {string} apiVersion - Versión de la API\n   */\n  constructor(httpClient: IFiscalapiHttpClient, apiVersion: string) {\n    super(httpClient, 'invoices', apiVersion);\n  }\n\n  /**\n   * @inheritdoc\n   */\n   override async create(requestModel: Invoice): Promise<ApiResponse<Invoice>> {\n    if (!requestModel) {\n      throw new Error('requestModel cannot be null');\n    }\n\n    let endpoint: string;\n\n    switch (requestModel.typeCode) {\n      case 'I':\n        endpoint = this.INCOME_ENDPOINT;\n        break;\n      case 'E':\n        endpoint = this.CREDIT_NOTE_ENDPOINT;\n        break;\n      case 'P':\n        endpoint = this.PAYMENT_ENDPOINT;\n        break;\n      default:\n        throw new Error(`Unsupported invoice type: ${requestModel.typeCode}`);\n    }\n\n      return await this.executeRequest<Invoice, Invoice>({\n        path:endpoint,\n        data:requestModel,\n        method:'POST',\n      });\n  }\n\n  /**\n   * Cancela una factura\n   * @param {CancelInvoiceRequest} request - Solicitud para cancelar factura\n   * @returns {Promise<ApiResponse<CancelInvoiceResponse>>} Respuesta de la cancelación\n   */\n  async cancel(request: CancelInvoiceRequest): Promise<ApiResponse<CancelInvoiceResponse>> {\n    if (!request) {\n      throw new Error('request cannot be null');\n    }\n\n    return await this.executeRequest<CancelInvoiceResponse, CancelInvoiceRequest>({\n      data:request,\n      method:'DELETE',\n    });\n  }\n\n  /**\n   * Obtiene el PDF de una factura\n   * @param {CreatePdfRequest} request - Solicitud para crear PDF\n   * @returns {Promise<ApiResponse<FileResponse>>} Respuesta con el archivo PDF\n   */\n  async getPdf(request: CreatePdfRequest): Promise<ApiResponse<FileResponse>> {\n    if (!request) {\n      throw new Error('request cannot be null');\n    }\n    return await this.executeRequest<FileResponse, CreatePdfRequest>({\n      path:'pdf',\n      data:request,\n      method:'POST',\n    });\n  }\n\n  /**\n   * Obtiene el XML de una factura\n   * @param {string} id - ID de la factura\n   * @returns {Promise<ApiResponse<FileResponse>>} Respuesta con el archivo XML\n   */\n  async getXml(id: string): Promise<ApiResponse<FileResponse>> {\n\n    if (!id || id.trim() === '') {\n      throw new Error('id cannot be null or empty');\n    }\n\n    return await this.executeRequest<FileResponse, string>({\n      path:`${id}/xml`,\n      method: 'GET',\n    });\n\n  }\n\n  /**\n   * Envía una factura por correo electrónico\n   * @param {SendInvoiceRequest} request - Solicitud para enviar factura\n   * @returns {Promise<ApiResponse<boolean>>} Resultado de la operación\n   */\n  async send(request: SendInvoiceRequest): Promise<ApiResponse<boolean>> {\n    return await this.executeRequest<boolean, SendInvoiceRequest>({\n      path:'send',\n      data:request,\n      method:'POST',\n    });\n  }\n\n  /**\n   * Obtiene el estado de una factura\n   * @param {InvoiceStatusRequest} request - Solicitud para consultar estado\n   * @returns {Promise<ApiResponse<InvoiceStatusResponse>>} Respuesta con el estado de la factura\n   */\n  async getStatus(request: InvoiceStatusRequest): Promise<ApiResponse<InvoiceStatusResponse>> {\n        return await this.executeRequest<InvoiceStatusResponse, InvoiceStatusRequest>({\n        path:'status',\n        data:request,\n        method:'POST',\n      });\n  }\n}"]}