codephix / pipedrive-sdk
PipeDrive.com PHP API 包装器
1.0
2022-01-19 02:56 UTC
Requires
- php: >=7.2
README
非官方的www.asaas.com服务API集成SDK
进行中的项目
安装
composer require codephix/pipedrive-sdk
示例
<?php require 'vendor/autoload.php'; use CodePhix\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)。请参阅许可证文件以获取更多信息。