Skip to content
This repository has been archived by the owner on Oct 15, 2024. It is now read-only.

wirecardBrasil/maquininha-wirecard-sdk-android

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

25 Commits
 
 
 
 

Repository files navigation

Moip v3 MPos client SDK - Android

O jeito mais simples e rápido de integrar o Moip ao seu App usando a Minizinha NFC

Instalação

Caso você use o Gradle, você pode adicionar a dependência em seu projeto

    repositories {
        maven { url 'https://oss.sonatype.org/content/repositories/snapshots/' }
        maven { url 'https://oss.sonatype.org/content/repositories/releases/' }
    }
    
    packagingOptions {
        exclude 'META-INF/DEPENDENCIES'
    }
    implementation 'br.com.moip:mpos-sdk:X.Y.Z'

Verifique a versão mais recente da SDK no CHANGELOG

Permissões

Para utilizar o SDK é necessário solicitar ao usuário as seguintes permissões:

    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.BLUETOOTH" />
    <uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />
    <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />

As permissões são necessárias para que seja possível fazer as requisições em nossas APIs e a conexão bluetooth com o POS que efetuará a cobrança. Lembre-se de pedir as seguinte permissões antes de realizar qualquer chamada na SDK.

    android.permission.ACCESS_FINE_LOCATION
    android.permission.READ_PHONE_STATE
    android.permission.WRITE_EXTERNAL_STORAGE

Configurando sua autenticação

Autenticando por BasicAuth:

    Authentication authentication = new BasicAuth("SEU_TOKEN", "SEU_KEY");

Autenticando por OAuth:

    Authentication authentication = new OAuth("SEU_TOKEN_OAUTH");

Após definir o tipo de autenticação, é necessário inicializar o sdk e informar em qual ambiente você quer executar suas ações:

Iniciando o SDK

MoipMpos.init(activity, MoipMpos.Enviroment.PRODUCTION, authentication, new InitCallback() {
        public void onSuccess() {
            //SUCCESS
        }

        public void onError(MposError e) {
            //ERROR
        }
});

Busca por maquininhas pareadas válidas

MoipMpos.searchPairedPinpads(new PairedPinpadsCallback() {
        @Override
        public void onPinpadsFound(List<BluetoothDevice> pinpads) {
           // Retorna todas as maquininhas, de modelos válidos, pareadas com o dispositivo do usuário.
        }

        @Override
        public void onActionChanged(MposAction action) {
           // Retorna o evento: MposAction.SEARCHING_PINPAD quando começar a busca pelas maquininhas
        }

        @Override
        public void onError(MposError error) {
            // ERROR
        }
});

Checando comunicação com a maquininha

O parâmetro pinpad é do tipo BluetoothDevice e deve ser uma maquininha previamente pareada com o dispositivo. Logo esse método checa se a maquininha está apta para realizar um pagamento.

MoipMpos.isPinpadConnected(pinpad, new PinpadCallback() {
        @Override
        public void onSuccess() {
            // SUCCESS
        }

        @Override
        public void onActionChanged(MposAction action) {
            // Retorna o evento: MposAction.GETTING_PINPAD_CONNECTION quando começar a checagem de conexão
        }

        @Override
        public void onError(MposError error) {
            // ERROR
        }
});

Método depreciado

IMPORTANTE: ⚠️ Não daremos mais suporte para esse método, e iremos removê-lo nas próximas versões.

MoipMpos.isPinpadConnected(new PinpadCallback() {
    @Override
    public void onActionChanged(MposAction action) {
        
    }

    @Override
    public void onSuccess() {
    
    }

    @Override
    public void onError(MposError error) {
        
    }
});

Definindo informações do seu pedido

ItemRequest item = new ItemRequest
        ("Produto/Servico", // Nome do produto ou serviço
        1, // Quantidade
        "Detalhe", // Detalhe
        101); // Valor

List items = Arrays.asList(item);

MposPaymentRequest mposPaymentRequest = new MposPaymentRequest()
        .installment(1) // Quantidade de parcelas
        .ownId("#{SEU IDENTIFICADOR}") // OPCIONAL Identificador único da sua transação, caso não seja informado um valor aleatório será criado
        .type(MposPaymentRequest.Type.CREDIT) //  Tipo da transação: `MposPaymentRequest.Type.CREDIT` e `MposPaymentRequest.Type.DEBIT`
        .items(items); // Lista de itens criada

Criando um pagamento

Agora temos que passar como parâmetro a maquininha que desejamos realizar o pagamento. Essa maquininha já deve estar pareada com seu dispositivo.

MoipMpos.charge(activity, pinpad, mposPaymentRequest, new MposCallback() {
        @Override
        public void onSuccess(MposPaymentResponse mposPaymentResponse) {
           //SUCCESS
        }

        @Override
        public void onActionChanged(MposAction action) {
           // Status em que a transação se encontra, pode ser utilizado para atualizar a sua UI.
        }

        @Override
        public void onError(MposError error) {
            //ERROR
        }
});

Método depreciado

IMPORTANTE: ⚠️ Não daremos mais suporte para esse método, e iremos removê-lo nas próximas versões.

MoipMpos.charge(activity, mposPaymentRequest, new MposCallback() {
    @Override
    public void onActionChanged(MposAction action) {
        //Status em que sua transação se encontra, você pode criar um dialog para exibir uma mensagem como preferir
    }

    @Override
    public void onSuccess(MposPaymentResponse mposPaymentResponse) {
        //SUCCESS
    }

    public void onError(MposError e) {
        //ERROR
    }
});

IMPORTANTE: ⚠️ Ao criar o pagamento você receberá o objeto MposPaymentResponse como retorno, com ele em mãos é possível checar se o pagamento foi autorizado ou não através de seu status.

Status da transação

Conforme a transação é realizada você receberá uma mensagem exibindo o status atual da transação, idealmente você deve exibir essa mensagem (ou uma similar) na tela do celular, para que o comprador e o vendedor possam se orientar.

No momento do pagamento o método onActionChanged lança vários eventos que estão listados abaixo:

Status Descrição
MposAction.GETTING_USER_LOCATION Pegando localização do usuário
MposAction.LOCATION_RETURNED Geolocalização obtida com sucesso
MposAction.CREATING_ORDER Criando pedido
MposAction.ORDER_CREATED Pedido criado
MposAction.CREATING_PAYMENT Criando pagamento
MposAction.PAYMENT_CREATED Pagamento criado
MposAction.WAITING_CARD Insira o cartão
MposAction.INSERTED_CARD Cartão inserido
MposAction.REMOVED_CARD Cartão removido
MposAction.WAITING_PASSWORD Insira a senha do cartão
MposAction.PROCESSING Processando transação
MposAction.WAITING_CARD_REMOVAL Remova o cartão
MposAction.COMPLETED_SALE Venda finalizada

Tratamento de erros

Quando ocorre algum erro no processo de pagamento, você deve utilizar o método onError() que retornará um MposError.

No momento do pagamento podem ocorrer os possiveis erros:

Código Descrição
POS-001 Ocorreu um erro ao inicializar a mPOS. Tente novamente
POS-002 Maquininha não encontrada
POS-003 Maquininha não compatível
POS-004 Conexão com a maquininha não encontrada
POS-005 Valor da transação inválido
POS-006 Não foi possível criar uma conexão com a maquininha
POS-007 Ocorreu um erro ao realizar a transação
POS-008 Operação cancelada
POS-009 Cartão inválido ou vencido
POS-010 Valor deve ser maior ou igual a R$ 1,00
POS-011 Valor da parcela deve ser maior ou igual a R$ 5,00
POS-012 Transação não autorizada
POS-013 Transação duplicada
POS-014 Senha inválida
POS-015 Transação não permitida para o cartão
POS-016 Cartão com erro ou mal inserido
POS-017 Modo inválido. Verifique se foi selecionado débito ou crédito corretamente
POS-018 Erro pinpad. Desconecte e conecte novamente a maquininha
POS-019 Operação por aproximação não autorizada, utilize chip

Adicionando um recebedor secundário

Para casos de marketplaces ou aplicações com mais de um recebedor envolvido é possível definir recebedores secundários nos pedidos, para isso basta utilizar o objeto ReceiverRequest e adicioná-lo em seu OrderRequest.

Ex:

    ReceiverRequest receiverRequest = new ReceiverRequest().secondary("MPA-123", new AmountRequest().fixed(100));
    mposPaymentRequest.setReceivers(Arrays.asList(receiverRequest));

Para maiores informações sobre a utilização de recebedores secundários, acesse nossa documentação sobre Split de Pagamentos ou a referência API

Métodos utilitários

Obs: ⚠️ Todos os métodos acima que recebem como parâmetro um pinpad que deve estar pareado com o dispositivo que deseja realizar transações

Temos esses métodos utilitários que podem ajudar no pareamento de novas maquininhas.

Buscando maquininhas

Esse método irá retornar maquininhas suportadas que não estão pareadas com seu dispositivo.

DevicePairingManager.searchDevices(activity, new PinpadSearchCallback() {
    @Override
    public void onPinpadFound(BluetoothDevice pinpad) {
        //Retorna os pinpads válidos que não estão pareados
    }

    @Override
    public void onError(MposError error) {
        // ERROR
    }
});

Para a busca por maquininhas não pareadas

DevicePairingManager.stopSearch(activity);

Parear com uma maquininha

  • O parâmetro pinpad é a maquininha que deseja parear
  • O método onStateChange retorna os seguintes estados

DevicePairingManager.State.PAIRING: Está realizando o pareamento. Com esse estado pode-se mostrar um feedback para o usuário avisando que o pareamento está sendo realizado.

DevicePairingManager.State.PAIRED: Pareamento realizado com sucesso.

DevicePairingManager.State.NOT_PAIRED: Ocorreu algum erro e o pareamento não foi realizado.

DevicePairingManager.pairDevice(activity, pinpad, new PinpadPairingCallback() {
    @Override
    public void onStateChange(DevicePairingManager.State state) {
        
    }

    @Override
    public void onError(MposError e) {

    }
});

Exceções ProGuard

  • Caso você utilize o ProGuard para desenvolver o seu app Android, é preciso adicionar as exceções abaixo para que a SDK funcione corretamente.
-keep class br.com.moip.api.** {*;}
-keep class br.com.moip.API {*;}
-keep class br.com.moip.Client {*;}
-keep class br.com.moip.response.** {*;}
-keep class br.com.moip.request.** {*;}
-keep class br.com.moip.resource.** {*;}
-keep class br.com.moip.android.entities.** {*;}

-keep class br.com.uol.pagseguro.plugpag.** {*;}
-keep class br.com.uol.pagseguro.libswitch.** {*;}
-keep class br.com.uol.pagseguro.util.** {*;}

-keep class com.segment.analytics.** { *; }
-keep class androidx.lifecycle.DefaultLifecycleObserver

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published