<listOptionValue builtIn="false" value=""C:\mingw\include\glib-2.0""/>
<listOptionValue builtIn="false" value=""C:\mingw\include\gtk-2.0""/>
<listOptionValue builtIn="false" value=""C:\mingw\include\libgda-4.0""/>
+ <listOptionValue builtIn="false" value=""C:\Program Files\PostgreSQL\8.4\include""/>
</option>
<inputType id="cdt.managedbuild.tool.gnu.c.compiler.input.120162119" superClass="cdt.managedbuild.tool.gnu.c.compiler.input"/>
</tool>
<property name="title" translatable="yes">Tipo nodo - Gestione organigramma</property>
<property name="modal">True</property>
<property name="window_position">center-on-parent</property>
+ <property name="default_width">500</property>
<property name="destroy_with_parent">True</property>
<child>
<object class="GtkVBox" id="vbox3">
<property name="title" translatable="yes">Tipo recapito - Gestione organigramma</property>
<property name="modal">True</property>
<property name="window_position">center-on-parent</property>
+ <property name="default_width">500</property>
<property name="destroy_with_parent">True</property>
<child>
<object class="GtkVBox" id="vbox4">
<object class="GtkTable" id="table3">
<property name="visible">True</property>
<property name="can_focus">False</property>
- <property name="n_rows">2</property>
+ <property name="n_rows">3</property>
<property name="n_columns">2</property>
<property name="column_spacing">5</property>
<property name="row_spacing">5</property>
<property name="y_options">GTK_FILL</property>
</packing>
</child>
+ <child>
+ <object class="GtkFrame" id="frame3">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="label_xalign">0</property>
+ <child>
+ <object class="GtkAlignment" id="alignment1">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="border_width">5</property>
+ <child>
+ <placeholder/>
+ </child>
+ </object>
+ </child>
+ <child type="label">
+ <object class="GtkLabel" id="label190">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="label" translatable="yes"><b>Immagine</b></property>
+ <property name="use_markup">True</property>
+ </object>
+ </child>
+ </object>
+ <packing>
+ <property name="right_attach">2</property>
+ <property name="top_attach">2</property>
+ <property name="bottom_attach">3</property>
+ </packing>
+ </child>
</object>
<packing>
<property name="expand">True</property>
status character varying(1) DEFAULT ''::character varying,
CONSTRAINT struttura_collegamenti_pkey PRIMARY KEY (id)
);
+
+ALTER TABLE tipi_recapito ADD COLUMN immagine_percorso character varying(255) DEFAULT '';
+ALTER TABLE tipi_recapito ADD COLUMN immagine_contenuto integer DEFAULT 0;
+ALTER TABLE tipi_recapito ADD COLUMN immagine_file_data timestamp without time zone;
+ALTER TABLE tipi_recapito ADD COLUMN immagine_file_dimensione bigint DEFAULT 0;
-- Dumped from database version 8.4.17
-- Dumped by pg_dump version 9.2.2
--- Started on 2013-06-03 10:51:06
+-- Started on 2013-06-03 13:27:01
SET statement_timeout = 0;
SET client_encoding = 'UTF8';
CREATE TABLE tipi_recapito (
id integer NOT NULL,
nome character varying(100) DEFAULT ''::character varying,
- status character varying(1) DEFAULT ''::character varying
+ status character varying(1) DEFAULT ''::character varying,
+ immagine_percorso character varying(255) DEFAULT ''::character varying,
+ immagine_contenuto integer DEFAULT 0,
+ immagine_file_data timestamp without time zone,
+ immagine_file_dimensione bigint DEFAULT 0
);
--
--- TOC entry 1988 (class 2606 OID 59289)
+-- TOC entry 1991 (class 2606 OID 59289)
-- Name: nodi_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2028 (class 2606 OID 61360)
+-- TOC entry 2031 (class 2606 OID 61360)
-- Name: persona_incarichi_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2018 (class 2606 OID 61305)
+-- TOC entry 2021 (class 2606 OID 61305)
-- Name: persona_nodi_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2020 (class 2606 OID 61321)
+-- TOC entry 2023 (class 2606 OID 61321)
-- Name: persona_nodo_recapiti_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2014 (class 2606 OID 61279)
+-- TOC entry 2017 (class 2606 OID 61279)
-- Name: persona_recapiti_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2012 (class 2606 OID 61252)
+-- TOC entry 2015 (class 2606 OID 61252)
-- Name: persona_uffici_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2016 (class 2606 OID 61294)
+-- TOC entry 2019 (class 2606 OID 61294)
-- Name: persona_ufficio_recapiti_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2008 (class 2606 OID 61235)
+-- TOC entry 2011 (class 2606 OID 61235)
-- Name: persone_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2022 (class 2606 OID 61328)
+-- TOC entry 2025 (class 2606 OID 61328)
-- Name: posizioni_economiche_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2026 (class 2606 OID 61342)
+-- TOC entry 2029 (class 2606 OID 61342)
-- Name: profili_professionali_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2032 (class 2606 OID 618188)
+-- TOC entry 2035 (class 2606 OID 618188)
-- Name: ruoli_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2036 (class 2606 OID 626378)
+-- TOC entry 2039 (class 2606 OID 626378)
-- Name: struttura_collegamenti_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 1998 (class 2606 OID 59356)
+-- TOC entry 2001 (class 2606 OID 59356)
-- Name: struttura_indirizzi_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 1996 (class 2606 OID 59339)
+-- TOC entry 1999 (class 2606 OID 59339)
-- Name: strutture_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 1990 (class 2606 OID 59296)
+-- TOC entry 1993 (class 2606 OID 59296)
-- Name: tipi_nodo_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2024 (class 2606 OID 61335)
+-- TOC entry 2027 (class 2606 OID 61335)
-- Name: tipi_prestazione_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2010 (class 2606 OID 61242)
+-- TOC entry 2013 (class 2606 OID 61242)
-- Name: tipi_rapporto_lavoro_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 1992 (class 2606 OID 59303)
+-- TOC entry 1995 (class 2606 OID 59303)
-- Name: tipi_recapito_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2006 (class 2606 OID 61226)
+-- TOC entry 2009 (class 2606 OID 61226)
-- Name: titoli_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 1994 (class 2606 OID 59321)
+-- TOC entry 1997 (class 2606 OID 59321)
-- Name: uffici_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2034 (class 2606 OID 626366)
+-- TOC entry 2037 (class 2606 OID 626366)
-- Name: ufficio_collegamenti_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2000 (class 2606 OID 59366)
+-- TOC entry 2003 (class 2606 OID 59366)
-- Name: ufficio_nodi_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2002 (class 2606 OID 59408)
+-- TOC entry 2005 (class 2606 OID 59408)
-- Name: ufficio_orari_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2004 (class 2606 OID 59419)
+-- TOC entry 2007 (class 2606 OID 59419)
-- Name: ufficio_recapiti_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
--
--- TOC entry 2030 (class 2606 OID 61430)
+-- TOC entry 2033 (class 2606 OID 61430)
-- Name: ufficio_stanze_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
ADD CONSTRAINT ufficio_stanze_pkey PRIMARY KEY (id);
--- Completed on 2013-06-03 10:51:06
+-- Completed on 2013-06-03 13:27:02
--
-- PostgreSQL database dump complete
cnc_string=PostgreSQL://postgres:postgres@HOST=localhost;PORT=5432;DB_NAME=autoz
[DB]
+pg_cnc_string=host=localhost dbname=organigramma user=postgres password=postgres
cnc_string=PostgreSQL://postgres:postgres@HOST=localhost;PORT=5432;DB_NAME=organigramma
cnc_string=PostgreSQL://postgres@HOST=panoramix.comune.scandicci.fi.it;PORT=5432;DB_NAME=audit
[DB]
-pg_cnc_string=host=panoramix.comune.scandicci.fi.it dbname=opengov user=postgres
+pg_cnc_string=host=panoramix.comune.scandicci.fi.it dbname=organigramma user=postgres
cnc_string=PostgreSQL://postgres@HOST=panoramix.comune.scandicci.fi.it;PORT=5432;DB_NAME=organigramma
LIBS = $(ORGANIGRAMMA_LIBS) \
-export-dynamic
+if PLATFORM_WIN32
+AM_CPPFLAGS += -I/programmi/PostgreSQL/8.4/include
+LIBS += -L/programmi/PostgreSQL/8.4/lib -lpq
+endif
+
lib_LTLIBRARIES = liborganigramma.la
liborganigramma_la_SOURCES = \
LIBS = $(ORGANIGRAMMA_LIBS) \
-export-dynamic
+if PLATFORM_WIN32
+AM_CPPFLAGS += -I/programmi/PostgreSQL/8.4/include
+LIBS += -L/programmi/PostgreSQL/8.4/lib -lpq
+endif
+
.rc.o:
$(WINDRES) $^ -o $@
/*
- * Copyright (C) 2010-2012 Andrea Zagli <a.zagli@comune.scandicci.fi.it>
+ * Copyright (C) 2010-2013 Andrea Zagli <a.zagli@comune.scandicci.fi.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
#ifndef __ORGANIGRAMMA_COMMONS_H__
#define __ORGANIGRAMMA_COMMONS_H__
+#include <libpq-fe.h>
+
#include <gtk/gtk.h>
#include <libgdaex/libgdaex.h>
#include <libautoz/autoz.h>
#include <libautoz/role_interface.h>
+#include <libsolipa/libsolipa.h>
#include <libterritorio/commons.h>
GdaEx *gdaex;
+ PGconn *pgcon;
+
const gchar *guifile;
const gchar *utente;
Autoz *autoz;
AutozIRole *role_utente;
+ Solipa *solipa;
+
TerritorioCommons *territorio_commons;
} OrganigrammaCommons;
/*
- * Copyright (C) 2010-2012 Andrea Zagli <a.zagli@comune.scandicci.fi.it>
+ * Copyright (C) 2010-2013 Andrea Zagli <a.zagli@comune.scandicci.fi.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
return 0;
}
+ /* inizializzo solipa */
+ commons->solipa = solipa_new ();
+
/* leggo la stringa di connessione al db */
error = NULL;
cnc_string = g_key_file_get_value (config, "DB", "cnc_string", &error);
g_error ("Errore nella connessione al database: %s", cnc_string);
}
+ /* leggo la stringa di connessione al db nativa di postgres */
+ error = NULL;
+ cnc_string = g_key_file_get_value (config, "DB", "pg_cnc_string", &error);
+ if (cnc_string == NULL)
+ {
+ if (error != NULL)
+ {
+ g_error ("Impossibile leggere la stringa di connessione dal file di configurazione: %s", error->message);
+ }
+ else
+ {
+ g_error ("Impossibile leggere la stringa di connessione dal file di configurazione.");
+ }
+ }
+
+ commons->pgcon = PQconnectdb (cnc_string);
+ if (commons->pgcon == NULL
+ || PQstatus (commons->pgcon) == CONNECTION_BAD)
+ {
+ g_error ("Errore nella connessione al database: %s", cnc_string);
+ }
+
/* leggo la stringa di connessione al db territorio */
error = NULL;
cnc_string = g_key_file_get_value (config, "DB_TERRITORIO", "cnc_string", &error);
#include <config.h>
#endif
+#include <libpq-fe.h>
+
#include <libautoz/autoz.h>
#include <libgtkform/form.h>
#include <libsolipa/utils.h>
GtkForm *form;
GtkWidget *w;
+ SolipaAllegato *sallegato;
GObject **objects;
"label15",
NULL);
+ priv->sallegato = solipa_allegato_new (commons->solipa);
+ if (priv->sallegato != NULL)
+ {
+ solipa_allegato_add_to_gtkform (priv->sallegato, priv->form,
+ "immagine_percorso", "immagine_file_data", "immagine_file_dimensione");
+ solipa_allegato_con_salva_in_db (priv->sallegato, FALSE);
+ gtk_container_add (GTK_CONTAINER (gtk_builder_get_object (priv->commons->gtkbuilder, "alignment1")),
+ solipa_allegato_get_widget (priv->sallegato));
+ }
+
g_signal_connect (priv->w,
"delete-event", G_CALLBACK (organigramma_tipo_recapito_on_w_organigramma_tipo_recapito_delete_event), (gpointer)a);
{
OrganigrammaTipoRecapitoPrivate *priv = ORGANIGRAMMA_TIPO_RECAPITO_GET_PRIVATE (tipo_recapito);
- gtk_form_fill_from_table (priv->form);
+ if (gtk_form_fill_from_table (priv->form))
+ {
+ solipa_allegato_set_salva_in_db (priv->sallegato, TRUE);
+ }
}
static void
priv->id = strtol (gtk_label_get_text (GTK_LABEL (priv->objects[LBL_ID])), NULL, 10);
}
+ /* salvo l'atto_allegato nel db */
+ /* devo utilizzare le funzioni native di postgres
+ * perché quelle di libgda non sembrano funzionare sotto windows */
+ Oid oid;
+ const gchar *percorso;
+
+ percorso = solipa_allegato_get_percorso (priv->sallegato);
+
+ if (PQexec (priv->commons->pgcon, "BEGIN") == NULL)
+ {
+ if (priv->id == 0)
+ {
+ gtk_label_set_text (GTK_LABEL (priv->objects[LBL_ID]), "");
+ }
+
+ solipa_message_dialog (priv->w,
+ GTK_MESSAGE_WARNING,
+ GTK_BUTTONS_OK,
+ "Errore durante il salvataggio: allegato non importato nel database (impossibile aprire la transazione).");
+ return;
+ }
+
+ oid = lo_import (priv->commons->pgcon, percorso);
+
+ if (oid > 0)
+ {
+ sql = g_strdup_printf ("UPDATE tipi_recapito"
+ " SET immagine_contenuto = %d,"
+ " immagine_percorso = '%s'"
+ " WHERE id = %d",
+ oid,
+ gdaex_strescape (g_path_get_basename (percorso), NULL),
+ priv->id);
+ if (gdaex_execute (priv->commons->gdaex, sql) < 1)
+ {
+ g_free (sql);
+
+ if (priv->id == 0)
+ {
+ gtk_label_set_text (GTK_LABEL (priv->objects[LBL_ID]), "");
+ }
+
+ solipa_message_dialog (priv->w,
+ GTK_MESSAGE_WARNING,
+ GTK_BUTTONS_OK,
+ "Errore durante il salvataggio.");
+ return;
+ }
+ g_free (sql);
+
+ organigramma_tipo_recapito_carica (tipo_recapito);
+ }
+ else
+ {
+ if (priv->id == 0)
+ {
+ gtk_label_set_text (GTK_LABEL (priv->objects[LBL_ID]), "");
+ }
+
+ solipa_message_dialog (priv->w,
+ GTK_MESSAGE_WARNING,
+ GTK_BUTTONS_OK,
+ "Errore durante il salvataggio: allegato non importato nel database.");
+ return;
+ }
+
+ PQexec (priv->commons->pgcon, "COMMIT");
+
solipa_message_dialog (priv->w,
GTK_MESSAGE_INFO,
GTK_BUTTONS_OK,