]> andersk Git - moira.git/blobdiff - server/qvalidate.pc
Don't complain for quota deltas < 400MB.
[moira.git] / server / qvalidate.pc
index 83b6fb17d11c53d3d0d2018c49efb8680b25ddc1..f84b15da236910831d90289bac96dcbdb12137ed 100644 (file)
@@ -206,8 +206,9 @@ int validate_id(struct query *q, char *argv[], struct valobj *vo)
   else if (status == MR_NO_MATCH && tbl == STRINGS_TABLE &&
           (q->type == APPEND || q->type == UPDATE))
     {
+      if (strlen(name) >= STRINGS_STRING_SIZE)
+       return MR_ARG_TOO_LONG;
       id = add_string(name);
-      cache_entry(name, STRINGS_TABLE, id);
       *(int *)argv[vo->index] = id;
       return MR_EXISTS;
     }
@@ -373,7 +374,7 @@ int validate_typedata(struct query *q, char *argv[], struct valobj *vo)
           * that we're trying to resolve, we should get the value of
           * numvalues.[idfield] for the id.
           */
-         if (vo->idfield && !strcmp(argv[0], argv[vo->index]))
+         if (vo->idfield && (*(int *)argv[0] == *(int *)argv[vo->index]))
            {
              set_next_object_id(q->validate->object_id, q->rtable, 0);
              name = vo->idfield;
@@ -412,13 +413,14 @@ int validate_typedata(struct query *q, char *argv[], struct valobj *vo)
        {
          if (q->type != APPEND && q->type != UPDATE)
            return MR_STRING;
+         if (strlen(name) >= STRINGS_STRING_SIZE)
+           return MR_ARG_TOO_LONG;
          id = add_string(name);
-         cache_entry(name, STRINGS_TABLE, id);
        }
       else if (status)
        return status;
     }
-  else if (!strcmp(data_type, "none"))
+  else if (!strcmp(data_type, "none") || !strcmp(data_type, "all"))
     id = 0;
   else
     return MR_TYPE;
@@ -463,6 +465,9 @@ int validate_num(char *argv[], struct valobj *vo)
 
   if (*p == '-')
     p++;
+  if (!*p)
+    return MR_INTEGER;
+
   for (; *p; p++)
     {
       if (*p < '0' || *p > '9')
This page took 0.262509 seconds and 4 git commands to generate.