﻿{
  "openapi": "3.0.0",
  "info": {
    "title": "API Efetivar Cotação",
    "version": "1.0.0"
  },
  "servers": [
    {
      "url": "https://sauto.dsv.bradescoseguros.com.br:443/V2/WSBL-CotacaoCSP/service/",
      "description": "Desenvolvimento"
    },
    {
      "url": "https://sauto.hml.bradescoseguros.com.br:443/V2/WSBL-CotacaoCSP/service/",
      "description": "Homologação"
    },
    {
      "url": "https://sauto.bradescoseguros.com.br:443/V2/WSBL-CotacaoCSP/service/",
      "description": "Produção"
    }
  ],
  "paths": {
    "/efetivar": {
      "post": {
        "tags": [
          "Efetivação"
        ],
        "summary": "Efetivar Cotação",
        "operationId": "efetivar",
        "requestBody": {
          "required": true,
          "content": {
            "application/json": {
              "schema": {
                "$ref": "#/components/schemas/EfetivarCotacaoDto"
              }
            }
          }
        },
        "responses": {
          "200": {
            "description": "Operação bem-sucedida",
            "content": {
              "application/json": {
                "schema": {
                  "$ref": "#/components/schemas/SPropostaVo"
                }
              }
            }
          },
          "400": {
            "description": "Solicitação inválida",
            "content": {
              "application/json": {
                "schema": {
                  "$ref": "#/components/schemas/SPropostaVo"
                }
              }
            }
          },
          "500": {
            "description": "Erro interno do servidor",
            "content": {
              "application/json": {
                "schema": {
                  "$ref": "#/components/schemas/MensagemErroVo"
                }
              }
            }
          },
          "503": {
            "description": "Serviço indisponível",
            "content": {
              "application/json": {
                "schema": {
                  "$ref": "#/components/schemas/MensagemErroVo"
                }
              }
            }
          }
        },
        "security": [
          {
            "bearerAuth": []
          }
        ]
      }
    }
  },
  "components": {
    "securitySchemes": {
      "bearerAuth": {
        "type": "http",
        "scheme": "bearer",
        "bearerFormat": "JWT"
      }
    },
    "schemas": {
      "EfetivarCotacaoDto": {
        "type": "object",
        "properties": {
          "autenticacao": {
            "$ref": "#/components/schemas/Autenticacao",
            "description": "Dados de autenticação"
          },
          "eEfetivarCotacaoVoIn": {
            "$ref": "#/components/schemas/EEfetivarCotacaoVoIn",
            "description": "Dados da efetivação da cotação"
          }
        },
        "required": [
          "autenticacao",
          "eEfetivarCotacaoVoIn"
        ]
      },
      "Autenticacao": {
        "type": "object",
        "properties": {
          "provedor": {
            "type": "integer",
            "format": "int64",
            "description": "Provedor de autenticação",
            "example": 1
          },
          "usuario": {
            "type": "string",
            "description": "Nome de usuário",
            "example": "usuario123"
          },
          "senha": {
            "type": "string",
            "description": "Senha do usuário",
            "example": "senhaSegura123"
          }
        },
        "required": [
          "provedor",
          "usuario",
          "senha"
        ]
      },
      "EEfetivarCotacaoVoIn": {
        "type": "object",
        "properties": {
          "codigoFormaPagamento": {
            "type": "integer",
            "description": "Código da forma de pagamento",
            "example": 1
          },
          "melhorDiaVencimento": {
            "type": "integer",
            "description": "Melhor dia de vencimento",
            "example": 15
          },
          "numeroPrestacoes": {
            "type": "integer",
            "description": "Número de prestações",
            "example": 12
          },
          "chassiVeiculo": {
            "type": "string",
            "description": "Chassi do veículo",
            "example": "9BWZZZ377VT004251"
          },
          "placaVeiculo": {
            "type": "string",
            "description": "Placa do veículo",
            "example": "ABC1234"
          },
          "dadosPessoaisEfetivacaoVoIn": {
            "$ref": "#/components/schemas/DadosPessoaisEfetivacaoVoIn"
          },
          "dadosRenovacaoEfetivacaoVoIn": {
            "$ref": "#/components/schemas/DadosRenovacaoEfetivacaoVoIn"
          },
          "buscaCotacaoVo": {
            "$ref": "#/components/schemas/BuscaCotacaoVo"
          },
          "cartaoCreditoVo": {
            "$ref": "#/components/schemas/CartaoCreditoVo"
          },
          "dadosBancariosVo": {
            "$ref": "#/components/schemas/DadosBancariosVo"
          },
          "eTeleEmpresaVo": {
            "$ref": "#/components/schemas/ETeleEmpresaVo"
          },
          "cdConcessionaria": {
            "type": "integer",
            "description": "Código da concessionária",
            "example": 123456
          },
          "cdAngariador": {
            "type": "integer",
            "description": "Código do angariador",
            "example": 654321
          },
          "cdRevenda": {
            "type": "integer",
            "description": "Código da revenda",
            "example": 789012
          },
          "cdAgenciaProdutor": {
            "type": "integer",
            "description": "Código da agência do produtor",
            "example": 345678
          },
          "cdVendedor": {
            "type": "integer",
            "description": "Código do vendedor",
            "example": 901234
          },
          "nuControleLeasing": {
            "type": "string",
            "description": "Número de controle do leasing",
            "example": "LEAS123456"
          },
          "dtLeasing": {
            "type": "string",
            "description": "Data do leasing",
            "example": "2023-10-01"
          },
          "dadosBancariosCredito": {
            "$ref": "#/components/schemas/DadosBancariosCreditoVo"
          },
          "versaoAplicacao": {
            "type": "string",
            "description": "Versão da aplicação",
            "example": "1.0.0"
          },
          "pontoSelecionado": {
            "$ref": "#/components/schemas/Livelo"
          }
        },
        "required": [
          "buscaCotacaoVo",
          "chassiVeiculo",
          "codigoFormaPagamento",
          "numeroPrestacoes",
          "dadosPessoaisEfetivacaoVoIn",
          "placaVeiculo"
        ]
      },
      "DadosPessoaisEfetivacaoVoIn": {
        "type": "object",
        "properties": {
          "nomeProponente": {
            "type": "string",
            "description": "Nome do proponente",
            "example": "João Silva"
          },
          "cpfCnpjProponente": {
            "type": "string",
            "description": "CPF ou CNPJ do proponente",
            "example": 12345678901
          },
          "emailProponente": {
            "type": "string",
            "description": "Email do proponente",
            "example": "joao.silva@example.com"
          },
          "numeroDocumentoProponente": {
            "type": "string",
            "description": "Número do documento do proponente",
            "example": 123456789
          },
          "tipoDocumento": {
            "type": "string",
            "description": "Tipo do documento do proponente",
            "example": "RG"
          },
          "nomeOrgEmissorDocumentoProponente": {
            "type": "string",
            "description": "Nome do órgão emissor do documento do proponente",
            "example": "SSP"
          },
          "dataEmissaoDocumentoProponente": {
            "type": "string",
            "description": "Data de emissão do documento do proponente",
            "example": "2023-01-01T00:00:00.000Z"
          },
          "nomeProprietario": {
            "type": "string",
            "description": "Nome do proprietário",
            "example": "Maria Oliveira"
          },
          "cpfCnpjProprietario": {
            "type": "string",
            "description": "CPF ou CNPJ do proprietário",
            "example": 98765432100
          },
          "atividadeOcupacaoProponente": {
            "type": "integer",
            "description": "Atividade ou ocupação do proponente",
            "example": 1
          },
          "tipoRelacionamento": {
            "type": "integer",
            "description": "Tipo de relacionamento",
            "example": 2
          },
          "eTelefoneVoResidencial": {
            "$ref": "#/components/schemas/ETelefoneVo"
          },
          "eTelefoneVoComercial": {
            "$ref": "#/components/schemas/ETelefoneVo"
          },
          "eTelefoneVoCelular": {
            "$ref": "#/components/schemas/ETelefoneVo"
          },
          "eEnderecoVoCobranca": {
            "$ref": "#/components/schemas/EEnderecoVo"
          },
          "enderecoPernoiteReduzido": {
            "$ref": "#/components/schemas/EnderencoReduzidoVo"
          },
          "enderecoResidencialReduzido": {
            "$ref": "#/components/schemas/EnderencoReduzidoVo"
          },
          "flEmailTelefoneEDoSegurado": {
            "type": "string",
            "description": "Flag indicando se o email e telefone são do segurado",
            "example": "S"
          }
        },
        "required": [
          "cpfCnpjProponente",
          "dataEmissaoDocumentoProponente",
          "eEnderecoVoCobranca",
          "eTelefoneVoCelular",
          "emailProponente",
          "enderecoPernoiteReduzido",
          "flEmailTelefoneEDoSegurado",
          "nomeOrgEmissorDocumentoProponente",
          "nomeProponente",
          "nomeProprietario",
          "numeroDocumentoProponente",
          "tipoDocumento",
          "tipoRelacionamento"
        ]
      },
      "DadosRenovacaoEfetivacaoVoIn": {
        "type": "object",
        "properties": {
          "flComodatoApoliceAnterior": {
            "type": "string",
            "description": "Flag de comodato da apólice anterior",
            "example": "S"
          },
          "cdApoliceAnterior": {
            "type": "string",
            "description": "Código da apólice anterior",
            "example": "123456789"
          },
          "cdColigada": {
            "type": "integer",
            "description": "Código da coligada",
            "example": 1
          },
          "cdSucursalAnterior": {
            "type": "integer",
            "description": "Código da sucursal anterior",
            "example": 2
          },
          "cdItemAnterior": {
            "type": "integer",
            "description": "Código do item anterior",
            "example": 3
          },
          "cdChaveIdentificacao": {
            "type": "string",
            "description": "Código da chave de identificação",
            "example": "ABC123"
          },
          "cdCiaInterna": {
            "type": "integer",
            "description": "Código da companhia interna",
            "example": 4
          },
          "flGrupoBradesco": {
            "type": "string",
            "description": "Flag do grupo Bradesco",
            "example": "N"
          },
          "nuDigitoApoliceAnt": {
            "type": "integer",
            "description": "Número do dígito da apólice anterior",
            "example": 5
          }
        }
      },
      "BuscaCotacaoVo": {
        "type": "object",
        "properties": {
          "cdCorretor": {
            "type": "string",
            "description": "Código do corretor",
            "example": "12345"
          },
          "nuCpfCnpjCorretor": {
            "type": "string",
            "description": "Número do CPF ou CNPJ do corretor",
            "example": "12345678901"
          },
          "cdModalidade": {
            "type": "string",
            "description": "Código da modalidade",
            "example": "E"
          },
          "cdSucursal": {
            "type": "string",
            "description": "Código da sucursal",
            "example": "001"
          },
          "nuCotacao": {
            "type": "string",
            "description": "Número da cotação",
            "example": "123456"
          },
          "cdItem": {
            "type": "string",
            "description": "Código do item",
            "example": "789"
          }
        },
        "required": [
          "cdCorretor",
          "nuCpfCnpjCorretor",
          "cdModalidade",
          "cdSucursal",
          "nuCotacao",
          "cdItem"
        ]
      },
      "CartaoCreditoVo": {
        "type": "object",
        "properties": {
          "dtValidadeCartaoCredito": {
            "type": "string",
            "description": "Data de validade do cartão de crédito",
            "example": "12/23"
          },
          "nuCartaoCredito": {
            "type": "string",
            "description": "Número do cartão de crédito",
            "example": "1234-5678-9876-5432"
          },
          "cdBandeiraCartaoCredito": {
            "type": "integer",
            "description": "Código da bandeira do cartão de crédito",
            "example": 1
          }
        }
      },
      "DadosBancariosVo": {
        "type": "object",
        "properties": {
          "cdBanco": {
            "type": "integer",
            "description": "Código do banco",
            "example": 123
          },
          "cdAgenciaDebito": {
            "type": "integer",
            "description": "Código da agência de débito",
            "example": 456
          },
          "nuDigitoAgenciaDebito": {
            "type": "string",
            "description": "Dígito da agência de débito",
            "example": "7"
          },
          "cdContaDebito": {
            "type": "integer",
            "description": "Código da conta de débito",
            "example": 789012
          },
          "nuDigitoContaDebito": {
            "type": "string",
            "description": "Dígito da conta de débito",
            "example": "3"
          }
        }
      },
      "ETeleEmpresaVo": {
        "type": "object",
        "properties": {
          "cdParentescoTeleempresa": {
            "type": "integer",
            "description": "Código do parentesco da teleempresa",
            "example": 1
          },
          "cdTipoGrupo": {
            "type": "integer",
            "description": "Código do tipo de grupo",
            "example": 2
          },
          "cdSubEstipulante": {
            "type": "integer",
            "description": "Código do subestipulante",
            "example": 3
          },
          "cdAgenciaFilial": {
            "type": "integer",
            "description": "Código da agência filial",
            "example": 4
          },
          "nuMatricula": {
            "type": "integer",
            "format": "int64",
            "description": "Número da matrícula",
            "example": 123456789
          },
          "cdDepartamento": {
            "type": "integer",
            "description": "Código do departamento",
            "example": 5
          },
          "cdIdentidade": {
            "type": "integer",
            "description": "Código da identidade",
            "example": 6
          }
        }
      },
      "DadosBancariosCreditoVo": {
        "type": "object",
        "properties": {
          "flDadosBancarioCredito": {
            "type": "string",
            "description": "Flag de dados bancários de crédito",
            "example": "S"
          },
          "cdBanco": {
            "type": "integer",
            "description": "Código do banco",
            "example": 123
          },
          "cdAgenciaCredito": {
            "type": "integer",
            "description": "Código da agência de crédito",
            "example": 456
          },
          "nuDigitoAgenciaCredito": {
            "type": "string",
            "description": "Dígito da agência de crédito",
            "example": "7"
          },
          "cdContaCredito": {
            "type": "integer",
            "description": "Código da conta de crédito",
            "example": 78901234
          },
          "nuDigitoContaCredito": {
            "type": "string",
            "description": "Dígito da conta de crédito",
            "example": "8"
          },
          "nuRazaoConta": {
            "type": "integer",
            "description": "Número da razão da conta",
            "example": 9
          }
        }
      },
      "Livelo": {
        "type": "object",
        "properties": {
          "id": {
            "type": "integer",
            "description": "Identificador do Livelo",
            "example": 1
          },
          "ponto": {
            "type": "number",
            "format": "double",
            "description": "Pontuação do Livelo",
            "example": 100
          },
          "valorDesconto": {
            "type": "number",
            "format": "double",
            "description": "Valor de desconto do Livelo",
            "example": 50
          }
        }
      },
      "SPropostaVo": {
        "type": "object",
        "properties": {
          "nuProposta": {
            "type": "string",
            "description": "Número da proposta",
            "example": "123456"
          },
          "dtEfetivacao": {
            "type": "string",
            "format": "date-time",
            "description": "Data de efetivação",
            "example": "2023-10-01T00:00:00Z"
          },
          "listaAlertas": {
            "type": "array",
            "description": "Lista de alertas",
            "items": {
              "$ref": "#/components/schemas/MensagemAlertaVo"
            }
          },
          "mensagemErroVo": {
            "$ref": "#/components/schemas/MensagemErroVo"
          }
        }
      },
      "MensagemAlertaVo": {
        "type": "object",
        "properties": {
          "cdAlerta": {
            "type": "integer",
            "description": "Código do alerta",
            "example": 1
          },
          "dsAlerta": {
            "type": "string",
            "description": "Descrição do alerta",
            "example": "Alerta de exemplo"
          },
          "flAcatavel": {
            "type": "string",
            "description": "Flag indicando se o alerta é acatável",
            "example": "S"
          },
          "flImpacto": {
            "type": "string",
            "description": "Flag indicando o impacto do alerta",
            "example": "N"
          },
          "dtLiberacao": {
            "type": "string",
            "format": "date-time",
            "description": "Data de liberação do alerta",
            "example": "2023-10-01T12:00:00Z"
          },
          "dtCancelamento": {
            "type": "string",
            "format": "date-time",
            "description": "Data de cancelamento do alerta",
            "example": "2023-10-02T12:00:00Z"
          }
        }
      },
      "MensagemErroVo": {
        "type": "object",
        "properties": {
          "cdErro": {
            "type": "integer"
          },
          "dsErro": {
            "type": "string"
          }
        }
      },
      "ETelefoneVo": {
        "type": "object",
        "properties": {
          "cdTipoTelefone": {
            "type": "integer",
            "description": "Código do tipo de telefone",
            "example": 1
          },
          "nuDDD": {
            "type": "integer",
            "description": "Número do DDD",
            "example": 11
          },
          "nuTelefone": {
            "type": "integer",
            "description": "Número do telefone",
            "example": 987654321
          },
          "nuRamal": {
            "type": "integer",
            "description": "Número do ramal",
            "example": 1234
          }
        },
        "required": [
          "cdTipoTelefone",
          "nuDDD",
          "nuTelefone",
          "nuRamal"
        ]
      },
      "EEnderecoVo": {
        "type": "object",
        "properties": {
          "cdTipoEndereco": {
            "type": "integer",
            "description": "Código do tipo de endereço",
            "example": 1
          },
          "cdTipoLogadouro": {
            "type": "integer",
            "description": "Código do tipo de logradouro",
            "example": 2
          },
          "nmLogadouro": {
            "type": "string",
            "description": "Nome do logradouro",
            "example": "Avenida Paulista"
          },
          "nuLogadouro": {
            "type": "integer",
            "description": "Número do logradouro",
            "example": 1234
          },
          "dsComplemento": {
            "type": "string",
            "description": "Descrição do complemento",
            "example": "Apto 101"
          },
          "nmBairro": {
            "type": "string",
            "description": "Nome do bairro",
            "example": "Bela Vista"
          },
          "nmMunicipio": {
            "type": "string",
            "description": "Nome do município",
            "example": "São Paulo"
          },
          "cdUF": {
            "type": "string",
            "description": "Código da Unidade Federativa",
            "example": "SP"
          },
          "dsUF": {
            "type": "string",
            "description": "Descrição da Unidade Federativa",
            "example": "São Paulo"
          },
          "nuCep": {
            "type": "string",
            "description": "Número do CEP",
            "example": "01311-000"
          }
        },
        "required": [
          "cdTipoEndereco",
          "cdTipoLogadouro",
          "nmLogadouro",
          "nuLogadouro",
          "dsComplemento",
          "nmBairro",
          "nmMunicipio",
          "cdUF",
          "dsUF",
          "nuCep"
        ]
      },
      "EnderencoReduzidoVo": {
        "type": "object",
        "properties": {
          "complemento": {
            "type": "string",
            "description": "Complemento do endereço",
            "example": "Apto 101"
          },
          "numero": {
            "type": "integer",
            "description": "Número do endereço",
            "example": 123
          },
          "nmBairro": {
            "type": "string",
            "description": "Nome do bairro",
            "example": "Centro"
          }
        }
      }
    }
  }
}