X-Git-Url: http://git.cascardo.eti.br/?a=blobdiff_plain;f=rnet_encode.c;h=559b17fae1f5b4bb5c35990844a678173b70a6d0;hb=c09b5340844f0e8ea2613e5ad19adc811195dfce;hp=e9e5bdb6beb8b26b62d0b0712ad6cad21e8cfd04;hpb=34d938d18bb1c391b9506b9aedf1ce58532765c5;p=cascardo%2Flibreceita.git diff --git a/rnet_encode.c b/rnet_encode.c index e9e5bdb..559b17f 100644 --- a/rnet_encode.c +++ b/rnet_encode.c @@ -26,6 +26,11 @@ #include "rnet_message.h" #include "decfile.h" +#define RNET_HEADER_START_2013 111 +#define RNET_HEADER_END_2013 (RNET_HEADER_SIZE_2013 - 15) +#define RNET_HEADER_START_2014 111 +#define RNET_HEADER_END_2014 (RNET_HEADER_SIZE_2014 - 15) + int rnet_encode(struct rnet_decfile *decfile, struct rnet_message **msg) { int r; @@ -40,6 +45,10 @@ int rnet_encode(struct rnet_decfile *decfile, struct rnet_message **msg) uint16_t versao_pgd; uint64_t file_len; char *hash; + char *header; + uint8_t ret; + + size_t header_start, header_end; *msg = rnet_message_new(); if (*msg == NULL) { @@ -50,6 +59,7 @@ int rnet_encode(struct rnet_decfile *decfile, struct rnet_message **msg) hash = rnet_decfile_get_file_hash(decfile); if (!hash) return -1; + header = rnet_decfile_get_header(decfile); codigo_recnet = rnet_decfile_get_header_field(decfile, "codigo_recnet"); tp_arq = strtoul(codigo_recnet, NULL, 10); @@ -59,6 +69,17 @@ int rnet_encode(struct rnet_decfile *decfile, struct rnet_message **msg) exerc = rnet_decfile_get_header_field(decfile, "exerc"); uf = rnet_decfile_get_header_field(decfile, "uf"); versao_pgd = strtoul(rnet_decfile_get_header_field(decfile, "nr_versao"), NULL, 10); + ret = strtoul(rnet_decfile_get_header_field(decfile, "in_ret"), NULL, 10); + + if (!strcmp(ano, "2013")) { + header_start = RNET_HEADER_START_2013; + header_end = RNET_HEADER_END_2013; + } else if (!strcmp(ano, "2014")) { + header_start = RNET_HEADER_START_2014; + header_end = RNET_HEADER_END_2014; + } else { + return -EINVAL; + } (*msg)->buffer[0] = 0x40; (*msg)->len = 1; @@ -73,7 +94,7 @@ int rnet_encode(struct rnet_decfile *decfile, struct rnet_message **msg) r = rnet_message_add_ascii(msg, "tp_ni", "CPF"); r = rnet_message_add_u8(msg, "num_ass", 0); r = rnet_message_add_u32(msg, "p_comp", 0); - r = rnet_message_add_u8(msg, "ret", 0); + r = rnet_message_add_u8(msg, "ret", ret); r = rnet_message_add_u64(msg, "tam_arq", file_len); r = rnet_message_add_u64(msg, "tam_assinado", file_len); r = rnet_message_add_u64(msg, "tam_trans", file_len); @@ -82,12 +103,13 @@ int rnet_encode(struct rnet_decfile *decfile, struct rnet_message **msg) r = rnet_message_add_u16(msg, "versao_pgd", versao_pgd); r = rnet_message_add_u8(msg, "critica_validador", 0x06); r = rnet_message_add_ascii(msg, "ip_loc", "127.0.0.1"); - r = rnet_message_add_ascii(msg, "versao_java", "1.7.0_03-icedtea;OpenJDK Runtime Environment"); + r = rnet_message_add_ascii(msg, "versao_java", "1.5.0-gij;Free Software rnetclient pretending to be GNU Interpreter for Java"); r = rnet_message_add_ascii(msg, "origem", "JA2R"); r = rnet_message_add_ascii(msg, "so", "GNU"); - r = rnet_message_add_ascii(msg, "cliente", "201104"); + r = rnet_message_add_ascii(msg, "cliente", "201105"); + r = rnet_message_add_buffer(msg, "dados_val", header + header_start, header_end - header_start); r = rnet_message_add_u32(msg, "tam_dados_val", 0); - r = rnet_message_add_u64(msg, "tam_dados_val_chave", 0); + r = rnet_message_add_u32(msg, "tam_dados_val_chave", 0); r = rnet_message_add_u32(msg, "arquivos_restantes", 0); free(hash);