Code Monkey home page Code Monkey logo

alterdata-bimer-php's Introduction

Alterdata Bimer - SDK PHP

SDK PHP para a API do Alterdata Bimer

Descrição

SDK em PHP para integração com os serviços de API do ERP Alterdata Bimer. Documentação da API Alterdata Bimer: https://bimersandbox.alterdata.com.br/#/.

Instalação

Via Composer

composer require vitorccs/alterdata-bimer-php

Métodos disponíveis

All: Buscar objetos. Retorna array de objetos.

$person = Bimer\PersonCharacteristic::all();

Find: Encontrar objetos por ID. Retorna objeto.

$person = Bimer\Person::find($strId);

Create - Criar novo objeto. Retorna objeto criado.

$customer = Bimer\Customer::create($arrayData);

Update - Atualiza objeto. Retorna objeto atualizado.

$person = Bimer\Person::update($strId, $arrayData);

Métodos específicos por recurso

$postalCode = Bimer\PostalCode::getByCode('03943000');
$people = Bimer\Person::getByName('maria', true);
$people = Bimer\Person::getByCpfCnpj('123.456.789-01');

Variáveis de ambiente

Os seguintes parâmetros devem ser informados:

  • BIMER_API_URL (URL da API)
  • BIMER_API_ID (ID do cliente)
  • BIMER_API_SECRET (Segredo do cliente)
  • BIMER_API_USER (Usuário)
  • BIMER_API_PWD (Senha)
  • BIMER_API_TIMEOUT (Opcional, padrão 30. Timeout em segundos para estabelecer conexão com a API)

Autenticação

Não é necessário codificar a variável BIMER_API_PWD com MD5, a SDK fará isso automaticamente.

Não é necessário autenticar manualmente, O SDK irá autenticar e obter um token automaticamente.

Cada processo PHP possuirá o seu próprio token de autenticação, sendo reaproveitado até o término da execução do script PHP. Caso esteja executando o PHP sem timeout (ex: CLI), o token será trocado a cada 10 minutos. Desta forma, evitamos sobrecarga no servidor da API.

Exemplo de implementação

error_reporting(E_ALL);
ini_set('display_errors', 1);

require __DIR__.'/vendor/autoload.php';

putenv('BIMER_API_URL=http://path:8086/api/');
putenv('BIMER_API_ID=client_id');
putenv('BIMER_API_SECRET=client_secret');
putenv('BIMER_API_USER=username');
putenv('BIMER_API_PWD=password');

use Bimer\Exceptions\BimerApiException;
use Bimer\Exceptions\BimerRequestException;

try {
    $characteristics = Bimer\PersonCharacteristic::all();
    print_r($characteristics); // array of objects

    $person = Bimer\Person::find('00A0000SQ4');
    print_r($person); // object

    $person = Bimer\Person::update('00A0000SQ4', [
       'Nome' => 'Nome Completo2',
       'NomeCurto' => 'Nome Curto2'
    ]);
    print_r($person); // object

    $people = Bimer\Person::getByName('NOME', true);
    print_r($people); // array of objects

    $people = Bimer\Person::getByCpfCnpj('123.456.789-01');
    print_r($people); // array of objects

    $customer = Bimer\Customer::create([
        'Identificador' => '',
        'IdentificadorRepresentantePrincipal' => '',
        'Tipo' => 'F',
        'Codigo' => '',
        'CpfCnpj' => '01234567894',
        'DataNascimento' => '1980-04-26T00:00:00:000Z',
        'Nome' => 'Nome Completo',
        'NomeCurto' => 'Nome Curto'
    ]);
    print_r($customer); // object

} catch (BimerApiException $e) { // erros retornados pela API Bimer
    echo sprintf("%s (%s)", $e->getMessage(), $e->getErrorCode());
} catch (BimerRequestException $e) { // erros de servidor (erros HTTP 4xx e 5xx)
    echo sprintf("%s (%s)", $e->getMessage(), $e->getErrorCode());
} catch (\Exception $e) { // demais erros
    echo $e->getMessage();
}

Métodos implementados

  • CEP (PostalCode)
  • Cliente (Customer)
  • NaturezaLancamento (AccountInformation)
  • Pessoa (Person)
  • PessoaCaracteristica (PersonCharacteristic)
  • Titulos a Receber (Income)
  • TiposLogradouro (AreaType)

... por favor, contribua com mais implementações

Testes

Caso queira contribuir, por favor, implementar testes em PHPUnit.

Para executar:

  1. Faça uma cópia de phpunit.xml.dist em phpunit.xml na raíz do projeto
  2. Altere os parâmtros ENV com os dados de seu acesso
  3. Execute o comando abaixo no terminal dentro da pasta deste projeto:
composer test

alterdata-bimer-php's People

Contributors

adb-deploy avatar vitorccs avatar

Stargazers

 avatar  avatar  avatar

Watchers

 avatar  avatar

Forkers

wicool

alterdata-bimer-php's Issues

Adiciona compatibilidade com Guzzle 7.x

Guzzle 7.x dispara exceção se enviar valor null para parâmetro $uri.

 public function request(string $method, $uri = '', array $options = []): ResponseInterface

O valor padrão de todos os métodos da classe Resource precisará ser trocado de null para "" (empty)

public static function get(string $endpoint = '', array $params = [], bool $single = true)

Refatorar testes de PHPUnit

  • Utilizar Data Providers para passar dados para os métodos de teste
public function incomeData(): array
public function accountData(): array
  • Transferir os dados estáticos como variável de ambiente do arquivo phpunit.xml
<env name="DATA_ACCOUNT" value='{"description":"teste","id":"00A0000001"}' />
<env name="DATA_AREA_TYPE" value='{"description":"RUA","id":"00A0000001"}' />
  • Atualizar PHP Unit para 8.5

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.