-<?xml version="1.0" standalone="no"?> <!--*- mode: xml -*-->
-<!DOCTYPE glade-interface SYSTEM "http://glade.gnome.org/glade-2.0.dtd">
-
-<glade-interface>
-
-<widget class="GtkDialog" id="diag_main">
- <property name="visible">True</property>
- <property name="title" translatable="yes">Autenticazione</property>
- <property name="type">GTK_WINDOW_TOPLEVEL</property>
- <property name="window_position">GTK_WIN_POS_NONE</property>
- <property name="modal">True</property>
- <property name="resizable">True</property>
- <property name="destroy_with_parent">False</property>
- <property name="decorated">True</property>
- <property name="skip_taskbar_hint">False</property>
- <property name="skip_pager_hint">False</property>
- <property name="type_hint">GDK_WINDOW_TYPE_HINT_DIALOG</property>
- <property name="gravity">GDK_GRAVITY_NORTH_WEST</property>
- <property name="focus_on_map">True</property>
- <property name="urgency_hint">False</property>
- <property name="has_separator">True</property>
-
- <child internal-child="vbox">
- <widget class="GtkVBox" id="dialog-vbox1">
- <property name="visible">True</property>
- <property name="homogeneous">False</property>
- <property name="spacing">0</property>
-
- <child internal-child="action_area">
- <widget class="GtkHButtonBox" id="dialog-action_area1">
- <property name="visible">True</property>
- <property name="layout_style">GTK_BUTTONBOX_END</property>
-
- <child>
- <widget class="GtkButton" id="cancelbutton1">
- <property name="visible">True</property>
- <property name="can_default">True</property>
- <property name="can_focus">True</property>
- <property name="label">gtk-cancel</property>
- <property name="use_stock">True</property>
- <property name="relief">GTK_RELIEF_NORMAL</property>
- <property name="focus_on_click">True</property>
- <property name="response_id">-6</property>
- </widget>
- </child>
-
- <child>
- <widget class="GtkButton" id="okbutton1">
- <property name="visible">True</property>
- <property name="can_default">True</property>
- <property name="has_default">True</property>
- <property name="can_focus">True</property>
- <property name="label">gtk-ok</property>
- <property name="use_stock">True</property>
- <property name="relief">GTK_RELIEF_NORMAL</property>
- <property name="focus_on_click">True</property>
- <property name="response_id">-5</property>
- </widget>
- </child>
- </widget>
- <packing>
- <property name="padding">0</property>
- <property name="expand">False</property>
- <property name="fill">True</property>
- <property name="pack_type">GTK_PACK_END</property>
- </packing>
- </child>
-
- <child>
- <widget class="GtkTable" id="table1">
- <property name="border_width">5</property>
- <property name="visible">True</property>
- <property name="n_rows">3</property>
- <property name="n_columns">2</property>
- <property name="homogeneous">False</property>
- <property name="row_spacing">3</property>
- <property name="column_spacing">3</property>
-
- <child>
- <widget class="GtkLabel" id="label1">
- <property name="visible">True</property>
- <property name="label" translatable="yes">Utente</property>
- <property name="use_underline">False</property>
- <property name="use_markup">False</property>
- <property name="justify">GTK_JUSTIFY_LEFT</property>
- <property name="wrap">False</property>
- <property name="selectable">False</property>
- <property name="xalign">0</property>
- <property name="yalign">0.5</property>
- <property name="xpad">0</property>
- <property name="ypad">0</property>
- <property name="ellipsize">PANGO_ELLIPSIZE_NONE</property>
- <property name="width_chars">-1</property>
- <property name="single_line_mode">False</property>
- <property name="angle">0</property>
- </widget>
- <packing>
- <property name="left_attach">0</property>
- <property name="right_attach">1</property>
- <property name="top_attach">0</property>
- <property name="bottom_attach">1</property>
- <property name="x_options">fill</property>
- <property name="y_options"></property>
- </packing>
- </child>
-
- <child>
- <widget class="GtkLabel" id="label2">
- <property name="visible">True</property>
- <property name="label" translatable="yes">Password</property>
- <property name="use_underline">False</property>
- <property name="use_markup">False</property>
- <property name="justify">GTK_JUSTIFY_LEFT</property>
- <property name="wrap">False</property>
- <property name="selectable">False</property>
- <property name="xalign">0</property>
- <property name="yalign">0.5</property>
- <property name="xpad">0</property>
- <property name="ypad">0</property>
- <property name="ellipsize">PANGO_ELLIPSIZE_NONE</property>
- <property name="width_chars">-1</property>
- <property name="single_line_mode">False</property>
- <property name="angle">0</property>
- </widget>
- <packing>
- <property name="left_attach">0</property>
- <property name="right_attach">1</property>
- <property name="top_attach">1</property>
- <property name="bottom_attach">2</property>
- <property name="x_options">fill</property>
- <property name="y_options"></property>
- </packing>
- </child>
-
- <child>
- <widget class="GtkEntry" id="txt_utente">
- <property name="visible">True</property>
- <property name="can_focus">True</property>
- <property name="editable">True</property>
- <property name="visibility">True</property>
- <property name="max_length">0</property>
- <property name="text" translatable="yes"></property>
- <property name="has_frame">True</property>
- <property name="invisible_char">*</property>
- <property name="activates_default">True</property>
- </widget>
- <packing>
- <property name="left_attach">1</property>
- <property name="right_attach">2</property>
- <property name="top_attach">0</property>
- <property name="bottom_attach">1</property>
- <property name="y_options"></property>
- </packing>
- </child>
-
- <child>
- <widget class="GtkEntry" id="txt_password">
- <property name="visible">True</property>
- <property name="can_focus">True</property>
- <property name="editable">True</property>
- <property name="visibility">False</property>
- <property name="max_length">0</property>
- <property name="text" translatable="yes"></property>
- <property name="has_frame">True</property>
- <property name="invisible_char">*</property>
- <property name="activates_default">True</property>
- </widget>
- <packing>
- <property name="left_attach">1</property>
- <property name="right_attach">2</property>
- <property name="top_attach">1</property>
- <property name="bottom_attach">2</property>
- <property name="y_options"></property>
- </packing>
- </child>
-
- <child>
- <widget class="GtkExpander" id="exp_cambio">
- <property name="visible">True</property>
- <property name="can_focus">True</property>
- <property name="expanded">False</property>
- <property name="spacing">0</property>
-
- <child>
- <widget class="GtkTable" id="table2">
- <property name="border_width">5</property>
- <property name="visible">True</property>
- <property name="n_rows">2</property>
- <property name="n_columns">2</property>
- <property name="homogeneous">False</property>
- <property name="row_spacing">3</property>
- <property name="column_spacing">3</property>
-
- <child>
- <widget class="GtkLabel" id="label4">
- <property name="visible">True</property>
- <property name="label" translatable="yes">Nuova</property>
- <property name="use_underline">False</property>
- <property name="use_markup">False</property>
- <property name="justify">GTK_JUSTIFY_LEFT</property>
- <property name="wrap">False</property>
- <property name="selectable">False</property>
- <property name="xalign">0</property>
- <property name="yalign">0.5</property>
- <property name="xpad">0</property>
- <property name="ypad">0</property>
- <property name="ellipsize">PANGO_ELLIPSIZE_NONE</property>
- <property name="width_chars">-1</property>
- <property name="single_line_mode">False</property>
- <property name="angle">0</property>
- </widget>
- <packing>
- <property name="left_attach">0</property>
- <property name="right_attach">1</property>
- <property name="top_attach">0</property>
- <property name="bottom_attach">1</property>
- <property name="x_options">fill</property>
- <property name="y_options"></property>
- </packing>
- </child>
-
- <child>
- <widget class="GtkLabel" id="label5">
- <property name="visible">True</property>
- <property name="label" translatable="yes">Conferma</property>
- <property name="use_underline">False</property>
- <property name="use_markup">False</property>
- <property name="justify">GTK_JUSTIFY_LEFT</property>
- <property name="wrap">False</property>
- <property name="selectable">False</property>
- <property name="xalign">0</property>
- <property name="yalign">0.5</property>
- <property name="xpad">0</property>
- <property name="ypad">0</property>
- <property name="ellipsize">PANGO_ELLIPSIZE_NONE</property>
- <property name="width_chars">-1</property>
- <property name="single_line_mode">False</property>
- <property name="angle">0</property>
- </widget>
- <packing>
- <property name="left_attach">0</property>
- <property name="right_attach">1</property>
- <property name="top_attach">1</property>
- <property name="bottom_attach">2</property>
- <property name="x_options">fill</property>
- <property name="y_options"></property>
- </packing>
- </child>
-
- <child>
- <widget class="GtkEntry" id="txt_password_nuova">
- <property name="visible">True</property>
- <property name="can_focus">True</property>
- <property name="editable">True</property>
- <property name="visibility">False</property>
- <property name="max_length">0</property>
- <property name="text" translatable="yes"></property>
- <property name="has_frame">True</property>
- <property name="invisible_char">*</property>
- <property name="activates_default">True</property>
- </widget>
- <packing>
- <property name="left_attach">1</property>
- <property name="right_attach">2</property>
- <property name="top_attach">0</property>
- <property name="bottom_attach">1</property>
- <property name="y_options"></property>
- </packing>
- </child>
-
- <child>
- <widget class="GtkEntry" id="txt_password_conferma">
- <property name="visible">True</property>
- <property name="can_focus">True</property>
- <property name="editable">True</property>
- <property name="visibility">False</property>
- <property name="max_length">0</property>
- <property name="text" translatable="yes"></property>
- <property name="has_frame">True</property>
- <property name="invisible_char">*</property>
- <property name="activates_default">True</property>
- </widget>
- <packing>
- <property name="left_attach">1</property>
- <property name="right_attach">2</property>
- <property name="top_attach">1</property>
- <property name="bottom_attach">2</property>
- <property name="y_options"></property>
- </packing>
- </child>
- </widget>
- </child>
-
- <child>
- <widget class="GtkLabel" id="label3">
- <property name="visible">True</property>
- <property name="label" translatable="yes">_Cambia password</property>
- <property name="use_underline">True</property>
- <property name="use_markup">False</property>
- <property name="justify">GTK_JUSTIFY_LEFT</property>
- <property name="wrap">False</property>
- <property name="selectable">False</property>
- <property name="xalign">0.5</property>
- <property name="yalign">0.5</property>
- <property name="xpad">0</property>
- <property name="ypad">0</property>
- <property name="ellipsize">PANGO_ELLIPSIZE_NONE</property>
- <property name="width_chars">-1</property>
- <property name="single_line_mode">False</property>
- <property name="angle">0</property>
- </widget>
- <packing>
- <property name="type">label_item</property>
- </packing>
- </child>
- </widget>
- <packing>
- <property name="left_attach">0</property>
- <property name="right_attach">2</property>
- <property name="top_attach">2</property>
- <property name="bottom_attach">3</property>
- <property name="x_options">fill</property>
- </packing>
- </child>
- </widget>
- <packing>
- <property name="padding">0</property>
- <property name="expand">True</property>
- <property name="fill">True</property>
- </packing>
- </child>
- </widget>
- </child>
-</widget>
-
-</glade-interface>
+<?xml version="1.0"?>
+<interface>
+ <!-- interface-requires gtk+ 2.6 -->
+ <!-- interface-naming-policy project-wide -->
+ <object class="GtkDialog" id="diag_main">
+ <property name="visible">True</property>
+ <property name="title" translatable="yes">Autenticazione</property>
+ <property name="modal">True</property>
+ <property name="type_hint">dialog</property>
+ <child internal-child="vbox">
+ <object class="GtkVBox" id="dialog-vbox1">
+ <property name="visible">True</property>
+ <child>
+ <object class="GtkTable" id="table1">
+ <property name="visible">True</property>
+ <property name="border_width">5</property>
+ <property name="n_rows">3</property>
+ <property name="n_columns">2</property>
+ <property name="column_spacing">3</property>
+ <property name="row_spacing">3</property>
+ <child>
+ <object class="GtkLabel" id="label1">
+ <property name="visible">True</property>
+ <property name="xalign">0</property>
+ <property name="label" translatable="yes">Utente</property>
+ </object>
+ <packing>
+ <property name="x_options">GTK_FILL</property>
+ <property name="y_options"></property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkLabel" id="label2">
+ <property name="visible">True</property>
+ <property name="xalign">0</property>
+ <property name="label" translatable="yes">Password</property>
+ </object>
+ <packing>
+ <property name="top_attach">1</property>
+ <property name="bottom_attach">2</property>
+ <property name="x_options">GTK_FILL</property>
+ <property name="y_options"></property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkEntry" id="txt_utente">
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="activates_default">True</property>
+ </object>
+ <packing>
+ <property name="left_attach">1</property>
+ <property name="right_attach">2</property>
+ <property name="y_options"></property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkEntry" id="txt_password">
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="visibility">False</property>
+ <property name="activates_default">True</property>
+ </object>
+ <packing>
+ <property name="left_attach">1</property>
+ <property name="right_attach">2</property>
+ <property name="top_attach">1</property>
+ <property name="bottom_attach">2</property>
+ <property name="y_options"></property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkExpander" id="exp_cambio">
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <child>
+ <object class="GtkTable" id="table2">
+ <property name="visible">True</property>
+ <property name="border_width">5</property>
+ <property name="n_rows">2</property>
+ <property name="n_columns">2</property>
+ <property name="column_spacing">3</property>
+ <property name="row_spacing">3</property>
+ <child>
+ <object class="GtkLabel" id="label4">
+ <property name="visible">True</property>
+ <property name="xalign">0</property>
+ <property name="label" translatable="yes">Nuova</property>
+ </object>
+ <packing>
+ <property name="x_options">GTK_FILL</property>
+ <property name="y_options"></property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkLabel" id="label5">
+ <property name="visible">True</property>
+ <property name="xalign">0</property>
+ <property name="label" translatable="yes">Conferma</property>
+ </object>
+ <packing>
+ <property name="top_attach">1</property>
+ <property name="bottom_attach">2</property>
+ <property name="x_options">GTK_FILL</property>
+ <property name="y_options"></property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkEntry" id="txt_password_nuova">
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="visibility">False</property>
+ <property name="activates_default">True</property>
+ </object>
+ <packing>
+ <property name="left_attach">1</property>
+ <property name="right_attach">2</property>
+ <property name="y_options"></property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkEntry" id="txt_password_conferma">
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="visibility">False</property>
+ <property name="activates_default">True</property>
+ </object>
+ <packing>
+ <property name="left_attach">1</property>
+ <property name="right_attach">2</property>
+ <property name="top_attach">1</property>
+ <property name="bottom_attach">2</property>
+ <property name="y_options"></property>
+ </packing>
+ </child>
+ </object>
+ </child>
+ <child type="label">
+ <object class="GtkLabel" id="label3">
+ <property name="visible">True</property>
+ <property name="label" translatable="yes">_Cambia password</property>
+ <property name="use_underline">True</property>
+ </object>
+ </child>
+ </object>
+ <packing>
+ <property name="right_attach">2</property>
+ <property name="top_attach">2</property>
+ <property name="bottom_attach">3</property>
+ <property name="x_options">GTK_FILL</property>
+ </packing>
+ </child>
+ </object>
+ <packing>
+ <property name="position">2</property>
+ </packing>
+ </child>
+ <child internal-child="action_area">
+ <object class="GtkHButtonBox" id="dialog-action_area1">
+ <property name="visible">True</property>
+ <property name="layout_style">end</property>
+ <child>
+ <object class="GtkButton" id="cancelbutton1">
+ <property name="label">gtk-cancel</property>
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="can_default">True</property>
+ <property name="receives_default">False</property>
+ <property name="use_stock">True</property>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="fill">False</property>
+ <property name="position">0</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkButton" id="okbutton1">
+ <property name="label">gtk-ok</property>
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="can_default">True</property>
+ <property name="has_default">True</property>
+ <property name="receives_default">False</property>
+ <property name="use_stock">True</property>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="fill">False</property>
+ <property name="position">1</property>
+ </packing>
+ </child>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="pack_type">end</property>
+ <property name="position">0</property>
+ </packing>
+ </child>
+ </object>
+ </child>
+ <action-widgets>
+ <action-widget response="-6">cancelbutton1</action-widget>
+ <action-widget response="-5">okbutton1</action-widget>
+ </action-widgets>
+ </object>
+</interface>
/*
- * Copyright (C) 2005-2006 Andrea Zagli <azagli@libero.it>
+ * Copyright (C) 2005-2010 Andrea Zagli <azagli@libero.it>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
*/
#include <gtk/gtk.h>
-#include <glade/glade.h>
#include <gcrypt.h>
-#include <libconfi.h>
-#include <libgdaobj.h>
+#include <libgdaex.h>
-static GtkWidget *txt_utente,
- *txt_password,
- *exp_cambio,
- *txt_password_nuova,
- *txt_password_conferma;
+#ifdef HAVE_LIBCONFI
+ #include <libconfi.h>
+#endif
+
+static GtkWidget *txt_utente;
+static GtkWidget *txt_password;
+static GtkWidget *exp_cambio;
+static GtkWidget *txt_password_nuova;
+static GtkWidget *txt_password_conferma;
/* PRIVATE */
+#ifdef HAVE_LIBCONFI
static gboolean
-get_connection_parameters (Confi *confi, gchar **provider_id, gchar **cnc_string)
+get_connection_parameters_from_confi (Confi *confi, gchar **cnc_string)
{
gboolean ret = TRUE;
- *provider_id = confi_path_get_value (confi, "aute/aute-db/db/provider_id");
*cnc_string = confi_path_get_value (confi, "aute/aute-db/db/cnc_string");
- if (*provider_id == NULL || *cnc_string == NULL
- || strcmp (g_strstrip (*provider_id), "") == 0
+ if (*cnc_string == NULL
|| strcmp (g_strstrip (*cnc_string), "") == 0)
{
ret = FALSE;
return ret;
}
+#endif
/**
* cifra_password:
}
static gchar
-*controllo (Confi *confi)
+*controllo (GSList *parameters)
{
gchar *sql;
gchar *utente = "";
gchar *password;
gchar *password_nuova;
- gchar *provider_id;
gchar *cnc_string;
- GdaO *gdao;
+ GdaEx *gdaex;
GdaDataModel *dm;
utente = g_strstrip (g_strdup (gtk_entry_get_text (GTK_ENTRY (txt_utente))));
password = g_strstrip (g_strdup (gtk_entry_get_text (GTK_ENTRY (txt_password))));
+ cnc_string = NULL;
+
+#ifdef HAVE_LIBCONFI
+ /* the first and only parameters must be a Confi object */
/* leggo i parametri di connessione dalla configurazione */
- if (!get_connection_parameters (confi, &provider_id, &cnc_string)) return NULL;
+ if (IS_CONFI (parameters->data))
+ {
+ if (!get_connection_parameters_from_confi (CONFI (parameters->data), &cnc_string))
+ {
+ cnc_string = NULL;
+ }
+ }
+#endif
- /* creo un oggetto GdaO */
- gdao = gdao_new_from_string (NULL, provider_id, cnc_string);
- if (gdao == NULL) return NULL;
+ if (cnc_string == NULL)
+ {
+ GSList *param;
+
+ param = g_slist_next (parameters);
+ if (param != NULL && param->data != NULL)
+ {
+ cnc_string = g_strdup ((gchar *)param->data);
+ cnc_string = g_strstrip (cnc_string);
+ if (g_strcmp0 (cnc_string, "") == 0)
+ {
+ cnc_string = NULL;
+ }
+ }
+ }
+
+ if (cnc_string == NULL)
+ {
+ return NULL;
+ }
+
+ /* creo un oggetto GdaEx */
+ gdaex = gdaex_new_from_string (cnc_string);
+ if (gdaex == NULL) return NULL;
sql = g_strdup_printf ("SELECT codice FROM utenti "
"WHERE codice = '%s' AND "
"password = '%s' AND "
"status <> 'E'",
- gdao_strescape (utente, NULL),
- gdao_strescape (cifra_password (password), NULL));
- dm = gdao_query (gdao, sql);
+ gdaex_strescape (utente, NULL),
+ gdaex_strescape (cifra_password (password), NULL));
+ dm = gdaex_query (gdaex, sql);
if (dm == NULL || gda_data_model_get_n_rows (dm) <= 0)
{
g_warning ("Utente o password non validi.");
return NULL;
}
- utente = g_strstrip (g_strdup (gdao_data_model_get_field_value_stringify_at (dm, 0, "codice")));
+ utente = g_strstrip (g_strdup (gdaex_data_model_get_field_value_stringify_at (dm, 0, "codice")));
if (strcmp (utente, "") != 0
&& gtk_expander_get_expanded (GTK_EXPANDER (exp_cambio)))
sql = g_strdup_printf ("UPDATE utenti "
"SET password = '%s' "
"WHERE codice = '%s'",
- gdao_strescape (cifra_password (password_nuova), NULL),
- gdao_strescape (utente, NULL));
- if (gdao_execute (gdao, sql) == -1)
+ gdaex_strescape (cifra_password (password_nuova), NULL),
+ gdaex_strescape (utente, NULL));
+ if (gdaex_execute (gdao, sql) == -1)
{
/* TO DO */
g_warning ("Errore durante la modifica della password.");
/* PUBLIC */
gchar
-*autentica (Confi *confi)
+*autentica (GSList *parameters)
{
+ GError *error;
gchar *ret = NULL;
- GladeXML *gla_main = glade_xml_new (GLADEDIR "/autedb.glade", NULL, NULL);
- GtkWidget *diag = glade_xml_get_widget (gla_main, "diag_main");
+ error = NULL;
+
+ GtkBuilder *gtkbuilder = gtk_builder_new ();
+ if (!gtk_builder_add_from_file (gtkbuilder, GLADEDIR "/autedb.glade", &error))
+ {
+ return NULL;
+ }
+
+ GtkWidget *diag = GTK_WIDGET (gtk_builder_get_object (gtkbuilder, "diag_main"));
- txt_utente = glade_xml_get_widget (gla_main, "txt_utente");
- txt_password = glade_xml_get_widget (gla_main, "txt_password");
- exp_cambio = glade_xml_get_widget (gla_main, "exp_cambio");
- txt_password_nuova = glade_xml_get_widget (gla_main, "txt_password_nuova");
- txt_password_conferma = glade_xml_get_widget (gla_main, "txt_password_conferma");
+ txt_utente = GTK_WIDGET (gtk_builder_get_object (gtkbuilder, "txt_utente"));
+ txt_password = GTK_WIDGET (gtk_builder_get_object (gtkbuilder, "txt_password"));
+ exp_cambio = GTK_WIDGET (gtk_builder_get_object (gtkbuilder, "exp_cambio"));
+ txt_password_nuova = GTK_WIDGET (gtk_builder_get_object (gtkbuilder, "txt_password_nuova"));
+ txt_password_conferma = GTK_WIDGET (gtk_builder_get_object (gtkbuilder, "txt_password_conferma"));
/* imposto di default l'utente corrente della sessione */
gtk_entry_set_text (GTK_ENTRY (txt_utente), g_get_user_name ());
{
case GTK_RESPONSE_OK:
/* controllo dell'utente e della password */
- ret = controllo (confi);
+ ret = controllo (parameters);
break;
case GTK_RESPONSE_CANCEL:
}
gtk_widget_destroy (diag);
- g_object_unref (gla_main);
+ g_object_unref (gtkbuilder);
return ret;
}
/**
* crea_utente:
- * @confi:
+ * @parameters:
* @codice:
* @password:
*/
gboolean
-crea_utente (Confi *confi, const gchar *codice, const gchar *password)
+crea_utente (GSList *parameters, const gchar *codice, const gchar *password)
{
gchar *codice_;
gchar *password_;
- gchar *provider_id;
gchar *cnc_string;
gchar *sql;
- GdaO *gdao;
+ GdaEx *gdaex;
GdaDataModel *dm;
- if (!IS_CONFI (confi))
- {
- g_warning ("confi non è un oggetto Confi valido.");
- return FALSE;
- }
-
if (codice == FALSE || password == NULL)
{
g_warning ("codice o password nulli.");
return FALSE;
}
+ cnc_string = NULL;
+
+#ifdef HAVE_LIBCONFI
+ /* the first and only parameters must be a Confi object */
/* leggo i parametri di connessione dalla configurazione */
- if (!get_connection_parameters (confi, &provider_id, &cnc_string)) return FALSE;
+ if (IS_CONFI (parameters->data))
+ {
+ if (!get_connection_parameters_from_confi (CONFI (parameters->data), &cnc_string))
+ {
+ cnc_string = NULL;
+ }
+ }
+#endif
+
+ if (cnc_string == NULL)
+ {
+ GSList *param;
+
+ param = g_slist_next (parameters);
+ if (param != NULL && param->data != NULL)
+ {
+ cnc_string = g_strdup ((gchar *)param->data);
+ cnc_string = g_strstrip (cnc_string);
+ if (g_strcmp0 (cnc_string, "") == 0)
+ {
+ cnc_string = NULL;
+ }
+ }
+ }
+
+ if (cnc_string == NULL)
+ {
+ return FALSE;
+ }
/* creo un oggetto GdaO */
- gdao = gdao_new_from_string (NULL, provider_id, cnc_string);
- if (gdao == NULL) return FALSE;
+ gdaex = gdaex_new_from_string (cnc_string);
+ if (gdaex == NULL) return FALSE;
/* controllo se esiste gia' */
- sql = g_strdup_printf ("SELECT codice FROM utenti WHERE codice = '%s'",
- gdao_strescape (codice_, NULL));
- dm = gdao_query (gdao, sql);
+ sql = g_strdup_printf ("SELECT codice FROM utenti WHERE codice = '%s'",
+ gdaex_strescape (codice_, NULL));
+ dm = gdaex_query (gdaex, sql);
if (dm != NULL && gda_data_model_get_n_rows (dm) > 0)
{
/* aggiorno l'utente */
sql = g_strdup_printf ("UPDATE utenti SET password = '%s' WHERE codice = '%s'",
- gdao_strescape (cifra_password (password_), NULL),
- gdao_strescape (codice_, NULL));
+ gdaex_strescape (cifra_password (password_), NULL),
+ gdaex_strescape (codice_, NULL));
}
else
{
/* creo l'utente */
sql = g_strdup_printf ("INSERT INTO utenti VALUES ('%s', '%s', '')",
- gdao_strescape (codice_, NULL),
- gdao_strescape (cifra_password (password_), NULL));
+ gdaex_strescape (codice_, NULL),
+ gdaex_strescape (cifra_password (password_), NULL));
}
- return (gdao_execute (gdao, sql) >= 0);
+ return (gdaex_execute (gdaex, sql) >= 0);
}
/**
* modifice_utente:
- * @confi:
+ * @parameters:
* @codice:
* @password:
*/
gboolean
-modifica_utente (Confi *confi, const gchar *codice, const gchar *password)
+modifica_utente (GSList *parameters, const gchar *codice, const gchar *password)
{
gchar *codice_;
gchar *password_;
- gchar *provider_id;
gchar *cnc_string;
gchar *sql;
- GdaO *gdao;
+ GdaEx *gdaex;
GdaDataModel *dm;
- if (!IS_CONFI (confi))
- {
- g_warning ("confi non è un oggetto Confi valido.");
- return FALSE;
- }
-
if (codice == FALSE || password == NULL)
{
g_warning ("codice o password nulli.");
return FALSE;
}
+#ifdef HAVE_LIBCONFI
+ /* the first and only parameters must be a Confi object */
/* leggo i parametri di connessione dalla configurazione */
- if (!get_connection_parameters (confi, &provider_id, &cnc_string)) return FALSE;
+ if (IS_CONFI (parameters->data))
+ {
+ if (!get_connection_parameters_from_confi (CONFI (parameters->data), &cnc_string))
+ {
+ cnc_string = NULL;
+ }
+ }
+#endif
- /* creo un oggetto GdaO */
- gdao = gdao_new_from_string (NULL, provider_id, cnc_string);
- if (gdao == NULL) return FALSE;
+ if (cnc_string == NULL)
+ {
+ GSList *param;
+
+ param = g_slist_next (parameters);
+ if (param != NULL && param->data != NULL)
+ {
+ cnc_string = g_strdup ((gchar *)param->data);
+ cnc_string = g_strstrip (cnc_string);
+ if (g_strcmp0 (cnc_string, "") == 0)
+ {
+ cnc_string = NULL;
+ }
+ }
+ }
+
+ if (cnc_string == NULL)
+ {
+ return FALSE;
+ }
+
+ /* creo un oggetto GdaEx */
+ gdaex = gdaex_new_from_string (cnc_string);
+ if (gdaex == NULL) return FALSE;
/* controllo se non esiste */
- sql = g_strdup_printf ("SELECT codice FROM utenti WHERE codice = '%s'",
- gdao_strescape (codice_, NULL));
- dm = gdao_query (gdao, sql);
+ sql = g_strdup_printf ("SELECT codice FROM utenti WHERE codice = '%s'",
+ gdaex_strescape (codice_, NULL));
+ dm = gdaex_query (gdaex, sql);
if (dm == NULL || gda_data_model_get_n_rows (dm) <= 0)
{
/* creo l'utente */
sql = g_strdup_printf ("INSERT INTO utenti VALUES ('%s', '%s', '')",
- gdao_strescape (codice_, NULL),
- gdao_strescape (cifra_password (password_), NULL));
+ gdaex_strescape (codice_, NULL),
+ gdaex_strescape (cifra_password (password_), NULL));
}
else
{
/* aggiorno l'utente */
sql = g_strdup_printf ("UPDATE utenti SET password = '%s' WHERE codice = '%s'",
- gdao_strescape (cifra_password (password_), NULL),
- gdao_strescape (codice_, NULL));
+ gdaex_strescape (cifra_password (password_), NULL),
+ gdaex_strescape (codice_, NULL));
}
- return (gdao_execute (gdao, sql) >= 0);
+ return (gdaex_execute (gdaex, sql) >= 0);
}
/**
* elimina_utente:
- * @confi:
+ * @parameters:
* @codice:
*/
gboolean
-elimina_utente (Confi *confi, const gchar *codice)
+elimina_utente (GSList *parameters, const gchar *codice)
{
gchar *codice_;
- gchar *provider_id;
gchar *cnc_string;
gchar *sql;
- GdaO *gdao;
-
- if (!IS_CONFI (confi))
- {
- g_warning ("confi non è un oggetto Confi valido.");
- return FALSE;
- }
+ GdaEx *gdaex;
if (codice == FALSE)
{
return FALSE;
}
+#ifdef HAVE_LIBCONFI
+ /* the first and only parameters must be a Confi object */
/* leggo i parametri di connessione dalla configurazione */
- if (!get_connection_parameters (confi, &provider_id, &cnc_string)) return FALSE;
+ if (IS_CONFI (parameters->data))
+ {
+ if (!get_connection_parameters_from_confi (CONFI (parameters->data), &cnc_string))
+ {
+ cnc_string = NULL;
+ }
+ }
+#endif
- /* creo un oggetto GdaO */
- gdao = gdao_new_from_string (NULL, provider_id, cnc_string);
- if (gdao == NULL) return FALSE;
+ if (cnc_string == NULL)
+ {
+ GSList *param;
+
+ param = g_slist_next (parameters);
+ if (param != NULL && param->data != NULL)
+ {
+ cnc_string = g_strdup ((gchar *)param->data);
+ cnc_string = g_strstrip (cnc_string);
+ if (g_strcmp0 (cnc_string, "") == 0)
+ {
+ cnc_string = NULL;
+ }
+ }
+ }
+
+ if (cnc_string == NULL)
+ {
+ return FALSE;
+ }
+
+ /* creo un oggetto GdaEx */
+ gdaex = gdaex_new_from_string (cnc_string);
+ if (gdaex == NULL) return FALSE;
/* elimino _logicamente_ l'utente */
- sql = g_strdup_printf ("UPDATE utenti SET status = 'E' WHERE codice = '%s'",
- gdao_strescape (codice_, NULL));
+ sql = g_strdup_printf ("UPDATE utenti SET status = 'E' WHERE codice = '%s'",
+ gdaex_strescape (codice_, NULL));
- return (gdao_execute (gdao, sql) >= 0);
+ return (gdaex_execute (gdaex, sql) >= 0);
}