Now accepts argument '-f', for which the argument is a file path.
Opens file, then reads input from it.
If file is not provided or fopen() fails, ldaphotos defaults to reading message from standard input.
This commit is contained in:
Sandy Mossgrave 2023-05-21 23:05:39 +00:00
parent da6f0568b6
commit 980784ea29
8 changed files with 244 additions and 53 deletions

7
.gitignore vendored Normal file
View File

@ -0,0 +1,7 @@
# Generated directories
build/
objects/
# Autosave files
*~
*#

View File

@ -39,8 +39,8 @@ SOURCES := $(wildcard $(SRCDIR)/*.c)
OBJECTS := $(patsubst $(SRCDIR)/%.c, $(OBJDIR)/%.o, $(SOURCES)) OBJECTS := $(patsubst $(SRCDIR)/%.c, $(OBJDIR)/%.o, $(SOURCES))
CPPFLAGS := -I$(abspath $(INCDIR)) -MMD -MP -DUSE_LIBNOTIFY CPPFLAGS := -I$(abspath $(INCDIR)) -MMD -MP -DUSE_LIBNOTIFY -DUSE_SYSLOG
CFLAGS := -Wall -Werror -Wpedantic $(shell pkg-config --cflags libnotify) CFLAGS := -Wall -Werror -Wpedantic $(shell pkg-config --cflags libnotify) -ggdb
LDFLAGS := #-Lmath or whatever LDFLAGS := #-Lmath or whatever
LDLIBS := $(shell pkg-config --libs libnotify libcrypto) #-lm or whatever LDLIBS := $(shell pkg-config --libs libnotify libcrypto) #-lm or whatever

View File

@ -47,13 +47,13 @@ int rounduptoblocksize(int a){
unsigned char * digest(const unsigned char *in, size_t inlen, unsigned int * outlen){ unsigned char * digest(const unsigned char *in, size_t inlen, unsigned int * outlen){
if(!EVP_DigestInit_ex(md_ctx, md, NULL)){ if(!EVP_DigestInit_ex(md_ctx, md, NULL)){
log("Problem encountered while initializing digest"); log(LOG_INFO, "Problem encountered while initializing digest");
ERR_print_errors_fp(stderr); ERR_print_errors_fp(stderr);
return NULL; return NULL;
} }
if(!EVP_DigestUpdate(md_ctx, in, inlen)){ if(!EVP_DigestUpdate(md_ctx, in, inlen)){
log("Problem encountered while adding data to digest"); log(LOG_INFO, "Problem encountered while adding data to digest");
ERR_print_errors_fp(stderr); ERR_print_errors_fp(stderr);
return NULL; return NULL;
} }
@ -61,7 +61,39 @@ unsigned char * digest(const unsigned char *in, size_t inlen, unsigned int * out
unsigned char *out = OPENSSL_malloc(EVP_MD_get_size(md)); unsigned char *out = OPENSSL_malloc(EVP_MD_get_size(md));
if(!EVP_DigestFinal_ex(md_ctx, out, outlen)){ if(!EVP_DigestFinal_ex(md_ctx, out, outlen)){
log("Problem encountered while retrieving digest"); log(LOG_INFO, "Problem encountered while retrieving digest");
ERR_print_errors_fp(stderr);
return NULL;
}
return out;
}
int begin_digest(){
if(!EVP_DigestInit_ex(md_ctx, md, NULL)){
log(LOG_INFO, "Problem encountered while initializing digest");
ERR_print_errors_fp(stderr);
return 0;
}
return 1;
}
int digest_part(const unsigned char *in, size_t inlen){
if(!EVP_DigestUpdate(md_ctx, in, inlen)){
log(LOG_INFO, "Problem encountered while adding data to digest");
ERR_print_errors_fp(stderr);
return 0;
}
return 1;
}
unsigned char * get_digest(unsigned int * outlen){
unsigned char *out = OPENSSL_malloc(EVP_MD_get_size(md));
if(!EVP_DigestFinal_ex(md_ctx, out, outlen)){
log(LOG_INFO, "Problem encountered while retrieving digest");
ERR_print_errors_fp(stderr); ERR_print_errors_fp(stderr);
return NULL; return NULL;
} }

View File

@ -5,3 +5,7 @@ extern EVP_MD * md;
int init_hasher(void); int init_hasher(void);
int deinit_hasher(void); int deinit_hasher(void);
unsigned char * digest(const unsigned char *in, size_t inlen, unsigned int * outlen); unsigned char * digest(const unsigned char *in, size_t inlen, unsigned int * outlen);
int begin_digest();
int digest_part(const unsigned char *in, size_t inlen);
unsigned char * get_digest(unsigned int * outlen);

View File

@ -1,6 +1,8 @@
#ifndef LDAP_LOG #ifndef LDAP_LOG
#define LDAP_LOG #define LDAP_LOG
extern int run_verbose;
const char * currtime(void); const char * currtime(void);
/* /*
Great, I remember why I chose to use a macro. Great, I remember why I chose to use a macro.
@ -14,6 +16,15 @@ const char * currtime(void);
Let's see whether I can split the log(X) macro into this and a Let's see whether I can split the log(X) macro into this and a
function in log.h that supplies the time function in log.h that supplies the time
*/ */
#define log(X) printf("%s %s", currtime(), X)
#ifdef USE_SYSLOG
#include <syslog.h>
#define log(Y, ...) syslog(Y, __VA_ARGS__)
#endif
#ifndef USE_SYSLOG
#define log(Y, ...) printf("%s %s", currtime(), __VA_ARGS__)
#endif
#define verb(...) if(run_verbose)log(LOG_DEBUG, __VA_ARGS__)
#endif #endif

20
sources/include/main.h Normal file
View File

@ -0,0 +1,20 @@
/**
* Main.h: contains definitions for ldaphotos.c
*/
#define VERSION "v0.0"
#define TITLE "LDAP Photo Album, by Catluck Kettlemerry"
#define PROGNAME "ldaphotos"
#define USAGE0 "Usage:"
#define USAGE1 "[OPTION...]"
#define OPTIONS0 "Options:"
#define OPTIONS1 "\t-v run verbosely"
#define OPTIONS2 "\t-h show help and exit"
#define OPTIONS3 "\t-t provide terse output"
#define OPTIONS4 "\t-f <path> Read input from file <path>"
#define OPTIONS5 ""
#define OPTIONS6 ""
#define OPTIONS7 ""
#define OPTIONS8 ""
#define OPTIONS9 ""
#define OPTIONS10 "\t-p Print the effects of the given options for this invocation"

164
sources/main/ldaphotos.c Normal file
View File

@ -0,0 +1,164 @@
#include <stdio.h> // printf
#include <string.h> // memcpy
#include <unistd.h> // getopt
#ifdef USE_SYSLOG
#include <syslog.h>
#endif
#include "hasher.h"
#include "log.h"
#include "main.h"
#define PATHBUF 4097
#define BUFLEN 2048
int run_verbose = 0;
int run_terse = 0;
int force_print_parameters = 0;
void print_help(void){
printf("%s %s\n", TITLE, VERSION);
printf("%s %s %s\n", USAGE0, PROGNAME, USAGE1);
printf("%s\n%s\n%s\n%s\n%s\n%s\n%s\n%s\n%s\n%s\n%s\n",
OPTIONS0, OPTIONS1, OPTIONS2, OPTIONS3, OPTIONS4,
OPTIONS5, OPTIONS6, OPTIONS7, OPTIONS8, OPTIONS9,
OPTIONS10);
}
int main(int argc, char *const argv[]){
#ifdef USE_SYSLOG
openlog(PROGNAME, 0, LOG_USER);
#endif
char *filepath = (char*)malloc(sizeof(char) * PATHBUF);
int opt;
while((opt = getopt(argc, argv, "vhtpf:")) != -1) {
switch(opt){
case 'v':
run_verbose = 1;
break;
case 'h':
print_help();
return 0;
case 't':
run_terse = 1;
break;
case 'p':
force_print_parameters = 1;
break;
case 'f':
memcpy(filepath, optarg, strlen(optarg));
break;
default:
printf("Literally how could you pass an unspecified argument to this program");
}
}
/**
Print run parameters at startup
*/
if(force_print_parameters) {
if(run_terse && run_verbose){
printf(PROGNAME " called with arguments to run both tersely and verbosely, the author legitimately cannot tell what you want her to do\n");
} else if(run_terse) {
printf(PROGNAME " will run tersely\n");
} else if(run_verbose) {
printf(PROGNAME " will run verbosely\n");
}
if(!run_terse){
if(filepath != NULL){
printf(PROGNAME " will read input from file %s\n", filepath);
} else {
printf(PROGNAME " will read input from standard input\n");
}
}
}
if(init_hasher()){
log(LOG_INFO, "Error encountered while initializing hasher");
}
begin_digest();
/*
Set up input buffers
*/
// unsigned char * in stores the unsigned version of signin
unsigned char * in = (unsigned char*)malloc(sizeof(unsigned char) * BUFLEN);
char * signin = (char*)malloc(sizeof(char) * BUFLEN);
/* End set up buffers*/
/*
Set up the input stream
Try to open file pointed to by filepath, or else use stdin
*/
FILE * infile;
if(strlen(filepath) >= 0){
log(LOG_DEBUG, "Trying to open file %s for input", filepath);
infile = fopen(filepath, "r");
}
if(infile == NULL){
infile = stdin;
}
/* End set up the input stream */
/*
Give blocks of data to the message digest algorithm.
*/
size_t bytesdigested = 0;
unsigned int round = 0;
while(!feof(infile) && !ferror(infile)){
round++;
size_t bytesread = fread(signin, sizeof(char), sizeof(char) * BUFLEN, infile);
if(bytesread==0){
printf("0 bytes read, breaking");
break;
}
memcpy(in, signin, bytesread);
digest_part(in, bytesread);
bytesdigested += bytesread;
verb("Passed %lu bytes to digest algorithm in round %u, %lu bytes passed so far", bytesread, round, bytesdigested);
}
/* End give blocks of data to the message digest algorithm */
printf("Input:\n\t");
for(int i = 0; i < bytesdigested; i++){
printf("%02x ", in[i]);
}
printf("\n\t");
for(int i = 0; i < bytesdigested; i++){
printf(" %c ", in[i]);
}
printf("\n");
unsigned int len;
unsigned char * a = get_digest(&len);
char * aa = (char*)malloc(sizeof(char) * 2 * len);
printf("Output:\n\t");
for(int i = 0; i < len; i++){
sprintf(aa + (2 * i), "%02x", a[i]);
}
printf("%s\n", aa);
OPENSSL_free(a);
free(aa);
if(deinit_hasher()){
log(LOG_INFO, "Error encountered while deinitializing hasher");
}
log(LOG_INFO, "hi");
#ifdef USE_SYSLOG
closelog();
#endif
if(infile != stdin){
fclose(infile);
}
return 0;
}

View File

@ -1,47 +0,0 @@
#include <stdio.h>
#include <string.h>
#include "hasher.h"
#include "log.h"
#define BUFLEN 2048
int main(void){
log("hi\n");
if(init_hasher()){
log("Error encountered while initializing hasher");
}
unsigned char * in = (unsigned char*)malloc(sizeof(unsigned char) * BUFLEN);
size_t inlen = 0;
char * signin = (char*)malloc(sizeof(char) * BUFLEN);
ssize_t bytesread = getline(&signin, &inlen, stdin);
memcpy(in, signin, bytesread);
printf("Input:\n\t");
for(int i = 0; i < bytesread; i++){
printf("%02x ", in[i]);
}
printf("\n\t");
for(int i = 0; i < bytesread; i++){
printf(" %c ", in[i]);
}
printf("\n");
unsigned int len;
unsigned char * a = digest(in, bytesread, &len);
char * aa = (char*)malloc(sizeof(char) * 2 * len);
printf("Output:\n\t");
for(int i = 0; i < len; i++){
sprintf(aa + (2 * i), "%02x", a[i]);
}
printf("%s\n", aa);
OPENSSL_free(a);
free(aa);
if(deinit_hasher()){
log("Error encountered while deinitializing hasher");
}
return 0;
}