X-Git-Url: http://git.cascardo.eti.br/?a=blobdiff_plain;f=rnet_encode.c;h=d37f06bdd6b3eae4ea9e2fae4cf6a9308667b700;hb=55f25c704d690159de79a7339285f2b269eb157e;hp=9800ec6740cc0bf8d5318c290f8d02f7c397ce7b;hpb=9cc129999c4236370e638dc9ef69c25f1793fd78;p=cascardo%2Flibreceita.git diff --git a/rnet_encode.c b/rnet_encode.c index 9800ec6..d37f06b 100644 --- a/rnet_encode.c +++ b/rnet_encode.c @@ -39,6 +39,8 @@ int rnet_encode(struct rnet_decfile *decfile, struct rnet_message **msg) char *uf; uint16_t versao_pgd; uint64_t file_len; + char *hash; + char *header; *msg = rnet_message_new(); if (*msg == NULL) { @@ -46,6 +48,10 @@ int rnet_encode(struct rnet_decfile *decfile, struct rnet_message **msg) } file_len = rnet_decfile_get_file(decfile)->len; + 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); @@ -63,8 +69,10 @@ int rnet_encode(struct rnet_decfile *decfile, struct rnet_message **msg) r = rnet_message_add_u32(msg, "id_dec", id_dec); r = rnet_message_add_ascii(msg, "exercicio", ano); r = rnet_message_add_ascii(msg, "exercicio_pgd", exerc); + r = rnet_message_add_buffer(msg, "hash_arq", hash, 16); + r = rnet_message_add_buffer(msg, "hash_trans", hash, 16); r = rnet_message_add_ascii(msg, "ni", cpf); - r = rnet_message_add_ascii(msg, "tipo_ni", "CPF"); + 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); @@ -80,10 +88,13 @@ int rnet_encode(struct rnet_decfile *decfile, struct rnet_message **msg) 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_buffer(msg, "dados_val", header + 111, 750 - 111); 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); + if (r < 0) return r; return 0;