diff options
| -rw-r--r-- | .gitignore | 2 | ||||
| -rw-r--r-- | Makefile | 29 | ||||
| -rw-r--r-- | client/main.c | 64 | ||||
| -rw-r--r-- | lib/crypto/aes.c | 2 | ||||
| -rw-r--r-- | lib/crypto/ecdh.c | 2 | ||||
| -rw-r--r-- | lib/include/net/auth.h | 6 | ||||
| -rw-r--r-- | lib/include/net/param.h | 2 | ||||
| -rw-r--r-- | lib/include/net/stpsession.h | 4 | ||||
| -rw-r--r-- | lib/include/server.h (renamed from lib/include/libostp/server.h) | 4 | ||||
| -rw-r--r-- | lib/include/session.h (renamed from lib/include/libostp/session.h) | 0 | ||||
| -rw-r--r-- | lib/libostp/auth.c | 6 | ||||
| -rw-r--r-- | lib/libostp/param.c | 12 | ||||
| -rw-r--r-- | lib/libostp/server.c | 6 | ||||
| -rw-r--r-- | lib/libostp/session.c | 12 | ||||
| -rw-r--r-- | lib/net/frame.c | 4 | ||||
| -rw-r--r-- | ostp.d/init/main.c | 59 | 
16 files changed, 45 insertions, 169 deletions
| @@ -1,3 +1,3 @@ -so/  bin/  *.o +*.so @@ -1,22 +1,10 @@ -CFILES_OTD = $(shell find ostp.d/ -name "*.c")  CFILES_OTLIB = $(shell find lib/ -name "*.c") -CFILES_CLIENT = $(shell find client/ -name "*.c") -CFLAGS_OTD = -pedantic -Iostp.d/include/ -Ilib/include/ -CFLAGS_CLIENT = -pedantic -Iclient/include/ -Ilib/include/  CFLAGS_OTLIB = -pedantic -Ilib/include/ -fPIC -lssl -lcrypto  OTLIB_OBJ = $(CFILES_OTLIB:.c=.o)  CC = gcc -.PHONY: all -all: $(OTLIB_OBJ) bin/ostp.d bin/client - -bin/ostp.d: $(CFILES_OTD) -	mkdir -p $(@D) -	$(CC) $(CFLAGS_OTD) $(OTLIB_OBJ) $^ -lssl -lcrypto -o $@ - -bin/client: $(CFILES_CLIENT) -	mkdir -p $(@D) -	$(CC) $(CFLAGS_CLIENT) $(OTLIB_OBJ) $^ -lssl -lcrypto -o $@ +libostp.so: $(OTLIB_OBJ) +	gcc -shared -o $@ $(OTLIB_OBJ)  %.o: %.c  	mkdir -p $(@D) @@ -24,4 +12,15 @@ bin/client: $(CFILES_CLIENT)  .PHONY: clean  clean: -	rm -rf bin/ $(OTLIB_OBJ) +	rm -rf $(OTLIB_OBJ) + +.PHONY: headers +headers: +	mkdir -p /usr/include/ostp/ +	cp -r lib/include/* /usr/include/ostp/ + +.PHONY: install +install: +	cp libostp.so /usr/lib +	chmod 0755 /usr/lib/libostp.so +	ldconfig diff --git a/client/main.c b/client/main.c deleted file mode 100644 index 0f87639..0000000 --- a/client/main.c +++ /dev/null @@ -1,64 +0,0 @@ -/* - * Copyright (c) 2023-2024 Ian Marco Moffett and the Osmora Team. - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions are met: - * - * 1. Redistributions of source code must retain the above copyright notice, - *    this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - *    notice, this list of conditions and the following disclaimer in the - *    documentation and/or other materials provided with the distribution. - * 3. Neither the name of Hyra nor the names of its - *    contributors may be used to endorse or promote products derived from - *    this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE - * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR - * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF - * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS - * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN - * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) - * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE - * POSSIBILITY OF SUCH DAMAGE. - */ - -#include <libostp/session.h> -#include <stdio.h> - -#define CENTRAL_SERVER "149.248.6.149" -// #define CENTRAL_SERVER "127.0.0.1" - -int -main(int argc, char **argv) -{ -    char buf[] = "Hello, World!\n"; -    char recv_buf[4096]; -    struct ostp_session s; -    int err; - -    if ((err = session_new(CENTRAL_SERVER, &s)) < 0) { -        fprintf(stderr, "Failed to create new session!\n"); -        return err; -    } - -    if (argc >= 2) { -        if (session_send(buf, sizeof(buf), &s) < 0) { -            fprintf(stderr, "Failed to send data to server!\n"); -            return -1; -        } -    } - -    if (session_recv(recv_buf, sizeof(recv_buf), &s) < 0) { -        fprintf(stderr, "Failed to recv data from server!\n"); -        return -1; -    } - -    printf("%s\n", recv_buf); -    session_close(&s); -    return 0; -} diff --git a/lib/crypto/aes.c b/lib/crypto/aes.c index c51c594..ee5aeb4 100644 --- a/lib/crypto/aes.c +++ b/lib/crypto/aes.c @@ -31,7 +31,7 @@  #include <openssl/evp.h>  #include <openssl/aes.h>  #include <openssl/rand.h> -#include <crypto/aes.h> +#include <ostp/crypto/aes.h>  #include <stdio.h>  #include <string.h> diff --git a/lib/crypto/ecdh.c b/lib/crypto/ecdh.c index c881ca1..70aee12 100644 --- a/lib/crypto/ecdh.c +++ b/lib/crypto/ecdh.c @@ -33,7 +33,7 @@  #include <openssl/pem.h>  #include <openssl/bn.h>  #include <openssl/err.h> -#include <crypto/ecdh.h> +#include <ostp/crypto/ecdh.h>  #include <stdio.h>  #define KEY_SIZE 32 diff --git a/lib/include/net/auth.h b/lib/include/net/auth.h index 0f22d22..f3f47d1 100644 --- a/lib/include/net/auth.h +++ b/lib/include/net/auth.h @@ -30,9 +30,9 @@  #ifndef NET_AUTH_H_  #define NET_AUTH_H_ -#include <net/stpsession.h> -#include <libostp/session.h> -#include <libostp/server.h> +#include <ostp/net/stpsession.h> +#include <ostp/session.h> +#include <ostp/server.h>  int handle_srq(struct ostp_client *c, struct ostp_listener *lp,      struct session_request *srq); diff --git a/lib/include/net/param.h b/lib/include/net/param.h index ba2a0a2..03282c1 100644 --- a/lib/include/net/param.h +++ b/lib/include/net/param.h @@ -30,8 +30,8 @@  #ifndef NET_PARAM_H_  #define NET_PARAM_H_ +#include <ostp/defs.h>  #include <stdint.h> -#include <defs.h>  /*   * The Parameter Arbitration Packet which is crucial diff --git a/lib/include/net/stpsession.h b/lib/include/net/stpsession.h index 8b61da2..7f9d151 100644 --- a/lib/include/net/stpsession.h +++ b/lib/include/net/stpsession.h @@ -30,9 +30,9 @@  #ifndef STP_SESSION_H_  #define STP_SESSION_H_ -#include <crypto/aes.h> +#include <ostp/crypto/aes.h> +#include <ostp/defs.h>  #include <stdint.h> -#include <defs.h>  /*   * 2^12 (4096) bytes is a common page size on diff --git a/lib/include/libostp/server.h b/lib/include/server.h index 0e232f6..9e09f78 100644 --- a/lib/include/libostp/server.h +++ b/lib/include/server.h @@ -31,7 +31,7 @@  #define LIBOSTP_SERVER_H_  #include <sys/select.h> -#include <libostp/session.h> +#include <ostp/session.h>  #include <pthread.h>  #include <stddef.h> @@ -44,7 +44,7 @@ struct ostp_client {  };  struct ostp_listener { -    int(*on_recv)(struct ostp_client *c, const char *buf, size_t len); +    int(*on_recv)(struct ostp_client *c, const void *buf, size_t len);      int port;      /* -- Private -- */ diff --git a/lib/include/libostp/session.h b/lib/include/session.h index 397fa68..397fa68 100644 --- a/lib/include/libostp/session.h +++ b/lib/include/session.h diff --git a/lib/libostp/auth.c b/lib/libostp/auth.c index f2097bc..7b840f6 100644 --- a/lib/libostp/auth.c +++ b/lib/libostp/auth.c @@ -28,9 +28,9 @@   */  #include <sys/wait.h> -#include <net/auth.h> -#include <crypto/ecdh.h> -#include <otconfig.h> +#include <ostp/net/auth.h> +#include <ostp/crypto/ecdh.h> +#include <ostp/otconfig.h>  #include <arpa/inet.h>  #include <stdio.h>  #include <unistd.h> diff --git a/lib/libostp/param.c b/lib/libostp/param.c index 8b83f46..83978d9 100644 --- a/lib/libostp/param.c +++ b/lib/libostp/param.c @@ -27,12 +27,12 @@   * POSSIBILITY OF SUCH DAMAGE.   */ -#include <net/stpsession.h> -#include <libostp/session.h> -#include <crypto/aes.h> -#include <net/param.h> -#include <net/auth.h> -#include <otconfig.h> +#include <ostp/net/stpsession.h> +#include <ostp/net/param.h> +#include <ostp/net/auth.h> +#include <ostp/session.h> +#include <ostp/crypto/aes.h> +#include <ostp/otconfig.h>  #include <stdio.h>  static int diff --git a/lib/libostp/server.c b/lib/libostp/server.c index 588a6d2..aea987c 100644 --- a/lib/libostp/server.c +++ b/lib/libostp/server.c @@ -27,10 +27,10 @@   * POSSIBILITY OF SUCH DAMAGE.   */ -#include <libostp/server.h> -#include <net/auth.h> -#include <net/stpsession.h> +#include <ostp/net/auth.h> +#include <ostp/net/stpsession.h>  #include <arpa/inet.h> +#include <ostp/server.h>  #include <string.h>  #include <stdlib.h>  #include <unistd.h> diff --git a/lib/libostp/session.c b/lib/libostp/session.c index 39acba2..8f2fb28 100644 --- a/lib/libostp/session.c +++ b/lib/libostp/session.c @@ -27,12 +27,12 @@   * POSSIBILITY OF SUCH DAMAGE.   */ -#include <libostp/session.h> -#include <net/stpsession.h> -#include <net/param.h> -#include <crypto/ecdh.h> -#include <defs.h> -#include <otconfig.h> +#include <ostp/net/stpsession.h> +#include <ostp/net/param.h> +#include <ostp/crypto/ecdh.h> +#include <ostp/defs.h> +#include <ostp/session.h> +#include <ostp/otconfig.h>  #include <arpa/inet.h>  #include <termios.h>  #include <stdint.h> diff --git a/lib/net/frame.c b/lib/net/frame.c index 1f33b09..7363266 100644 --- a/lib/net/frame.c +++ b/lib/net/frame.c @@ -27,8 +27,8 @@   * POSSIBILITY OF SUCH DAMAGE.   */ -#include <net/stpsession.h> -#include <crypto/aes.h> +#include <ostp/net/stpsession.h> +#include <ostp/crypto/aes.h>  #include <arpa/inet.h>  #include <string.h>  #include <stdlib.h> diff --git a/ostp.d/init/main.c b/ostp.d/init/main.c deleted file mode 100644 index 9b2a836..0000000 --- a/ostp.d/init/main.c +++ /dev/null @@ -1,59 +0,0 @@ -/* - * Copyright (c) 2023-2024 Ian Marco Moffett and the Osmora Team. - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions are met: - * - * 1. Redistributions of source code must retain the above copyright notice, - *    this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - *    notice, this list of conditions and the following disclaimer in the - *    documentation and/or other materials provided with the distribution. - * 3. Neither the name of Hyra nor the names of its - *    contributors may be used to endorse or promote products derived from - *    this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE - * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR - * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF - * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS - * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN - * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) - * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE - * POSSIBILITY OF SUCH DAMAGE. - */ - -#include <libostp/session.h> -#include <libostp/server.h> -#include <string.h> -#include <stdio.h> - -static int -handle_data(struct ostp_client *s, const char *buf, size_t len) -{ -    printf("Got data!\n"); -    return 0; -} - -int -main(void) -{ -    struct ostp_listener l; -    int error; - -    listener_init(&l); -    l.on_recv = handle_data; - -    if ((error = listener_bind(&l)) < 0) { -        return error; -    } -    if ((error = listener_poll(&l)) < 0) { -        return error; -    } - -    return 0; -} | 
