gerarDas method
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);
}