summaryrefslogtreecommitdiff
path: root/admin.c
diff options
context:
space:
mode:
Diffstat (limited to 'admin.c')
-rw-r--r--admin.c30
1 files changed, 26 insertions, 4 deletions
diff --git a/admin.c b/admin.c
index 3ba9464..a334f3b 100644
--- a/admin.c
+++ b/admin.c
@@ -17,9 +17,31 @@ icclient_admin *icclient_admin_login(const char *username, const char *password,
return admin;
}
-void icclient_admin_newitem(const char *description, const char *comment, const char *price, const char *image_path)
+void icclient_admin_new_admin(const char *username, const char *password, const char *name, bool super,
+ enum icclient_admin_group group, void (*handler)(icclient_fetch_t *))
{
- request(NULL, NULL, &(struct body){ 15, {
+ request(handler, NULL, &(struct body){ 13, {
+ { "mv_todo", "set" },
+ { "mv_data_table", "access" },
+ { "mv_data_key", "username" },
+ { "mv_update_empty", "1" },
+ { "mv_data_fields", "username password name super groups" },
+ { "mv_click", "process_filter" },
+ { "user_id", "NEW" },
+ { "name", name },
+ { "mv_data_function", "insert" },
+ { "username", username },
+ { "password", password },
+ { "super", super ? "1" : "0" },
+ { "groups", group == ICCLIENT_ADMIN_GROUP_CONTENT ? ":CONTENT"
+ : group == ICCLIENT_ADMIN_GROUP_MERCH ? ":MERCH" : ":ORDERS" }
+ }}, "%s", "ui");
+}
+
+void icclient_admin_new_item(const char *description, const char *comment, const char *price, const char *image_path,
+ void (*handler)(icclient_fetch_t *))
+{
+ request(handler, NULL, &(struct body){ 15, {
{ "mv_click", "process_filter" },
{ "mv_data_fields", "sku description prod_group category comment inactive price wholesale image thumb image_large weight nontaxable gift_cert" },
{ "mv_ui", "1" },
@@ -45,9 +67,9 @@ void icclient_admin_newitem(const char *description, const char *comment, const
}}, "%s", "admin/item_edit");
}
-void icclient_admin_logout(icclient_admin *admin)
+void icclient_admin_logout(icclient_admin *admin, void (*handler)(icclient_fetch_t *))
{
- request(NULL, NULL, NULL, "%s", "admin/login");
+ request(handler, NULL, NULL, "%s", "admin/login");
if (admin->name)
free(admin->name);
if (admin->username)