/* * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include "config.h" #include "printf.h" #include "util.h" #include "cryptobox.h" #include "unix-std.h" static double total_time = 0; static void rspamd_process_file(const char *fname, int decode) { int fd; gpointer map; struct stat st; uint8_t *dest; gsize destlen; fd = open(fname, O_RDONLY); if (fd == -1) { rspamd_fprintf(stderr, "cannot open %s: %s", fname, strerror(errno)); exit(EXIT_FAILURE); } if (fstat(fd, &st) == -1) { rspamd_fprintf(stderr, "cannot stat %s: %s", fname, strerror(errno)); exit(EXIT_FAILURE); } map = mmap(NULL, st.st_size, PROT_READ, MAP_SHARED, fd, 0); close(fd); if (map == MAP_FAILED) { rspamd_fprintf(stderr, "cannot mmap %s: %s", fname, strerror(errno)); exit(EXIT_FAILURE); } if (decode) { destlen = st.st_size / 4 * 3 + 10; dest = g_malloc(destlen); rspamd_cryptobox_base64_decode(map, st.st_size, dest, &destlen); } else { dest = rspamd_encode_base64(map, st.st_size, 80, &destlen); } rspamd_printf("%*s", (int) destlen, dest); g_free(dest); munmap(map, st.st_size); } int main(int argc, char **argv) { int i, start = 1, decode = 0; if (argc > 2 && *argv[1] == '-') { start = 2; if (argv[1][1] == 'd') { decode = 1; } } for (i = start; i < argc; i++) { if (argv[i]) { rspamd_process_file(argv[i], decode); } } return 0; }