From 9b50f08c3995c2215420bba8eca029b14514dfac Mon Sep 17 00:00:00 2001 From: Ian Moffett Date: Tue, 1 Oct 2024 00:24:54 -0400 Subject: project: Convert project to library Signed-off-by: Ian Moffett --- .gitignore | 2 +- Makefile | 29 +++++++++-------- client/main.c | 64 ------------------------------------- lib/crypto/aes.c | 2 +- lib/crypto/ecdh.c | 2 +- lib/include/libostp/server.h | 63 ------------------------------------- lib/include/libostp/session.h | 73 ------------------------------------------- lib/include/net/auth.h | 6 ++-- lib/include/net/param.h | 2 +- lib/include/net/stpsession.h | 4 +-- lib/include/server.h | 63 +++++++++++++++++++++++++++++++++++++ lib/include/session.h | 73 +++++++++++++++++++++++++++++++++++++++++++ lib/libostp/auth.c | 6 ++-- lib/libostp/param.c | 12 +++---- lib/libostp/server.c | 6 ++-- lib/libostp/session.c | 12 +++---- lib/net/frame.c | 4 +-- ostp.d/init/main.c | 59 ---------------------------------- 18 files changed, 179 insertions(+), 303 deletions(-) delete mode 100644 client/main.c delete mode 100644 lib/include/libostp/server.h delete mode 100644 lib/include/libostp/session.h create mode 100644 lib/include/server.h create mode 100644 lib/include/session.h delete mode 100644 ostp.d/init/main.c diff --git a/.gitignore b/.gitignore index 88e66e2..b5cdb72 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,3 @@ -so/ bin/ *.o +*.so diff --git a/Makefile b/Makefile index af6d185..c287b3c 100644 --- a/Makefile +++ b/Makefile @@ -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 -#include - -#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 #include #include -#include +#include #include #include 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 #include #include -#include +#include #include #define KEY_SIZE 32 diff --git a/lib/include/libostp/server.h b/lib/include/libostp/server.h deleted file mode 100644 index 0e232f6..0000000 --- a/lib/include/libostp/server.h +++ /dev/null @@ -1,63 +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. - */ - -#ifndef LIBOSTP_SERVER_H_ -#define LIBOSTP_SERVER_H_ - -#include -#include -#include -#include - -#define MAX_CLIENTS 32 - -struct ostp_client { - struct ostp_session session; - int sockfd; - pthread_t td; -}; - -struct ostp_listener { - int(*on_recv)(struct ostp_client *c, const char *buf, size_t len); - int port; - - /* -- Private -- */ - struct ostp_client clients[MAX_CLIENTS]; - size_t client_count; - int serv_sockfd; - fd_set client_fds; -}; - -void listener_init(struct ostp_listener *lp); -int listener_bind(struct ostp_listener *lp); -int listener_poll(struct ostp_listener *lp); -void listener_cleanup(struct ostp_listener *lp); -void listener_close(struct ostp_listener *lp, struct ostp_client *c); - -#endif /* !LIBOSTP_SERVER_H_ */ diff --git a/lib/include/libostp/session.h b/lib/include/libostp/session.h deleted file mode 100644 index 397fa68..0000000 --- a/lib/include/libostp/session.h +++ /dev/null @@ -1,73 +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. - */ - -#ifndef LIBOSTP_SESSION_H_ -#define LIBOSTP_SESSION_H_ - -#include - -struct ostp_session { - unsigned char *session_key; - int sockfd; -}; - -/* - * Create a new ostp ostp_session. - * - * @host: IPv4 address of OST host. - * @res: Output for new ostp_session structure. - */ -int session_new(const char *host, struct ostp_session *res); - -/* - * Close an existing/running ostp_session. - * - * @ostp_session: Session to close. - */ -int session_close(struct ostp_session *session); - -/* - * Encrypt and send data to server. - * - * @data: Data to send. - * @len: Length of data. - * @ostp_session: Running ostp_session. - */ -int session_send(void *data, uint16_t len, const struct ostp_session *session); - -/* - * Receive data from the server. - * - * @buf: Buffer for received data. - * @len: Length of buffer. - * @ostp_session: Running ostp_session. - */ -int session_recv(void *buf, uint16_t len, const struct ostp_session *session); - -#endif /* LIBOSTP_SESSION_H_ */ 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 -#include -#include +#include +#include +#include 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 #include -#include /* * 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 +#include +#include #include -#include /* * 2^12 (4096) bytes is a common page size on diff --git a/lib/include/server.h b/lib/include/server.h new file mode 100644 index 0000000..9e09f78 --- /dev/null +++ b/lib/include/server.h @@ -0,0 +1,63 @@ +/* + * 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. + */ + +#ifndef LIBOSTP_SERVER_H_ +#define LIBOSTP_SERVER_H_ + +#include +#include +#include +#include + +#define MAX_CLIENTS 32 + +struct ostp_client { + struct ostp_session session; + int sockfd; + pthread_t td; +}; + +struct ostp_listener { + int(*on_recv)(struct ostp_client *c, const void *buf, size_t len); + int port; + + /* -- Private -- */ + struct ostp_client clients[MAX_CLIENTS]; + size_t client_count; + int serv_sockfd; + fd_set client_fds; +}; + +void listener_init(struct ostp_listener *lp); +int listener_bind(struct ostp_listener *lp); +int listener_poll(struct ostp_listener *lp); +void listener_cleanup(struct ostp_listener *lp); +void listener_close(struct ostp_listener *lp, struct ostp_client *c); + +#endif /* !LIBOSTP_SERVER_H_ */ diff --git a/lib/include/session.h b/lib/include/session.h new file mode 100644 index 0000000..397fa68 --- /dev/null +++ b/lib/include/session.h @@ -0,0 +1,73 @@ +/* + * 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. + */ + +#ifndef LIBOSTP_SESSION_H_ +#define LIBOSTP_SESSION_H_ + +#include + +struct ostp_session { + unsigned char *session_key; + int sockfd; +}; + +/* + * Create a new ostp ostp_session. + * + * @host: IPv4 address of OST host. + * @res: Output for new ostp_session structure. + */ +int session_new(const char *host, struct ostp_session *res); + +/* + * Close an existing/running ostp_session. + * + * @ostp_session: Session to close. + */ +int session_close(struct ostp_session *session); + +/* + * Encrypt and send data to server. + * + * @data: Data to send. + * @len: Length of data. + * @ostp_session: Running ostp_session. + */ +int session_send(void *data, uint16_t len, const struct ostp_session *session); + +/* + * Receive data from the server. + * + * @buf: Buffer for received data. + * @len: Length of buffer. + * @ostp_session: Running ostp_session. + */ +int session_recv(void *buf, uint16_t len, const struct ostp_session *session); + +#endif /* LIBOSTP_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 -#include -#include -#include +#include +#include +#include #include #include #include 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 -#include -#include -#include -#include -#include +#include +#include +#include +#include +#include +#include #include 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 -#include -#include +#include +#include #include +#include #include #include #include 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 -#include -#include -#include -#include -#include +#include +#include +#include +#include +#include +#include #include #include #include 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 -#include +#include +#include #include #include #include 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 -#include -#include -#include - -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; -} -- cgit v1.2.3