add temporary directory
authorLaurent Mazet <laurent.mazet@thalesgroup.com>
Fri, 2 Jun 2023 13:31:08 +0000 (15:31 +0200)
committerLaurent Mazet <laurent.mazet@thalesgroup.com>
Fri, 2 Jun 2023 13:31:08 +0000 (15:31 +0200)
file.c
file.h
http.h
webserver.c

diff --git a/file.c b/file.c
index 47f91a7c8b21b647844bd8a378bfbcb271e103c7..472ab4252a16e5b9d719733c3295155fbb9f3972 100644 (file)
--- a/file.c
+++ b/file.c
@@ -1,11 +1,14 @@
 #include <malloc.h>
 #include <stdio.h>
 #include <stdlib.h>
+#include <string.h>
 
 #include "debug.h"
 
 #include "file.h"
 
+#define TLEN 8
+
 /* read full file */
 
 int readfile (char **buffer, char *filename)
@@ -36,4 +39,21 @@ int readfile (char **buffer, char *filename)
     return size;
 }
 
+/* temp name */
+
+char *tempname (char *tempdir)
+{
+    char table[65] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz-_";
+
+    unsigned int len = strlen (tempdir) + 1 + 4 + TLEN + 1;
+    char *name = (char *) calloc (len, 1);
+
+    sprintf (name, "%s/tmp-", tempdir);
+    while (strlen (name) + 1 < len) {
+        name[strlen (name)] = table[rand () % 64];
+    }
+
+    return name;
+}
+
 /* vim: set ts=4 sw=4 et: */
diff --git a/file.h b/file.h
index c6edd0d00ec5498aedee535d66609d08f69b6217..106f881e09d891e34eeab286a6bb3e77f5c4a420 100644 (file)
--- a/file.h
+++ b/file.h
@@ -3,6 +3,8 @@
 
 int readfile (char **buffer, char *filename);
 
+char *tempname (char *tempdir);
+
 #endif /* __FILE_H__ */
 
 /* vim: set ts=4 sw=4 et: */
diff --git a/http.h b/http.h
index d25fa692de118510cf1438b9224c6ba50d257fb3..193698ea5ebbec3dd072b262511f7fcb0dd53d3b 100644 (file)
--- a/http.h
+++ b/http.h
@@ -5,6 +5,7 @@
 
 typedef struct {
     char *root;
+    char *temp;
     char *servername;
     char *charset;
 } conf_t;
index 2f5422771c8379dc5e06cb09243541979a5722d5..bca0262579bdec1c6ffa686ed7b9d08331f38f28 100644 (file)
@@ -6,9 +6,11 @@
 #include <dirent.h>
 #include <stdio.h>
 #include <stdlib.h>
+#include <time.h>
 #include <unistd.h>
 
 #include "debug.h"
+#include "file.h"
 #include "http.h"
 #include "server.h"
 
@@ -18,6 +20,7 @@
 
 #define BUFFER_SIZE 4096
 #define ROOT_DIR "webroot"
+#define TEMP_DIR "tmp"
 #define SERVER_NAME "localhost"
 #define CHARSET "iso-8859-1"
 
@@ -28,6 +31,7 @@
 char *progname = NULL;
 int port = 8080;
 char *root = ROOT_DIR;
+char *temp = TEMP_DIR;
 char *servername = SERVER_NAME;
 char *charset = CHARSET;
 
@@ -42,6 +46,7 @@ int usage (int ret)
     fprintf (fid, " -p : port number (%d)\n", port);
     fprintf (fid, " -r : web root directory (%s)\n", root);
     fprintf (fid, " -s : server name (%s)\n", servername);
+    fprintf (fid, " -t : temporay directory (%s)\n", temp);
     fprintf (fid, " -v : verbose level (%d)\n", verbose);
 
     return ret;
@@ -95,6 +100,14 @@ int main (int argc, char *argv[])
                 return 1;
             }
             break;
+        case 'r':
+            arg = (arg[2]) ? arg + 2 : (--argc > 0) ? *(++argv) : NULL;
+            if (arg == NULL) {
+                VERBOSE (ERROR, PERROR ("%s: missing directory name\n", progname); usage (1));
+                return 1;
+            }
+            root = arg;
+            break;
         case 's':
             arg = (arg[2]) ? arg + 2 : (--argc > 0) ? *(++argv) : NULL;
             if (arg == NULL) {
@@ -103,13 +116,13 @@ int main (int argc, char *argv[])
             }
             servername = arg;
             break;
-        case 'r':
+        case 't':
             arg = (arg[2]) ? arg + 2 : (--argc > 0) ? *(++argv) : NULL;
             if (arg == NULL) {
                 VERBOSE (ERROR, PERROR ("%s: missing directory name\n", progname); usage (1));
                 return 1;
             }
-            root = arg;
+            temp = arg;
             break;
         case 'v':
             arg = (arg[2]) ? arg + 2 : (--argc > 0) ? *(++argv) : NULL;
@@ -125,17 +138,37 @@ int main (int argc, char *argv[])
         }
     }
 
+    /* init seed */
+    srand (time (NULL));
+
     /* check root directory */
     VERBOSE (DEBUG, PRINT ("Check web root\n"));
-    DIR *pdir = opendir (root);
-    if (pdir == NULL) {
+    DIR *prootdir = opendir (root);
+    if (prootdir == NULL) {
         VERBOSE (ERROR, PERROR ("Can't read directory (%s)\n", root));
         return 1;
     }
-    closedir (pdir);
+    closedir (prootdir);
+
+    /* check temp directory */
+    VERBOSE (DEBUG, PRINT ("Check temp dirweb root\n"));
+    DIR *ptempdir = opendir (temp);
+    if (ptempdir == NULL) {
+        VERBOSE (ERROR, PERROR ("Can't read directory (%s)\n", temp));
+        return 1;
+    }
+    char *ntemp = tempname (temp);
+    FILE *ftemp = fopen (ntemp, "w");
+    if (ftemp == NULL) {
+        VERBOSE (ERROR, PERROR ("Can't write temporary file (%s)\n", ntemp));
+        return 1;
+    }
+    fclose (ftemp);
+    unlink (ntemp);
+    free (ntemp);
 
     /* configuration */
-    conf_t conf = {root, servername, charset};
+    conf_t conf = {root, temp, servername, charset};
 
     /* init network stack */
     VERBOSE (DEBUG, PRINT ("Initializing socket\n"));