thyagobrejao / asaas-sdk
Asaas.com PHP API 包装器
2.0.2
2022-11-18 00:45 UTC
Requires
- php: >=7.2
- guzzlehttp/guzzle: ^7.5
This package is auto-updated.
Last update: 2024-09-18 04:31:33 UTC
README
www.asaas.com 服务 API 集成非官方 SDK
项目进行中
修改以使用 Guzzle 而不是 curl
安装
composer require thyagobrejao/asaas-sdk
示例
<?php require 'vendor/autoload.php'; use ThyagoBrejao\Asaas\Asaas; // Instancie o cliente Asaas usando a instância do adapter previamente criada. $asaas = new Asaas('seu_token_de_acesso');
端点
如果想在测试模式下使用 API,只需在实例化客户端时指定 环境
。
// Obs.: Caso não seja informado o segundo parâmetro a API entra em modo de produção $asaas = new Asaas('seu_token_de_acesso', 'producao|homologacao');
客户端
// Retorna a listagem de clientes $clientes = $asaas->Cliente()->getAll(array $filtros); // Retorna os dados do cliente de acordo com o Id $clientes = $asaas->Cliente()->getById(123); // Retorna os dados do cliente de acordo com o Email $clientes = $asaas->Cliente()->getByEmail('email@mail.com'); // Insere um novo cliente $clientes = $asaas->Cliente()->create(array $dadosCliente); // Atualiza os dados do cliente $clientes = $asaas->Cliente()->update(123, array $dadosCliente); // Restaura um cliente $asaas->Cliente()->restaura(123); // Deleta uma cliente $asaas->Cliente()->delete(123);
收费
// Retorna a listagem de cobranças $cobrancas = $asaas->Cobranca()->getAll(array $filtros); // Retorna os dados da cobrança de acordo com o Id $cobranca = $asaas->Cobranca()->getById(123); // Retorna a listagem de cobranças de acordo com o Id do Cliente $cobrancas = $asaas->Cobranca()->getByCustomer($customer_id); // Retorna a listagem de cobranças de acordo com o Id da Assinaturas $cobrancas = $asaas->Cobranca()->getBySubscription($subscription_id); // Insere uma nova cobrança / cobrança parcelada / cobrança split $cobranca = $asaas->Cobranca()->create(array $dadosCobranca); // Atualiza os dados da cobrança $cobranca = $asaas->Cobranca()->update(123, array $dadosCobranca); // Restaura cobrança removida $cobranca = $asaas->Cobranca()->restore(id); // Estorna cobrança $cobranca = $asaas->Cobranca()->estorno(id); // Confirmação em dinheiro $cobranca = $asaas->Cobranca()->confirmacao(id); // Desfazer confirmação de recebimento em dinheiro $cobranca = $asaas->Cobranca()->dezconfirmacao(id); // Deleta uma cobrança $asaas->Cobranca()->delete(123);
Pix
要创建 Pix,需要添加收费,并使用该收费 ID 生成 Pix 的 qrCode,请注意,qrCode 将在当天 23:59 前生成。QrCode 以 base64 编码。
$Pix = $asaas->Pix()->create($id_cobranca); if($Pix->success){ echo '<img src="data:image/jpeg;base64, '.$Pix->encodedImage.'" />'; } //Consulta se foi efetivado o pagamento via Pix, (Obs: Recomendo um post a cada 30s, ou um botão para confirmação do pagamento, assim não sobrecarregado o seu sistema e nem o do asaas ;) ). $retorno = $asaas->Pix()->get($id_cobranca);
付款链接
// Retorna a listagem de cobranças $LinkPagamento = $asaas->LinkPagamento()->getAll(array $filtros); // Retorna os dados da cobrança de acordo com o Id $LinkPagamento = $asaas->LinkPagamento()->getById($id); // Insere uma nova cobrança / cobrança parcelada / cobrança split $LinkPagamento = $asaas->LinkPagamento()->create(array $dadosLink); Body { "name": "Venda de livros", "description": "Qualquer livro por apenas R$: 50,00", "endDate": "2021-02-05", "value": 50, "billingType": "UNDEFINED", "chargeType": "DETACHED", "dueDateLimitDays": 10, "subscriptionCycle": null, "maxInstallmentCount": 1 } $dadosLink = array( 'name' => 'Nome do link de pagamentos -> String required', 'description' => 'Descrição do link de pagamentos -> String', 'endDate' => 'Data de encerramento, a partir desta data o seu link de pagamentos será desativado automaticamente', 'value' => 'Valor do link de pagamentos, caso não informado o pagador poderá informar o quanto deseja pagar', /* Forma de pagamento permitida BOLETO -> Boleto Bancário CREDIT_CARD -> Cartão de Crédito UNDEFINED -> Perguntar ao Cliente */ 'billingType' => 'UNDEFINED', //required /* Forma de cobrança DETACHED -> Avulsa RECURRENT -> Assinatura INSTALLMENT -> Parcelamento */ 'chargeType' => 'DETACHED' //required /* Caso seja possível o pagamento via boleto bancário, define a quantidade de dias úteis que o seu cliente poderá pagar o boleto após gerado */ 'dueDateLimitDays' => '10', /* Periodicidade da cobrança, envio obrigatório caso a forma de cobrança selecionado seja Assinatura WEEKLY -> Semanal BIWEEKLY -> Quinzenal (2 semanas) MONTHLY -> Mensal QUARTERLY -> Trimestral SEMIANNUALLY -> Semestral YEARLY -> Anual 'subscriptionCycle' => 'MONTHLY', */ /* Quantidade máxima de parcelas que seu cliente poderá parcelar o valor do link de pagamentos caso a forma de cobrança selecionado seja Parcelamento. Caso não informado o valor padrão será de 1 parcela */ 'maxInstallmentCount' => '1' ); // Atualiza os dados da cobrança $LinkPagamento = $asaas->LinkPagamento()->update($id, array $dadosLink); // Restaura cobrança removida $LinkPagamento = $asaas->LinkPagamento()->restore(id); // Estorna cobrança $LinkPagamento = $asaas->LinkPagamento()->estorno(id); // Confirmação em dinheiro $LinkPagamento = $asaas->LinkPagamento()->confirmacao(id); // Deleta uma cobrança $asaas->LinkPagamento()->delete(123);
订阅
Os status possíveis de uma cobrança são os seguintes: [PENDING] - Aguardando pagamento [RECEIVED] - Recebida (saldo já creditado na conta) [CONFIRMED] - Pagamento confirmado (saldo ainda não creditado) [OVERDUE] - Vencida [REFUNDED] - Estornada [RECEIVED_IN_CASH] - Recebida em dinheiro (não gera saldo na conta) [REFUND_REQUESTED] - Estorno Solicitado [CHARGEBACK_REQUESTED] - Recebido chargeback [CHARGEBACK_DISPUTE] - Em disputa de chargeback (caso sejam apresentados documentos para contestação) [AWAITING_CHARGEBACK_REVERSAL] - Disputa vencida, aguardando repasse da adquirente [DUNNING_REQUESTED] - Em processo de recuperação [DUNNING_RECEIVED] - Recuperada [AWAITING_RISK_ANALYSIS] - Pagamento em análise // Retorna a listagem de assinaturas $assinaturas = $asaas->Assinatura()->getAll(array $filtros); // Retorna os dados da assinatura de acordo com o Id $assinatura = $asaas->Assinatura()->getById(123); // Retorna a listagem de assinaturas de acordo com o Id do Cliente $assinaturas = $asaas->Assinatura()->getByCustomer($customer_id); // Insere uma nova assinatura /* Assinatura via Boleto $dadosAssinatura = array( "customer" => "{CUSTOMER_ID}", "billingType" => "BOLETO", "nextDueDate" => "2017-05-15", "value" => 19.9, "cycle" => "MONTHLY", "description" => "Assinatura Plano Pró", "discount" => array( "value" => 10, "dueDateLimitDays" => 0 ), "fine" => array( "value": 1 ), "interest" => array( "value": 2 ) ); Assinatura via cartão de credito $dadosAssinatura = array( "customer" => "{CUSTOMER_ID}", "billingType" => "CREDIT_CARD", "nextDueDate" => "2017-05-15", "value" => 19.9, "cycle" => "MONTHLY", "description" => "Assinatura Plano Pró", "creditCard" => array( "holderName" => "marcelo h almeida", "number" => "5162306219378829", "expiryMonth" => "05", "expiryYear" => "2021", "ccv" => "318" ), "creditCardHolderInfo" => array( "name" => "Marcelo Henrique Almeida", "email" => "marcelo.almeida@gmail.com", "cpfCnpj" => "24971563792", "postalCode" => "89223-005", "addressNumber" => "277", "addressComplement" => null, "phone" => "4738010919", "mobilePhone" => "47998781877" ) ); */ $assinatura = $asaas->Assinatura()->create(array $dadosAssinatura); // Atualiza os dados da assinatura $assinatura = $asaas->Assinatura()->update(123, array $dadosAssinatura); Listar notas fiscais das cobranças de uma assinatura /* $parametos = array( 'offset' => '', 'limit' => '', 'status' => '', */ $assinatura = $asaas->Assinatura()->getNotaFiscal($id, array $parametos); // Deleta uma assinatura $asaas->Assinatura()->delete(123);
提前支付
$Antecipacao = $Asaas->Antecipacao()->getAll($filtro); Parametros Filtro para retorno $filtro = array( 'payment' => 'Filtrar antecipações de uma cobrança -> string', 'installment' => 'Filtrar antecipações de um parcelamento -> String', 'status' => 'Filtrar por status -> String', 'offset' => 'Elemento inicial da lista -> Number', 'limit' => 'Número de elementos da lista (max: 100) -> Number', ) $Antecipacao = $Asaas->Antecipacao()->create($dados); Dados Para solicitação de antecipação = array() { "agreementSignature": "João Almeida", "installment": null, "payment": "pay_626366773834", "documents": [<file>] } Recupera uma Antecipação $Asaas = $Asaas->Antecipacao()->getBy($id); Dados de retorno { "object": "receivableAnticipation", "id": "9e7d8639-350f-45c0-8bc3-d4ddc5f4ebac", "installment": null, "payment": "pay_626366773834", "status": "PENDING", "anticipationDate": "2019-05-20", "dueDate": "2019-05-26", "requestDate": "2019-05-14", "fee": "2.33", "anticipationDays": "6", "netValue": "73.68", "totalValue": "80.00", "value": "76.01", "denialObservation": null }
账户支付
Retorna Lista $Pagar = $Asaas->PagarConta()->getAll($filtro); $filtro = array( 'offset' => 'Elemento inicial da lista -> Number', 'limit' => 'Número de elementos da lista (max: 100) -> Number', ); $Pagar = $Asaas->PagarConta()->create($dados); Parametros Filtro para retorno $dados = array( 'identificationField' => 'Linha digitável do boleto -> required string', 'scheduleDate' => 'Data de agendamento do pagamento -> string', 'description' => 'Descrição do pagamento de conta -> string', 'discount' => 'Desconto atribuido ao pagamento -> number', 'dueDate' => 'Data de vencimento da conta caso seja do tipo que não possui essa informação -> string', 'value' => 'Valor da conta caso seja do tipo que não possui essa informação (Ex: faturas de cartão de crédito) -> number', ) /* * Simulação Pagar Conta * */ $Pagar = $Asaas->PagarConta()->simulate($dados); Dados simulação $dados = array( 'identificationField' => 'Linha digitável do boleto', /* OU */ 'barCode' => 'Código de barras do boleto', ); Recupera um Pagamento $Pagar = $Asaas->PagarConta()->getBy($id); Dados de retorno { "object": "bill", "id": "f1bce822-6f37-4905-8de8-f1af9f2f4bab", "status": "PENDING", "value": 29.9, "discount": 0, "identificationField": "03399.77779 29900.000000 04751.101017 1 81510000002990", "dueDate": "2020-01-31", "scheduleDate": "2020-01-31", "fee": 0, "description": "Celular 01/12", "companyName": null, "transactionReceiptUrl": "https://www.asaas.com/comprovantes/00016578", "canBeCancelled": false, "failReasons": null }
查询 Serasa
Retorna Lista $ConsultaSerasa = $Asaas->ConsultaSerasa()->getAll($filtro); $filtro = array( 'startDate' => 'Filtrar a partir da data de criação -> String', 'endDate' => 'Filtrar até uma data de criação -> String', 'offset' => 'Elemento inicial da lista -> Number', 'limit' => 'Número de elementos da lista (max: 100) -> Number', ); Dados de retorno { "object": "list", "hasMore": false, "totalCount": 1, "limit": 10, "offset": 0, "data": [ { "id": "6c5e73fa-9efd-4a75-b60c-1cafb8d1c7ed", "dateCreated": "2021-01-27", "cpfCnpj": "05666663755", "state": "SC", "customer": "cus_000000001766", "downloadUrl": "https://www.asaas.com.br/creditBureauReport/download/6c5e73fa-9efd-4a75-b60c-1cafb8d1c7ed" } ] } Cria uma consulta As consultas junto ao Serasa Experian são realizadas no momento da solicitação, para evitar possíveis percas de conexão, sugerimos um timeout de 30 segundos ou mais. Ao realizar a consulta será retornado o atributo reportFile contendo o PDF da consulta em Base64, este campo apenas é retornado no momento da criação da consulta, caso precise obte-lo novamente será necessário realizar o download por meio da url presente no campo downloadUrl. Para realizar a consulta você terá que informar um CPF ou CNPJ e o estado onde deseja realizar a consulta. Caso queira informar um cliente já cadastrado na sua conta Asaas: Este deverá possuir um CPF ou CNPJ já cadastrado O envio do estado se torna opcional caso já conste no cadastro do cliente $ConsultaSerasa = $Asaas->ConsultaSerasa()->create($dados); Parametros Create $dados = array( 'customer' = 'Identificador único do cliente no Asaas -> String', 'cpfCnpj' = 'CPF ou CNPJ do cliente. Informe este campo caso seu cliente não esteja cadastrado no Asaas -> String', 'state' = 'Estado em que deseja realizar a consulta. -> required EX: PE ou PB etc', ) Consulta Valida até as 23:59 do dia da consulta dados de retorno { "id": "6c5e73fa-9efd-4a75-b60c-1cafb8d1c7ed", "dateCreated": "2021-01-27", "cpfCnpj": "05666663755", "state": "SC", "customer": "cus_000000001766", "downloadUrl": "https://www.asaas.com.br/creditBureauReport/download/6c5e73fa-9efd-4a75-b60c-1cafb8d1c7ed" } Recupera consulta $ConsultaSerasa = $Asaas->ConsultaSerasa()->getBy($id); Dados de retorno { "id": "6c5e73fa-9efd-4a75-b60c-1cafb8d1c7ed", "dateCreated": "2021-01-27", "cpfCnpj": "05666663755", "state": "SC", "customer": "cus_000000001766", "downloadUrl": "https://www.asaas.com.br/creditBureauReport/download/6c5e73fa-9efd-4a75-b60c-1cafb8d1c7ed" }
发票
允许企业(法人)为客户开具发票。可以针对已存在的收费开具发票。
在开具发票之前,需要填写账户的税务信息。点击此处了解如何操作。
发票的可能状态如下
SCHEDULED - 已安排
SYNCHRONIZED - 已发送至市政府
AUTHORIZED - 已开具
PROCESSING_CANCELLATION - 正在处理取消
CANCELED - 已取消
CANCELLATION_DENIED - 取消拒绝
ERROR - 开具错误
//Recuperar dados comerciais /* Parametros */ $dados = array( 'effectiveDate[ge]' => 'Filtrar a partir de uma data de emissão -> Date (Y-m-d)', 'effectiveDate[le]' => 'Filtrar até uma data de emissão -> String', 'payment' => 'Filtrar pelo identificador único da cobrança -> String', 'installment' => 'Filtrar pelo identificador único do parcelamento -> String', 'externalReference' => 'Identificador da nota fiscal no seu sistema -> String', 'status' => 'Filtrar por situação -> Enum', 'offset' => 'Elemento inicial da lista -> Number', 'limit' => 'Número de elementos da lista (max: 100) -> Number', ); $NotaFiscal = $asaas->NotaFiscal()->getAll($dados); /*Agenda Nota Fiscal*/ $dados = array( "payment" => "pay_637959110194", "installment" => null, "serviceDescription" => "Nota fiscal da Fatura 101940. \nDescrição dos Serviços: ANÁLISE E DESENVOLVIMENTO DE SISTEMAS", "observations" => "Mensal referente aos trabalhos de Junho.", "value" => 300, "deductions" => 0, "effectiveDate" => "2018-07-03", "externalReference" => null, "taxes" => array( "retainIss" => false, "iss" => 3, "cofins" => 3, "csll" => 1, "inss" => 0, "ir" => 1.5, "pis" => 0.65 ), "municipalServiceId" => null, "municipalServiceCode" => "1.01", "municipalServiceName" => "Análise e desenvolvimento de sistemas" ); $NotaFiscal = $asaas->NotaFiscal()->create($dados); /*Agenda Nota Fiscal*/ $dados = array( "serviceDescription" => "Nota fiscal da Fatura 101940. \nDescrição dos Serviços: ANÁLISE E DESENVOLVIMENTO DE SISTEMAS", "observations" => "Mensal referente aos trabalhos de Junho.", "value" => 300, "deductions" => 0, "effectiveDate" => "2018-07-03", "externalReference" => null, "taxes" => array( "retainIss" => false, "iss" => 3, "cofins" => 3, "csll" => 1, "inss" => 0, "ir" => 1.5, "pis" => 0.65 ), ); $NotaFiscal = $asaas->NotaFiscal()->update($dados); //Emitir Nota Fiscal $NotaFiscal = $asaas->NotaFiscal()->issueInvoice($id); //Listar serviços municipais $NotaFiscal = $asaas->NotaFiscal()->ListMunicipalServices($descricao);
税务信息
//Recuperar Informações Fiscais $InformacoesFiscais = $asaas->InformacoesFiscais()->get(); /*Cria e atualiza informações Fiscais*/ $dados = array( "object" => "customerFiscalInfo", "simplesNacional" => false, "rpsSerie" => "1", "rpsNumber" => 1, "loteNumber" => 1, "username" => "usuario", "specialTaxRegime" => "1", "email" => "marcelo.almeida@gmail.com", "serviceListItem" => null, "cnae" => "6209100", "culturalProjectsPromoter" => false, "municipalInscription" => "21779501", "stateInscription" => null, "password" => "secret", "accessToken" => null, "certificateFile" => null, "certificatePassword" => "secret" ); $InformacoesFiscais = $asaas->InformacoesFiscais()->createUpdate($dados); //Listar configurações municipais $InformacoesFiscais = $asaas->NotaFiscal()->ListMunicipalConfigurations();
我的账户
//Recuperar dados comerciais $MinhaConta = $asaas->MinhaConta()->get(); // Recuperar configurações de personalização $MinhaConta = $asaas->MinhaConta()->getConf();
通知
// Retorna a listagem de notificações $notificacoes = $asaas->Notificacao()->getAll(array $filtros); // Retorna os dados da notificação de acordo com o Id $notificacao = $asaas->Notificacao()->getById(123); // Retorna a listagem de notificações de acordo com o Id do Cliente $notificacoes = $asaas->Notificacao()->getByCustomer($customer_id); // Insere uma nova notificação $notificacao = $asaas->Notificacao()->create(array $dadosNotificacao); // Atualiza os dados da notificação $notificacao = $asaas->Notificacao()->update(123, array $dadosNotificacao); // Deleta uma notificação $asaas->Notificacao()->delete(123);
官方文档
注意:这是一个非官方 API。它是基于以下链接提供的文档制作的 此处。
贡献
有关详细信息,请参阅 CONTRIBUTING。
致谢
支持
如要报告新错误,请在新 GitHub Issue 中创建一个
支持
安全性:如果您发现任何安全问题,请通过电子邮件 contato@codephix.com 联系我们,而不是使用问题跟踪器。
如果您发现任何与安全相关的任何问题,请通过电子邮件 contato@codephix.com 联系我们,而不是使用问题跟踪器。
谢谢
致谢
许可证
MIT 许可证(MIT)。请参阅 许可证文件 了解更多信息。