Árvore de páginas

Versões comparadas

Chave

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

...

Esta API retorna os dados da carteirinha do beneficiário informado, incluindo as imagens do cartão frente e verso. As informações relacionadas à montagem dos dados da carteirinha são retornadas, bem como campos customizados, permitindo uma configuração dinâmica da exibição do cartão no frontend.

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

02. ENDPOINT

Estado
subtletrue
colourBlue
titleGET
/totvsHealthPlans/familyContract/v1/beneficiaries/{subscriberId}/card

...

NomeTipoDescrição

Content-Type (header)

string

'application/json' é o formato do conteúdo
Authorization (Header)string

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

*required

Estado
subtletrue
colourRed
titleRequired

subscriberId (Path)string

Identificador único da carteirinha do beneficiário.

*required

04. RESPOSTA

...

Estado
subtletrue
colourRed
titleRequired

04. RESPOSTA

Informações
iconfalse
Dica

200 - 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 layout.

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 

Estado
subtletrue
title

...

string

Código de registro do

...

beneficiário.

BA1_MATRIC

fields.

...

kinshipCode 

Estado
subtletrue
titlestring

Código de parentesco

...

.

BA1_TIPREG

fields.

...

digit 

Estado
subtletrue
titlestring

Dígito de identificação

...

.

BA1_DIGITO

fields.

...

nationalHealthCard 

Estado

...

subtletrue
title

...

string

...

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

BTS_NRCRNA

fields.

...

subscriberId 

Estado

...

subtletrue
title

...

string

...

Identificador único do beneficiário.BA1_CODINT + BA1_CODEMP + BA1_MATRIC + BA1_TIPREG + BA1_DIGITO
fields.

...

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

fields.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

fields.holderCompanyCode 

Estado
subtletrue
titlestring

Có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.

BA1_CODINT

fields.dependentCompanyCode

Estado
subtletrue
titlestring

Código da empresa do dependente.

BA1_CODEMP

fields.dependentRegistrationCode 

Estado
subtletrue
titlestring

Código de registro do dependente.

BA1_MATRIC

fields.dependentKinshipCode 

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
fields.planCode 

Estado
subtletrue
titlestring

Código do plano.

BI3_CODIGO

fields.planDescription 

Estado
subtletrue
titlestring

Descrição do plano de saúde.

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_NOMCAR

fields.healthInsurerCodeANS 

Estado
subtletrue
titlestring

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

BA0_SUSEP

fields.healthInsurerName 

Estado
subtletrue
titlestring

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).
layoutConfig 

Estado
subtletrue
titleobject



layoutConfig.front 

Estado
subtletrue
titleobject[]

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.
Bloco de código
languagec#
themeMidnight
titleExemplo
collapsetrue
{

   "fields": {
    "name": "Marli Brenda Viana",
    "socialName": "",
    "healthInsurerCode": "0001",
    "companyCode": "0101",
    "registrationCode": "000007",
    "kinshipCode": "53",
    "digit": "5",
    "nationalHealthCard

...

Informações
iconfalse
Dica
iconfalse
title(200) - 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 layout.

CampoTipoDescrição
fields objeto
fields.name stringNome completo do beneficiário.
fields.socialNamestringNome social do beneficiário.
fields.healthInsurerCodestringCódigo da operadora de saúde.
fields.companyCode stringCódigo da empresa.
fields.registrationCode stringCódigo de registro do beneficiário.
fields.kinshipCode stringCódigo de parentesco.
fields.digit stringDígito de identificação.
fields.nationalHealthCard stringNúmero do cartão nacional de saúde
fields.subscriberId stringIdentificador único do beneficiário.
fields.birthDate string - dataData de nascimento do beneficiário.
fields.cardValidity string - dataData de validade do cartão.
fields.effectiveDate string - dataData de efetivação do plano de saúde.
fields.cardCopy stringIdentificador da cópia do cartão.
fields.holderName stringNome do titular do plano.
fields.holderHealthInsurerCode stringCódigo da operadora de saúde do titular.
fields.holderCompanyCode stringCódigo da empresa do titular.
fields.holderRegistrationCodestringCódigo de registro do titular.
fields.holderKinshipCode stringCódigo de parentesco do titular.
fields.holderDigit stringDígito de identificação do titular.
fields.holderSubscriberId stringIdentificador único do titular.
fields.dependentName stringNome do dependente.
fields.dependentHealthInsurerCode stringCódigo da operadora de saúde do dependente.
fields.dependentCompanyCodestringCódigo da empresa do dependente.
fields.dependentRegistrationCode stringCódigo de registro do dependente.
fields.dependentKinshipCode stringCódigo de parentesco do dependente.
fields.dependentDigit stringDígito de identificação do dependente.
fields.dependentSubscriberId stringIdentificador único do dependente.
fields.planCode stringCódigo do plano.
fields.planDescription stringDescrição do plano de saúde.
fields.accommodationDescription stringDescrição da acomodação do plano.
fields.coverageArea stringÁrea de cobertura do plano de saúde.
fields.planRegulation stringTipo de regulamentação do plano.
fields.planCodeANS stringCódigo do plano na ANS.
fields.planSegmentation stringSegmentação do plano.
fields.subcontractCardName stringNome do cartão de subcontrato.
fields.healthInsurerCodeANS stringCódigo da operadora de saúde na ANS.
fields.healthInsurerName stringNome da operadora de saúde.
cardImage objeto
cardImage.front stringImagem em base64 da frente do cartão (formato PNG).
cardImage.back stringImagem em base64 da verso do cartão (formato PNG).
layoutConfig objeto
layoutConfig.front array de objetosConfigurações de layout para a frente do cartão.
layoutConfig.front.css stringEstilo CSS para o campo.
layoutConfig.front.valuesarray de objetosValores a serem exibidos no campo.
layoutConfig.front.values.typestringTipo do campo, podendo ser: custom, field ou text.
layoutConfig.front.values.valuestringValor do campo.
layoutConfig.backarray de objetosConfigurações de layout para o verso do cartão.
layoutConfig.back.css stringEstilo CSS para o campo.
layoutConfig.back.valuesarray de objetosValores a serem exibidos no campo.
layoutConfig.back.values.typestringTipo do campo, podendo ser: custom, field ou text.
layoutConfig.back.values.valuestringValor do campo.
customFields array de objetos
customFields.fieldstringNome do campo customizado.
customFields.valuestringValor do campo customizado.
Bloco de código
languagec#
themeMidnight
titleExemplo
collapsetrue
{

   "fields": {
    "name": "Marli Brenda Viana",
    "socialName": "",
    "healthInsurerCodesubscriberId": "000100010101000007535",
    "companyCodebirthDate": "01011997-10-07",
    "registrationCodecardValidity": "000007",
    "kinshipCodeeffectiveDate": "532020-12-28",
    "digitcardCopy": "506",
    "nationalHealthCardholderName": "LUCAS NONATO",
    "subscriberIdholderHealthInsurerCode": "00010101000007535",
    "birthDateholderCompanyCode": "1997-10-070101",
    "cardValidityholderRegistrationCode": "000007",
    "effectiveDateholderKinshipCode": "2020-12-2801",
    "cardCopyholderDigit": "062",
    "holderNameholderSubscriberId": "LUCAS NONATO00010101000007012",
    "holderHealthInsurerCodedependentName": "Marli Brenda Viana",
    "holderCompanyCodedependentHealthInsurerCode": "01010001",
    "holderRegistrationCodedependentCompanyCode": "0000070101",
    "holderKinshipCodedependentRegistrationCode": "01000007",
    "holderDigitdependentKinshipCode": "253",
    "holderSubscriberIddependentDigit": "000101010000070125",
    "dependentNamedependentSubscriberId": "Marli Brenda Viana00010101000007535",
    "dependentHealthInsurerCodeplanCode": "0001",
    "dependentCompanyCodeplanDescription": "0101PLANO DOS GRANDE",
    "dependentRegistrationCodeaccommodationDescription": "000007INDIVIDUAL",
    "dependentKinshipCodecoverageArea": "53",
 GRUPO DE ESTADOS",
    "dependentDigitplanRegulation": "5PLANO REGULAMENTADO",
    "dependentSubscriberIdplanCodeANS": "00010101000007535123456",
    "planCodeplanSegmentation": "0001AMBULATORIAL",
    "planDescriptionsubcontractCardName": "PLANO DOS GRANDE",
    "accommodationDescriptionhealthInsurerCodeANS": "INDIVIDUAL888888",
    "coverageAreahealthInsurerName": "GRUPOOPERADORA DESAÚDE ESTADOS888888",
  },
  "planRegulationcardImage": "PLANO REGULAMENTADO",{
    "planCodeANSfront": "123456",
    "planSegmentationback": "AMBULATORIAL",
    "subcontractCardName": ""},
    "healthInsurerCodeANSlayoutConfig": "888888",{
    "healthInsurerNamefront": "OPERADORA SAÚDE 888888"
[
   },
  "cardImage": {
    "front": "",
    "backcss": ""
  },
  "layoutConfig": {
    "front": [
      {
        "css": "font-size: 9px;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"
    }
  ]
}

Exemplo de resposta:

...

 {
            "type": "field",
            "value": "accommodationDescription"
          }
        ]
      }
    ]
  },
  "customFields": [
    {
      "field": "meuCampo",
      "value": "Meu valor customizado"
    }
  ]
}
Nota

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 Layout

No 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

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
titlestring

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
collapsetrue
{
  "code": "E001",
  "message": "Não foi possível localizar o beneficiário informado no sistema. Por favor, verifique os dados fornecidos e tente novamente.",
  "detailedMessage": "O path informado (subscriberId) não foi encontrado na tabela de beneficiários (BA1). A consulta considerou os seguintes campos: BA1_CODINT, BA1_CODEMP, BA1_MATRIC, BA1_TIPREG e BA1_DIGITO. Verifique os dados enviados e tente novamente."
}