Skip to content

DelfimCelestino/mpesa-connect

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Mpesa SDK (mpesa-connect)

Uma biblioteca para integração com a API M-Pesa.

Índice

Instalação

Clone o repositório ou adicione a biblioteca ao seu projeto com npm:

npm install mpesa-connect

Crie um arquivo .env na raiz do seu projeto. Utilize o arquivo .env.example para referência:

MPESA_PUBLIC_KEY=YOUR_PUBLIC_KEY
MPESA_API_KEY=YOUR_API_KEY
MPESA_SERVICE_PROVIDER_CODE=YOUR_SERVICE_PROVIDER_CODE

Substitua YOUR_PUBLIC_KEY, YOUR_API_KEY e YOUR_SERVICE_PROVIDER_CODE pelos valores fornecidos pela sua conta M-Pesa.

Configuração

Para configurar a biblioteca, crie um arquivo .env com as variáveis de ambiente necessárias. Exemplo de .env:

MPESA_PUBLIC_KEY=YOUR_PUBLIC_KEY
MPESA_API_KEY=YOUR_API_KEY
MPESA_SERVICE_PROVIDER_CODE=YOUR_SERVICE_PROVIDER_CODE

Uso

Aqui está um exemplo básico de como usar a biblioteca:

import { initializeMpesa } from "mpesa-connect";


const mpesa = initializeMpesa({
  publicKey: process.env.MPESA_PUBLIC_KEY,
  apiKey: process.env.MPESA_API_KEY,
  serviceProviderCode: process.env.MPESA_SERVICE_PROVIDER_CODE,
  env: "test", // Use 'live' para produção e 'test' para teste
});

const run = async () => {
  try {
    const result = await mpesa.c2b("TX123456", "258840000000", 10, "REF123");
    console.log("C2B Result:", result);
  } catch (error) {
    console.error("Error:", error.message);
  }
};

run();

Métodos Disponíveis

c2b(transactionReference, customerMSISDN, amount, thirdPartyReference, serviceProviderCode)

Inicia uma transação C2B.

  • transactionReference: Referência da transação.
  • customerMSISDN: Número MSISDN do cliente.
  • amount: Valor da transação.
  • thirdPartyReference: Referência única do sistema de terceiros.
  • serviceProviderCode: Código do provedor de serviço (opcional).

b2c(transactionReference, customerMSISDN, amount, thirdPartyReference, serviceProviderCode)

Inicia uma transação B2C.

  • transactionReference: Referência da transação.
  • customerMSISDN: Número MSISDN do cliente.
  • amount: Valor da transação.
  • thirdPartyReference: Referência única do sistema de terceiros.
  • serviceProviderCode: Código do provedor de serviço (opcional).

transactionReversal(transactionID, securityCredential, initiatorIdentifier, thirdPartyReference, serviceProviderCode, reversalAmount)

Realiza um estorno de transação.

  • transactionID: ID da transação.
  • securityCredential: Credencial de segurança.
  • initiatorIdentifier: Identificador do iniciador.
  • thirdPartyReference: Referência única do sistema de terceiros.
  • serviceProviderCode: Código do provedor de serviço.
  • reversalAmount: Valor do estorno.

status(thirdPartyReference, queryReference, serviceProviderCode)

Consulta o status de uma transação.

  • thirdPartyReference: Referência única do sistema de terceiros.
  • queryReference: Referência da consulta.
  • serviceProviderCode: Código do provedor de serviço.

Contribuições

Se você deseja contribuir para o projeto, siga as seguintes etapas:

  1. Abra uma issue: Caso encontre um problema ou tenha uma sugestão.
  2. Envie um pull request: Para propor mudanças ou melhorias.
  3. Certifique-se de seguir as diretrizes de contribuição: Inclua testes para suas alterações.

Licença

Este projeto está licenciado sob a Licença MIT. Veja o arquivo LICENSE para mais detalhes.

Releases

No releases published

Packages

No packages published