gerarDas method

Future<GerarDasResponse> gerarDas({
  1. String? contribuinteNumero,
  2. required String periodoApuracao,
  3. String? dataConsolidacao,
  4. String? contratanteNumero,
  5. String? autorPedidoDadosNumero,
})

Gerar DAS de uma declaração previamente transmitida

contribuinteNumero CNPJ do contribuinte periodoApuracao Período de apuração (formato: AAAAMM) dataConsolidacao Data de consolidação futura (opcional) contratanteNumero CNPJ do contratante (opcional, usa dados da autenticação se não informado) autorPedidoDadosNumero CPF/CNPJ do autor do pedido (opcional, usa dados da autenticação se não informado)

Implementation

Future<GerarDasResponse> gerarDas({
  String? contribuinteNumero,
  required String periodoApuracao,
  String? dataConsolidacao,
  String? contratanteNumero,
  String? autorPedidoDadosNumero,
}) async {
  final resolvedContribuinte =
      contribuinteNumero ??
      _apiClient.contribuinteNumero ??
      (throw ArgumentError('CNPJ do contribuinte é obrigatório'));
  final dasRequest = GerarDasRequest(
    periodoApuracao: periodoApuracao,
    dataConsolidacao: dataConsolidacao,
  );

  if (!dasRequest.isValid) {
    throw ArgumentError('Dados para geração do DAS inválidos');
  }

  final baseRequest = BaseRequest(
    contribuinteNumero: resolvedContribuinte,
    pedidoDados: PedidoDados(
      idSistema: 'PGDASD',
      idServico: 'GERARDAS12',
      versaoSistema: '1.0',
      dados: dasRequest.toJson().toString(),
    ),
  );

  final response = await _apiClient.post(
    '/Emitir',
    baseRequest,
    contratanteNumero: contratanteNumero,
    autorPedidoDadosNumero: autorPedidoDadosNumero,
  );
  return GerarDasResponse.fromJson(response);
}