Árvore de páginas

Versões comparadas

Chave

  • Esta linha foi adicionada.
  • Esta linha foi removida.
  • A formatação mudou.

...

  1. Introdução
  2. Endpoint
  3. Parâmetros
  4. Resposta


01. INTRODUÇÃO

Esta API cria permite criar um novo lote de importação de beneficiários em massa na operadora.
Os beneficiários serão gerados com um protocolo ao serem importados na rotina de análise de beneficiários (PLSA977AB), permitindo que a operadora análise analise e aprove a inclusão no grupo familiar (PLSA174).

Clique aqui para detalhes sobre como habilitar o serviço de APIs no Protheus.

...

NomeTipoLocalizaçãoDescrição

Content-Type

string

headermultipart/form-data ou application/json (body)dependendo do formato do corpo da requisição).
Authorizationstring

Headerheader

Token de acesso obtido via a API de autenticação, no formato Bearer <access_token>.

Estado
subtletrue
colourRed
titleRequired

healthInsurerCodestring

body/form

Código da operadora

Estado
subtletrue
colourRed
titleRequired

companyCodestring

body/form

Código da empresa

Estado
subtletrue
colourRed
titleRequired

contractCodestring

body/form

Código do contrato

Estado
subtletrue
colourRed
titleRequired

contractVersionstring

body/form

Versão do contrato

Estado
subtletrue
colourRed
titleRequired

subcontractCodestring

body/form

Código do subcontrato

Estado
subtletrue
colourRed
titleRequired

subcontractVersionstring

body/form

Versão do subcontrato

Estado
subtletrue
colourRed
titleRequired

loginUserstring

body/form

Login do portal

Estado
subtletrue
colourRed
titleRequired

filefile

form-data

Arquivo CSV com os beneficiários

Estado
subtletrue
colourRed
titleRequired

fileBase64string

body

Arquivo CSV em Base64

Estado
subtletrue
colourRed
titleRequired

fileNamestring

body

Nome do arquivo CSV

Estado
subtletrue
colourRed
titleRequired

Informações

Pode-se enviar o arquivo CSV dos beneficiários via file (form-data) ou fileBase64 (body) com o fileName.

Bloco de código
languagec#
themeMidnight
titleExemplo de Body
collapsetrue
{
  "healthInsurerCode": "0001",
  "companyCode": "1017",
  "contractCode": "000000000001",
  "contractVersion": "001",
  "subcontractCode": "000000001",
  "subcontractVersion": "001",
  "loginUser": "TOTVS",
  "fileBase64": "QjJOX0NPRFNFUTtCMk5fQ1BGVVNSO0IyTl9OT01VU1I7QjJOX0RBVE5BUztCMk5...",
  "fileName": "modelo-importacao-beneficiarios.csv"
}

04. RESPOSTA

Informações
iconfalse
Dica
200

201 - Operação realizada com sucesso

Retorna os dados da carteirinha do beneficiário, incluindo informações pessoais, planos de saúde, imagens do cartão e configurações de layoutO sistema cria um novo lote na rotina de Lotes de Importação de Beneficiários (PLCTO001) com status Recebido, e anexa o arquivo CSV ao banco de conhecimento do lote.

subtle
CampoTipoDescriçãoCampo (Protheus)fields 
Estado
subtletrue
titleobject
fields.name 

Estado
subtletrue
titlestring

Nome completo do beneficiário.BTS_NOMCAR ou BTS_NOMUSR
fields.socialName

Estado
subtletrue
titlestring

Nome social do beneficiário.

BTS_NOMSOC

fields.healthInsurerCode

Estado
subtletrue
titlestring

Código da operadora de saúde.

BA1_CODINT

fields.companyCode 

Estado
subtletrue
titlestring

Código da empresa.

BA1_CODEMP

fields.registrationCode batchCode

Estado
subtletrue
titlestring

Código de registro do beneficiário.Lote

BA1BJ5_MATRICCODLOT

fields.kinshipCode 
statustrue
titlestring
Código de parentesco.

BA1_TIPREG

fields.digit 

Estado
subtletrue
titlestring

Dígito de identificação.

BA1_DIGITO

fields.nationalHealthCard 

Estado
subtletrue
titlestring

Número do cartão nacional de saúde

BTS_NRCRNA

Status do LoteBJ5_STATUS
importDatefields.subscriberId 

Estado
subtletrue
titlestring

Identificador único do beneficiário.BA1_CODINT + BA1_CODEMP + BA1_MATRIC + BA1_TIPREG + BA1_DIGITOfields.birthDate 
Estado
subtletrue
titleString (date)
Data de nascimento do beneficiário.

BA1_DATNAS

fields.cardValidity 
Estado
subtletrue
titleString (date)
Data de validade do cartão.

BA1_DTVLCR

fields.effectiveDate 
Estado
subtletrue
titleString (date)
Data de efetivação do plano de saúde.

BA1_DATINC

fields.cardCopy 

Estado
subtletrue
titlestring

Identificador da cópia do cartão.

BA1_VIACAR

(DATE)

Data da importaçãoBJ5_DATIMP
importTimefields.holderName 

Estado
subtletrue
titlestring

Nome do titular do plano.BTS_NOMCAR ou BTS_NOMUSR
fields.holderHealthInsurerCode 

Estado
subtletrue
titlestring

Código da operadora de saúde do titular.

BA1_CODINT

Hora da importaçãoBJ5_HORIMP
loginUserfields.holderCompanyCode 

Estado
subtletrue
titlestring

Usuário que gerou o loteBJ5_USRLOG
healthInsurerCodeCódigo da empresa do titular.

BA1_CODEMP

fields.holderRegistrationCode

Estado
subtletrue
titlestring

Código de registro do titular.

BA1_MATRIC

fields.holderKinshipCode 

Estado
subtletrue
titlestring

Código de parentesco do titular.

BA1_TIPREG

fields.holderDigit 

Estado
subtletrue
titlestring

Dígito de identificação do titular.

BA1_DIGITO

fields.holderSubscriberId 

Estado
subtletrue
titlestring

Identificador único do titular.BA1_CODINT + BA1_CODEMP + BA1_MATRIC + BA1_TIPREG + BA1_DIGITO
fields.dependentName 

Estado
subtletrue
titlestring

Nome do dependente.BTS_NOMCAR ou BTS_NOMUSR
fields.dependentHealthInsurerCode 

Estado
subtletrue
titlestring

Código da operadora de saúde do dependente.BA1BJ5_CODINTCODOPE
fields.dependentCompanyCodecompanyCode

Estado
subtletrue
titlestring

Código da empresa do dependente.BA1BJ5_CODEMP
fields.dependentRegistrationCode contractCode

Estado
subtletrue
titlestring

Código de registro do dependente.contratoBA1BJ5_MATRICCONEMP
fields.dependentKinshipCode contractVersion

Estado
subtletrue
titlestring

Código de parentesco do dependente.

BA1_TIPREG

fields.dependentDigit 

Estado
subtletrue
titlestring

Dígito de identificação do dependente.

BA1_DIGITO

fields.dependentSubscriberId 

Estado
subtletrue
titlestring

Identificador único do dependente.BA1_CODINT + BA1_CODEMP + BA1_MATRIC + BA1_TIPREG + BA1_DIGITO
Versão do contratoBJ5_VERCON
subcontractCodefields.planCode 

Estado
subtletrue
titlestring

Código do plano.subcontratoBI3BJ5_CODIGOSUBCON
fields.planDescription subcontractVersion

Estado
subtletrue
titlestring

Descrição do plano de saúde.Versão do subcontratoBJ5_VERSUB
subcontractDescription

BI3_NREDUZ

fields.accommodationDescription 

Estado
subtletrue
titlestring

Descrição da acomodação do plano.

BI4_CODEDI

fields.coverageArea 

Estado
subtletrue
titlestring

Área de cobertura do plano de saúde.

BI3_ABRANG

fields.planRegulation 

Estado
subtletrue
titlestring

Tipo de regulamentação do plano.

BI3_APOSRG

fields.planCodeANS 

Estado
subtletrue
titlestring

Código do plano na ANS.

BI3_SUSEP ou BI3_SCPA

fields.planSegmentation 

Estado
subtletrue
titlestring

Segmentação do plano.

BI6_DESCRI

fields.subcontractCardName 

Estado
subtletrue
titlestring

Nome do cartão de subcontrato.BQC_NOMCARDESCRI
fields.healthInsurerCodeANS totalCount

Estado
subtletrue
titlestringINTEGER

Código da operadora de saúde na ANS.

BA0_SUSEP

Total de beneficiários do loteBJ5_QTDTOT
importedCountfields.healthInsurerName 

Estado
subtletrue
titlestringINTEGER

Nome da operadora de saúde.

BA0_NOMINT

cardImage 
Estado
subtletrue
titleobject
cardImage.front 

Estado
subtletrue
titlestring

Imagem em base64 da frente do cartão (formato PNG).cardImage.back 

Estado
subtletrue
titlestring

Imagem em base64 da verso do cartão (formato PNG).Total de beneficiários importados (em processamento, pode variar)BJ5_QTDIMP
errorCountlayoutConfig 
Estado
subtletrue
titleobject
layoutConfig.front 

Estado
subtletrue
titleobject[]INTEGER

Configurações de layout para a frente do cartão.layoutConfig.front.css 

Estado
subtletrue
titlestring

Estilo CSS para o campo.layoutConfig.front.values
Estado
subtletrue
titleobject[]
Valores a serem exibidos no campo.layoutConfig.front.values.type

Estado
subtletrue
titlestring

Tipo do campo, podendo ser: custom, field ou text.layoutConfig.front.values.value

Estado
subtletrue
titlestring

Valor do campo.layoutConfig.back
Estado
subtletrue
titleobject[]
Configurações de layout para o verso do cartão.layoutConfig.back.css 

Estado
subtletrue
titlestring

Estilo CSS para o campo.layoutConfig.back.values
Estado
subtletrue
titleobject[]
Valores a serem exibidos no campo.layoutConfig.back.values.type

Estado
subtletrue
titlestring

Tipo do campo, podendo ser: custom, field ou text.layoutConfig.back.values.value

Estado
subtletrue
titlestring

Valor do campo.customFields 
Estado
subtletrue
titleobject[]
customFields.field

Estado
subtletrue
titlestring

Nome do campo customizado.customFields.value

Estado
subtletrue
titlestring

Valor do campo customizado.Total de beneficiários com erro (em processamento, pode variar)BJ5_QTDERR

Campos Customizados

O campo customFields permite que o cliente adicione campos personalizados à resposta, oferecendo flexibilidade para configurar os dados da carteirinha conforme necessário. Utilize o ponto de entrada: PE PTBENCARD Campos Customizados para Carteirinha Virtual no Portal do Beneficiário

Imagens do Cartão

As imagens do cartão (frente e verso) são fornecidas em formato PNG, com tamanho de 420x240 pixels. As imagens são nomeadas como front-card.png e back-card.png e estão localizadas no diretório do servidor:

RootPath: \portais-saude\portal-beneficiario\card\

Arquivo de Configuração de LayoutNo mesmo diretório das imagens, um arquivo de configuração chamado layout-config.json. Este arquivo contém as definições para os campos que aparecerão no cartão, incluindo o layout de posicionamento e estilo CSS.
Para mais detalhes sobre a configuração da imagem e do layout, consulte a documentação Configuração do Layout Customizado da Carteirinha
Bloco de código
languagec#
themeMidnight
titleExemplo
collapsetrue
{

   "fields": {
    "namebatchCode": "Marli Brenda Viana00000155",
    "socialNamestatus": "1",
    "healthInsurerCodeimportDate": "0001",
    "companyCode": "0101",
    "registrationCode": "000007",
    "kinshipCode": "53",
    "digit": "5",
    "nationalHealthCard": "",
    "subscriberId": "00010101000007535",
    "birthDate": "1997-10-072025-08-22",
    "cardValidityimportTime": "",
    "effectiveDate": "2020-12-28",
    "cardCopy": "0617:07:17",
    "holderNameloginUser": "LUCAS NONATOVINIEMP",
    "holderHealthInsurerCodehealthInsurerCode": "",
    "holderCompanyCode": "0101",
    "holderRegistrationCode": "000007",
    "holderKinshipCode": "01",
    "holderDigit": "2",
    "holderSubscriberId": "00010101000007012",
    "dependentName": "Marli Brenda Viana",
    "dependentHealthInsurerCode": "0001",
    "dependentCompanyCodecompanyCode": "01011017",
    "dependentRegistrationCodecontractCode": "000007000000000001",
    "dependentKinshipCodecontractVersion": "53001",
    "dependentDigitsubcontractCode": "5000000001",
    "dependentSubscriberIdsubcontractVersion": "00010101000007535001",
    "planCodesubcontractDescription": "0001",
CONTRATO    "planDescription": "PLANO DOS GRANDE",
    "accommodationDescription": "INDIVIDUAL",
    "coverageArea": "GRUPODE IMPOT. DE ESTADOSBENEFICIARIOS",
    "planRegulationtotalCount": "PLANO REGULAMENTADO"8,
    "planCodeANSimportedCount": "123456"0,
    "planSegmentationerrorCount": "AMBULATORIAL",
    "subcontractCardName": "",
    "healthInsurerCodeANS": "888888",
    "healthInsurerName": "OPERADORA SAÚDE 888888"
  },
  "cardImage": {
    "front": "",
    "back": ""
  },
  "layoutConfig": {
    "front": [
      {
        "css": "font-size: 9px;font-weight: bold;top: 50px; width: 200px; left: 300px;",
        "values": [
          {
            "type": "custom",
            "value": "meuCampo"
          }
        ]
      },
      {
        "css": "font-size: 9px;font-weight: bold;top: 70px; width: 200px; left: 20px;",
        "values": [
          {
            "type": "field",
            "value": "planDescription"
          },
          {
            "type": "field",
            "value": "accommodationDescription"
          }
        ]
      },
      {
        "css": "font-size: 8px;top: 117px; width: 70px; left: 330px;",
        "values": [
          {
            "type": "text",
            "value": "VÁLIDO ATÉ:"
          }
        ]
      }
    ],
    "back": [
      {
        "css": "font-size: 9px;font-weight: bold;top: 70px; width: 200px; left: 100px;",
        "values": [
          {
            "type": "field",
            "value": "planDescription"
          },
          {
            "type": "field",
            "value": "accommodationDescription"
          }
        ]
      }
    ]
  },
  "customFields": [
    {
      "field": "meuCampo",
      "value": "Meu valor customizado"
    }
  ]
}
Nota
0
}
Informações
iconfalse
Aviso

400 - Formato de JSON inválido.
O corpo da requisição não está em um formato JSON válido. Verifique a estrutura e tente novamente.

Aviso

400 - Erro ao processar o arquivo CSV.
Não foi possível obter o arquivo CSV. Verifique se o arquivo está disponível e se está em um formato válido.

Aviso

400 - Os campos do cabeçalho do arquivo não correspondem ao modelo esperado para a importação de beneficiários.

Aviso

400 - O arquivo CSV do lote está vazio e não contém dados de beneficiários para processar.

Aviso

400 - Falha na validação dos dados.
"Mensagem de erro do MVC"

Aviso

400 - Parâmetro obrigatório não informado.
O parâmetro obrigatório deve ser enviado na requisição.

Aviso

404 - Contrato informado não encontrado.
O contrato informado não foi encontrado na tabela BQC. Verifique se o número do contrato está correto e devidamente cadastrado no sistema.

Aviso

406 - Formato de dados inválido.
Os dados enviados não estão no formato form-data. Verifique se o Content-Type da requisição está definido como multipart/form-data e se os campos foram corretamente estruturados

Informações
iconfalse
Aviso

404 - Beneficiário não encontrado

Caso o subscriberId informado não seja encontrado no sistema, a API retornará o código de erro E001 com uma mensagem detalhada

.

CampoTipoDescrição
code

Estado
subtletrue
titlestringINTEGER

Código identificador do erro.
message

Estado
subtletrue
titlestring

Literal no idioma da requisição descrevendo o erro para o usuário.
detailedMessage

Estado
subtletrue
titlestring

Mensagem técnica e mais detalhada do erro.
Bloco de código
languagec#
themeMidnight
titleExemplo JSON de Erro
collapsetrue
{
  "codestatus": "E001"400,
  "message": "NãoErro foiao possível localizarprocessar o beneficiário informado no sistema. Por favor, verifique os dados fornecidos e tente novamente.arquivo CSV",
  "detailedMessage": "O path informado (subscriberId) não Não foi encontradopossível naobter tabelao de beneficiários (BA1)arquivo CSV. AVerifique consultase considerouo osarquivo seguintes campos: BA1_CODINT, BA1_CODEMP, BA1_MATRIC, BA1_TIPREG e BA1_DIGITO. Verifique os dados enviados e tente novamenteestá disponível e se está em um formato válido."
}