aboutsummaryrefslogblamecommitdiffstats
path: root/plugins/groupwise-features/share-folder.c
blob: 104da0fd60a3dab24e70eac93a83ed67bb089a69 (plain) (tree)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
















                                                                           
                                                                                  








                         
                           













                                             
                                  






























































































































































                                                                                              






                                

                                                                   
                                                                     





















                                                                                                                                 
 


























                                                                                                                                                         
                         




                                                                                                 

                 
 










                                                                                                                                  



                                                                                                              
 





















                                                                                                                                                                           




































































































                                                                                                              

                                                                             














































































































                                                                                                                                                              
                        

                                                          






                                                           











                                                                                                         



                                                                                     



























                                                                                                          
                            

                                                                     
                                                                           
                                                                         

        






                                                                            






                                                                                      

                                                                                                



                                          









                                                                                                        
                                  

 
           





                                                                            






                                                                                       

                                                                                                



                                          










                                                                                                        
                                  

 
           





                                                                              






                                                                                       

                                                                                                



                                          



                                                                                        

                                                                                                        



                                                                                           
                                  









                                                  






                                                         
 





                                                                           
                                                                         













































                                                                                                                               
                                                            




                                                                                                                      
                                                                                                      



                                                                   
                                                                                                          




                                                                                   
                                                                                                         




                                                                                    
                                                                                                         





















                                                                                                                                
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
/*
 *  Author: Vivek Jain <jvivek@novell.com>
 *
 *  Copyright 2004 Novell, Inc.
 *
 *  This program is free software; you can redistribute it and/or
 *  modify it under the terms of version 2 of the GNU General Public
 *  License as published by the Free Software Foundation.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to the Free Software
 *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 *
 */

#ifdef HAVE_CONFIG_H
#  include <config.h>
#endif
#include <glade/glade.h>
#include "share-folder.h"
#include <glib/gmain.h>
#include <glib/gi18n-lib.h>
#include <gtk/gtktreemodel.h>
#include <gtk/gtkliststore.h>
#include <gtk/gtktreeselection.h>
#include <gtk/gtktreeview.h>
#include <gtk/gtkdialog.h>
#include <gtk/gtkbutton.h>
#include <gtk/gtk.h>
#include <gtk/gtktogglebutton.h>
#include <gtk/gtkcellrenderertoggle.h>
#include <gtk/gtkcellrenderertext.h>
#include <libedataserverui/e-contact-store.h>
#include <libgnomeui/gnome-ui-init.h>
#include <libgnome/gnome-init.h>
#include <e-util/e-error.h>
#include <e-util/e-util-private.h>
#include <e-gw-container.h>
#include <e-gw-connection.h>
#define ROOTNODE "vboxSharing"
#define NROOTNODE "vbox191"
#define d(x)

struct _SharedUser {
    EShUsers *user_node;
    int flag;
};
typedef struct _SharedUser SharedUser;

static void share_folder_class_init (ShareFolderClass *class);
static void share_folder_init       (ShareFolder *sf);
static void share_folder_destroy    (GtkObject *obj);
static void share_folder_finalise   (GObject *obj);
static void free_user_node(EShUsers *user);
static void free_node(SharedUser *user);
static void free_all(ShareFolder *sf);
static SharedUser * find_node(GList *list, gchar *email);
static void free_all(ShareFolder *sf);
static void get_container_list (ShareFolder *sf);
static void user_selected(GtkTreeSelection *selection, ShareFolder *sf);
static void not_shared_clicked (GtkRadioButton *button, ShareFolder *sf);
static void shared_clicked (GtkRadioButton *button, ShareFolder *sf);
static void add_clicked(GtkButton *button, ShareFolder *sf);
static void remove_clicked(GtkButton *button, ShareFolder *sf);
static void not_ok_clicked(GtkButton *button, ShareFolder *sf);
static void not_cancel_clicked(GtkButton *button, GtkWidget *window);
static void not_cancel_clicked(GtkButton *button, GtkWidget *window);
static void share_folder_construct (ShareFolder *sf);
GType share_folder_get_type (void);

static GtkVBoxClass *parent_class = NULL;

GType
share_folder_get_type (void)
{
    static GType type = 0;

    if (!type) {
        static const GTypeInfo info = {
            sizeof (ShareFolderClass),
            NULL, NULL,
            (GClassInitFunc) share_folder_class_init,
            NULL, NULL,
            sizeof (ShareFolder),
            0,
            (GInstanceInitFunc) share_folder_init
        };

        type = g_type_register_static (gtk_vbox_get_type (), "ShareFolder", &info, 0);
    }

    return type;
}

static void
share_folder_class_init (ShareFolderClass *klass)
{
    GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
    GtkObjectClass *object_class = GTK_OBJECT_CLASS (klass);

    parent_class = g_type_class_ref (gtk_vbox_get_type ());
    object_class->destroy = share_folder_destroy;
    gobject_class->finalize = share_folder_finalise;
}

static void
share_folder_finalise (GObject *obj)
{
    ShareFolder *sf = (ShareFolder *) obj;
    g_object_unref (sf->xml);
    free_all(sf);   
    G_OBJECT_CLASS (parent_class)->finalize (obj);
}

static void
share_folder_destroy (GtkObject *obj)
{

    ShareFolder *sf = (ShareFolder *) obj;
    free_all (sf);  
    GTK_OBJECT_CLASS (parent_class)->destroy (obj);
}

static void
share_folder_init (ShareFolder *sf)
{
    sf->gcontainer = NULL;
    sf->users = 0;
    sf->flag_for_ok = 0;
    sf->shared = FALSE;
    sf->container_list = NULL;
    sf->users_list = NULL;
    sf->sub = "Shared Folder notification";
    sf->message = NULL;
}

static void
free_user_node(EShUsers *user)
{
    if(user){
        g_free(user->email);
        user->email = NULL;
    }
    return ;
}

static void
free_node(SharedUser *usr)
{
    EShUsers *user = usr->user_node;
    if(user){
        g_free(user->email);
        user->email = NULL;
    }
    return ;
}

static SharedUser * 
find_node(GList *list, gchar *email)
{
    SharedUser *user = NULL;
    EShUsers *usr = NULL; 
    GList *tmp;
    gint i ;
    
    if(list){
        tmp = g_list_first(list); 
        for(i=0; tmp  ; i++)
        {
            user = tmp->data;
            usr = user->user_node;
            if(!g_ascii_strcasecmp(usr->email, email)){
                return user; /*if found, it returns that user*/
            }
            tmp= g_list_next(tmp);
        }
    }
    return NULL;
}

static void 
free_all (ShareFolder *sf)
{
    if (sf->users_list){
        g_list_foreach (sf->users_list,(GFunc) free_node, NULL);
        g_list_free (sf->users_list);
        sf->users_list = NULL;
    }

    //e_gw_connection_free_container_list (sf->container_list);
}


static void 
display_container (EGwContainer *container , ShareFolder *sf)
{
    gboolean byme = FALSE;
    gboolean tome = FALSE;
    gchar *email = NULL;
    gchar *msg;
    GList *user_list = NULL;
    EShUsers *user = NULL;

    sf->gcontainer = container;
    if(!(byme = e_gw_container_get_is_shared_by_me(container)))
        tome = e_gw_container_get_is_shared_to_me(container);
    if(byme || tome) {
        e_gw_container_get_user_list (sf->gcontainer, &user_list);  
        sf->users = g_list_length (user_list);
        if(sf->users != 0) {
            sf->is_shared = TRUE;
            gtk_toggle_button_set_active((GtkToggleButton *) sf->shared, TRUE);
            shared_clicked(sf->shared , sf);
            if (tome) {
                g_print ("Entered: inside too\n");

                gtk_widget_set_sensitive (GTK_WIDGET (sf->not_shared), FALSE);
                gtk_widget_set_sensitive (GTK_WIDGET (sf->add_button), FALSE);
                gtk_widget_set_sensitive (GTK_WIDGET (sf->remove), FALSE);
                gtk_widget_set_sensitive (GTK_WIDGET (sf->add_book), FALSE);
                gtk_widget_set_sensitive (GTK_WIDGET (sf->notification), FALSE);
                gtk_widget_set_sensitive (GTK_WIDGET (sf->user_list), FALSE);
                email = g_strdup (e_gw_container_get_owner (sf->gcontainer));
                msg = g_strconcat (email, "  (Owner)", NULL);
                gtk_list_store_append (GTK_LIST_STORE (sf->model), &(sf->iter));
                gtk_list_store_set (GTK_LIST_STORE (sf->model), &(sf->iter), 0, msg, -1);            
                g_free (msg);
                g_free (email);

            } else
                gtk_widget_set_sensitive (GTK_WIDGET (sf->table), TRUE);
            /* I populate the list and set flags to 0 for the existing users*/ 
            while (user_list) {
                SharedUser *shared_user = g_new0 (SharedUser , 1);
                gboolean add, edit, delete;
                add = edit = delete = FALSE;
                user = user_list->data;
                shared_user->user_node = user;
                shared_user->flag = 0;  
                email = g_strdup (user->email);
                if (user->rights & 0x1)
                    add = TRUE;
                if (user->rights & 0x2)
                    edit = TRUE;
                if (user->rights & 0x4)
                    delete = TRUE;

                msg = g_strdup_printf ("%s", email);
                gtk_list_store_append (GTK_LIST_STORE (sf->model), &(sf->iter));
                gtk_list_store_set (GTK_LIST_STORE (sf->model), &(sf->iter), 0, msg, 1, add, 2, edit, 3, delete, -1);            
                sf->users_list = g_list_append (sf->users_list, shared_user);
                g_free (msg);
                g_free (email);
                msg = NULL;
                email = NULL;
                user_list = user_list->next;
            }
            /* i also need to display status*/
        } else {

            gtk_toggle_button_set_active ((GtkToggleButton *) sf->not_shared,  TRUE);
            not_shared_clicked (sf->not_shared , sf);
        }
    }

}

static void
get_container_list (ShareFolder *sf)
{
    sf->container_list = NULL;
    if (E_IS_GW_CONNECTION (sf->cnc)) {
        /* get list of containers */
        if (e_gw_connection_get_container_list (sf->cnc, "folders", &(sf->container_list)) == E_GW_CONNECTION_STATUS_OK) {
            GList *container = NULL;

            for (container = sf->container_list; container != NULL; container = container->next) {
                gchar **tail;
                gchar *id_shared = NULL;
                gchar *id_unshared = NULL;

                id_shared = g_strdup(e_gw_container_get_id (container->data));

                /* this has to be done since id changes after the folder is shared*/
                if( g_str_has_suffix (id_shared, "35")){
                    tail = g_strsplit(id_shared, "@", 2);
                    id_unshared = g_strconcat(tail[0], "@", "13", NULL);
                    g_strfreev(tail);
                }

                if((id_shared && !g_ascii_strcasecmp(id_shared, sf->container_id)) ||(id_unshared && !g_ascii_strcasecmp(id_unshared, sf->container_id))) {

                    display_container (E_GW_CONTAINER (container->data), sf);
                    g_free (id_shared);
                    g_free (id_unshared);
                    break;
                }
            
                g_free (id_shared);
                g_free (id_unshared);
            }

        } else
            g_warning("Could not get the Container List");
    }
}


static void 
shared_clicked (GtkRadioButton *button, ShareFolder *sf)
{

    gtk_widget_set_sensitive (GTK_WIDGET (sf->table) ,TRUE);
    sf->flag_for_ok = 0;        
}

static void 
not_shared_clicked (GtkRadioButton *button, ShareFolder *sf)
{
    if (!sf->is_shared) {
        sf->flag_for_ok = 0;
    } else {
        sf->flag_for_ok = 2;
    }
    gtk_widget_set_sensitive (GTK_WIDGET (sf->table), FALSE);

}

static void
add_clicked(GtkButton *button, ShareFolder *sf)
{
    const char *email = NULL;
    const char *self_email = NULL;
    SharedUser *new_user = NULL;
    EShUsers *usr = NULL;
    gint rights = 0;
    gchar *msg = NULL;
    EDestinationStore *destination_store;
    GList *destinations, *tmp;
    ENameSelectorEntry *name_selector_entry;

    name_selector_entry = e_name_selector_peek_section_entry (sf->name_selector, "Add User");
    destination_store = e_name_selector_entry_peek_destination_store (E_NAME_SELECTOR_ENTRY (
                name_selector_entry));
    destinations = e_destination_store_list_destinations (destination_store);
    tmp = destinations;
    self_email = g_strdup (e_gw_connection_get_user_email (sf->cnc));
    for (; tmp != NULL; tmp = g_list_next (tmp)) {
        email = e_destination_get_email (tmp->data);
        /* You can't share a folder with yourself*/
        if (g_strrstr (email, "@") == NULL || (!g_ascii_strcasecmp (email , self_email))) 
            e_error_run (NULL, "org.gnome.evolution.mail_shared_folder:invalid-user",email ,NULL);
        else {  
            if (!g_ascii_strcasecmp (email, "" )) {
                e_error_run (NULL, "org.gnome.evolution.mail_shared_folder:no-user",NULL);

                return ;
            }


            /*check whether already exists*/
            if (sf->users_list && email){
                new_user = find_node (sf->users_list, (gchar *)email);
                if (new_user) 
                    return ;

            }
            usr = g_new0 (EShUsers, 1);
            new_user = g_new0 (SharedUser, 1);
            usr->email = g_strdup(email);
            usr->rights = rights;
            new_user->user_node = usr;
            new_user->flag = 1;
            msg = g_strdup (email);
            gtk_list_store_append (GTK_LIST_STORE (sf->model), &(sf->iter));
            
        /*  have to add code for rights*/   
            gtk_list_store_set (GTK_LIST_STORE (sf->model), &(sf->iter), 0, msg, -1);
            g_free(msg);
            sf->users_list = g_list_append (sf->users_list, new_user);
            sf->flag_for_ok = 0;
        }
    }
    gtk_entry_set_text (GTK_ENTRY(name_selector_entry), "");

}

static void
remove_clicked(GtkButton *button, ShareFolder *sf)
{

    SharedUser *usr = NULL;
    gchar *email;

    gtk_tree_model_get ((GtkTreeModel *) sf->model, &(sf->iter), 0, &email, -1);
    usr = find_node (sf->users_list, email);
    if (usr->flag & 0x1) {  
        sf->users_list = g_list_remove (sf->users_list, usr);
        free_node(usr);     
    } else {
        usr->flag = 0;
        usr->flag |= 0x4;
    }
    g_free (email);
    if (!gtk_list_store_remove (GTK_LIST_STORE (sf->model), &(sf->iter)))
        gtk_widget_set_sensitive (GTK_WIDGET (sf->remove), FALSE);
    sf->flag_for_ok = 1;
}

void 
share_folder (ShareFolder *sf)
{
    
    GList *new_list = NULL;
    GList *update_list = NULL;
    GList *remove_list = NULL;
    GList *node = NULL;
    SharedUser *user = NULL;

    for (node = sf->users_list; node; node = node->next)
    {
        user = node->data;  
        if (user->flag & 0x1)
            new_list = g_list_append (new_list, user->user_node);   
        else if (user->flag & 0x2)
            update_list = g_list_append (update_list, user->user_node); 
        else if (user->flag & 0x4) {
            remove_list = g_list_append (remove_list, user->user_node); 
        }
    }

    if (E_IS_GW_CONNECTION (sf->cnc)) {
        if(sf->flag_for_ok == 2){  /* you have to remove all the users*/
        GList *list = NULL;

            if(new_list){
                g_list_foreach (new_list, (GFunc) free_user_node, NULL);
                g_list_free (new_list);
            }
            if(update_list){
                g_list_foreach (update_list, (GFunc) free_user_node, NULL);
                g_list_free (update_list);
            }

            new_list = NULL;
            if(remove_list){
                g_list_foreach (remove_list,(GFunc) free_user_node, NULL);
                g_list_free (remove_list);
            }
            remove_list = NULL;
            if (sf->gcontainer) {
                e_gw_container_get_user_list (sf->gcontainer, &list);
                remove_list = g_list_copy (list);

            } else {
                g_warning("Container is Null");
            }   


        } else {
            if (new_list) {
                if (e_gw_connection_share_folder (sf->cnc, sf->container_id, new_list, sf->sub, sf->mesg, 0) == E_GW_CONNECTION_STATUS_OK);
            }

            if (update_list) {
                sf->sub = "Shared Folder rights updated";

                if (e_gw_connection_share_folder (sf->cnc, sf->container_id, update_list, sf->sub, sf->mesg, 2) == E_GW_CONNECTION_STATUS_OK);
            }
        }  
        if (remove_list) {
            sf->sub = "Shared Folder removed";
            if (e_gw_connection_share_folder (sf->cnc, sf->container_id, remove_list, sf->sub, sf->mesg, 1) == E_GW_CONNECTION_STATUS_OK);
        }

    }
}

static void
not_ok_clicked(GtkButton *button, ShareFolder *sf)
{

    gchar *subj = NULL;
    gchar *msg = NULL;
    GtkTextIter *start, *end;
    GtkTextBuffer *buffer;

    buffer = gtk_text_buffer_new (NULL);
    start = g_new0 (GtkTextIter, 1);
    end = g_new0 (GtkTextIter, 1);
    subj = g_strdup (gtk_entry_get_text (sf->subject));
    if (subj)
        sf->sub = subj;
    buffer = gtk_text_view_get_buffer (sf->message);
    gtk_text_buffer_get_start_iter (buffer, start);
    gtk_text_buffer_get_end_iter (buffer, end);
    msg = gtk_text_buffer_get_text (buffer, start, end, FALSE);
    if (msg)
        sf->mesg = msg;
    gtk_widget_destroy (GTK_WIDGET (sf->window));

}

static void 
not_cancel_clicked(GtkButton *button, GtkWidget *window)
{
    gtk_widget_destroy(window);
}


static void
notification_clicked(GtkButton *button, ShareFolder *sf)
{
    static  GladeXML *xmln;
    GtkButton *not_ok;
    GtkButton *not_cancel;
    GtkWidget *vbox;
    char *gladefile;

    sf->window = gtk_window_new (GTK_WINDOW_TOPLEVEL);

    gladefile = g_build_filename (EVOLUTION_GLADEDIR,
                      "properties.glade",
                      NULL);
    xmln = glade_xml_new (gladefile, NROOTNODE , NULL);
    g_free (gladefile);

    vbox = GTK_WIDGET (glade_xml_get_widget (xmln, "vbox191"));
    gtk_container_add (GTK_CONTAINER (sf->window), vbox);
    sf->subject = GTK_ENTRY (glade_xml_get_widget (xmln, "entry3"));
    gtk_entry_set_text(GTK_ENTRY (sf->subject) , sf->sub);
    sf->message = GTK_TEXT_VIEW (glade_xml_get_widget (xmln, "textview1"));
    not_ok = GTK_BUTTON (glade_xml_get_widget (xmln, "nOK"));
    g_signal_connect ((gpointer) not_ok, "clicked", G_CALLBACK (not_ok_clicked), sf);
    not_cancel = GTK_BUTTON (glade_xml_get_widget (xmln, "nCancel"));
    g_signal_connect ((gpointer) not_cancel, "clicked", G_CALLBACK (not_cancel_clicked), sf->window);
    gtk_window_set_title (GTK_WINDOW (sf->window), "Custom Notification");
    gtk_window_set_position (GTK_WINDOW (sf->window) , GTK_WIN_POS_CENTER_ALWAYS);
    gtk_window_set_default_size (GTK_WINDOW (sf->window), 100, 200);
    gtk_widget_reparent (GTK_WIDGET (sf->window), GTK_WIDGET (sf->vbox));
    gtk_window_set_transient_for ((GtkWindow *)sf->window, GTK_WINDOW(sf->vbox));
    gtk_window_set_modal ((GtkWindow *)sf->window, TRUE);
    gtk_window_present ((GtkWindow *)sf->window); 
    gtk_widget_show_all (sf->window);
}

static void
addressbook_dialog_response (ENameSelectorDialog *name_selector_dialog, gint response, gpointer user_data)
{
    gtk_widget_hide (GTK_WIDGET (name_selector_dialog));
}

static void
addressbook_entry_changed (GtkWidget *entry, gpointer   user_data)
{

}

static void
address_button_clicked_cb (GtkButton *button, gpointer data)
{
    ShareFolder *sf = data;
    ENameSelectorDialog *name_selector_dialog;

    name_selector_dialog = e_name_selector_peek_dialog (sf->name_selector);
    gtk_widget_show (GTK_WIDGET (name_selector_dialog));
}

    static void 
user_selected(GtkTreeSelection *selection, ShareFolder *sf)
{
    GtkTreeModel *model;

    gtk_tree_selection_set_mode(selection, GTK_SELECTION_SINGLE);
    if (gtk_tree_selection_get_selected (selection, &model, &sf->iter))
        gtk_widget_set_sensitive (GTK_WIDGET (sf->remove), TRUE);
}
    
static void
add_right_clicked (GtkCellRenderer *renderer, gchar *arg1, ShareFolder *sf )
{
    gboolean right = FALSE;
    SharedUser *usr = NULL;
    EShUsers *user = NULL;
    char *email = NULL;
    GtkTreePath *path = NULL;

    path = gtk_tree_path_new_from_string (arg1);
    if (!gtk_tree_model_get_iter ((GtkTreeModel *) sf->model, &(sf->iter), path)){
        gtk_tree_path_free (path);
        return ;
    }
    gtk_tree_model_get ((GtkTreeModel *) sf->model, &(sf->iter), 0, &email, 1, &right , -1);
    usr = find_node(sf->users_list, email);
    if (!usr) {
        gtk_tree_path_free (path);
        return;
    }
    if(! usr->flag)  /* if user was already existing one change the flag to update*/
        usr->flag = usr->flag | 0x2;    
    user = usr->user_node;
    if (!right) {
        user->rights |= 0x1;    
        gtk_list_store_set (GTK_LIST_STORE (sf->model), &(sf->iter), 1, TRUE, -1);      
    } else {
        user->rights &= 0x6;    
        gtk_list_store_set (GTK_LIST_STORE (sf->model), &(sf->iter), 1, FALSE, -1);
    }
    gtk_tree_path_free (path);
}

static void
edit_right_clicked(GtkCellRenderer *renderer, gchar *arg1, ShareFolder *sf )
{
    gboolean right = FALSE;
    SharedUser *usr = NULL;
    EShUsers *user = NULL;
    char *email = NULL;
    GtkTreePath *path = NULL;

    path = gtk_tree_path_new_from_string (arg1);
    if (!gtk_tree_model_get_iter ((GtkTreeModel *) sf->model, &(sf->iter), path)) {
        gtk_tree_path_free (path);
        return;
    }
    gtk_tree_model_get ((GtkTreeModel *) sf->model, &(sf->iter), 0, &email, 2, &right , -1);
    usr = find_node(sf->users_list, email);
    if (!usr) {
        gtk_tree_path_free (path);
        return;
    }
    if(! usr->flag)  /* if user was already existing one change the flag to update*/
        usr->flag = usr->flag | 0x2;    
    user = usr->user_node;

    if (!right) {
        user->rights |= 0x2;    
        gtk_list_store_set (GTK_LIST_STORE (sf->model), &(sf->iter), 2, TRUE, -1);      
    } else {
        user->rights &= 0x5;    
        gtk_list_store_set (GTK_LIST_STORE (sf->model), &(sf->iter), 2, FALSE, -1);
    }
    gtk_tree_path_free (path);
}

static void
delete_right_clicked(GtkCellRenderer *renderer, gchar *arg1, ShareFolder *sf )
{
    gboolean right = FALSE;
    SharedUser *usr = NULL;
    EShUsers *user = NULL;
    char *email = NULL;
    GtkTreePath *path = NULL;

    path = gtk_tree_path_new_from_string (arg1);
    if (!gtk_tree_model_get_iter ((GtkTreeModel *) sf->model, &(sf->iter), path)) {
        gtk_tree_path_free (path);
        return;
    }
    gtk_tree_model_get ((GtkTreeModel *) sf->model, &(sf->iter), 0, &email, 3, &right , -1);
    usr = find_node(sf->users_list, email);
    if (!usr) {
        gtk_tree_path_free (path);
        return;
    }
    if(! usr->flag)  /* if user was already existing one change the flag to update*/
        usr->flag = usr->flag | 0x2;    
    user = usr->user_node;
    if (!right) {
        user->rights |= 0x4;    
        gtk_list_store_set (GTK_LIST_STORE (sf->model), &(sf->iter), 3, TRUE, -1);      
    } else {
        user->rights &= 0x3;    
        gtk_list_store_set (GTK_LIST_STORE (sf->model), &(sf->iter), 3, FALSE, -1);
    }
    gtk_tree_path_free (path);
}

static void 
share_folder_construct (ShareFolder *sf)
{
    GladeXML *xml;
    ENameSelectorDialog *name_selector_dialog;
    ENameSelectorModel *name_selector_model;
    ENameSelectorEntry *name_selector_entry;
    GtkWidget *box;
    char *gladefile;

    gladefile = g_build_filename (EVOLUTION_GLADEDIR,
                      "properties.glade",
                      NULL);
    xml = glade_xml_new (gladefile, ROOTNODE, NULL);
    g_free (gladefile);

    sf->xml =xml; 

    if (!sf->xml) {
        g_warning ("could not get xml");
    }
    sf->vbox = GTK_VBOX (glade_xml_get_widget(sf->xml, "vboxSharing"));
    sf->table = GTK_VBOX (glade_xml_get_widget (sf->xml, "vbox194"));
    gtk_widget_set_sensitive (GTK_WIDGET (sf->table), FALSE);

    sf->shared = GTK_RADIO_BUTTON (glade_xml_get_widget (sf->xml, "radShared"));
    g_signal_connect ((gpointer) sf->shared, "clicked", G_CALLBACK (shared_clicked), sf);

    sf->not_shared = GTK_RADIO_BUTTON (glade_xml_get_widget (sf->xml, "radNotShared"));
    g_signal_connect ((gpointer) sf->not_shared, "clicked", G_CALLBACK (not_shared_clicked), sf);

    sf->add_book = GTK_BUTTON (glade_xml_get_widget (sf->xml, "Address"));
    gtk_widget_set_sensitive (GTK_WIDGET (sf->add_book), TRUE);
    g_signal_connect((GtkWidget *) sf->add_book, "clicked", G_CALLBACK (address_button_clicked_cb), sf);

    sf->name_selector = e_name_selector_new ();
    name_selector_dialog = e_name_selector_peek_dialog (sf->name_selector);
    g_signal_connect (name_selector_dialog, "response",
            G_CALLBACK (addressbook_dialog_response), sf);

    name_selector_model = e_name_selector_peek_model (sf->name_selector);
    e_name_selector_model_add_section (name_selector_model, "Add User", "Add User", NULL);

    name_selector_entry = e_name_selector_peek_section_entry (sf->name_selector, "Add User");
    g_signal_connect (name_selector_entry, "changed",
            G_CALLBACK (addressbook_entry_changed), sf);

    sf->add_button = GTK_BUTTON (glade_xml_get_widget(sf->xml, "Add"));
    g_signal_connect((GtkWidget *) sf->add_button, "clicked", G_CALLBACK (add_clicked), sf);

    sf->remove = GTK_BUTTON(glade_xml_get_widget(sf->xml, "Remove"));
    g_signal_connect ((GtkWidget *) sf->remove, "clicked", G_CALLBACK (remove_clicked), sf);
    gtk_widget_set_sensitive(GTK_WIDGET (sf->remove), FALSE);

    sf->notification = GTK_BUTTON (glade_xml_get_widget (sf->xml, "Notification"));
    g_signal_connect((GtkWidget *) sf->notification, "clicked", G_CALLBACK (notification_clicked), sf);

    sf->name = GTK_ENTRY (glade_xml_get_widget (sf->xml, "entry4"));
        /*TODO:connect name and label*/
    gtk_widget_hide (GTK_WIDGET(sf->name));
    box = GTK_WIDGET (glade_xml_get_widget (sf->xml, "hbox227"));
    gtk_box_pack_start (GTK_BOX (box), (GtkWidget *) name_selector_entry, TRUE, TRUE, 0);
    gtk_widget_show ((GtkWidget *) name_selector_entry);

    sf->scrolled_window = GTK_WIDGET (glade_xml_get_widget (sf->xml,"scrolledwindow4"));

    gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (sf->scrolled_window), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);

    sf->model = gtk_list_store_new (4, G_TYPE_STRING, G_TYPE_BOOLEAN, G_TYPE_BOOLEAN, G_TYPE_BOOLEAN);
    sf->user_list = (GtkTreeView *)gtk_tree_view_new ();
    gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW (sf->scrolled_window), (GtkWidget *)sf->user_list);
    gtk_tree_view_set_model (GTK_TREE_VIEW (sf->user_list), GTK_TREE_MODEL (sf->model));
    gtk_widget_show (GTK_WIDGET (sf->user_list));

    sf->cell = gtk_cell_renderer_text_new ();
    sf->column = gtk_tree_view_column_new_with_attributes (_("Users"), sf->cell, "text", 0, NULL);
    gtk_tree_view_append_column (GTK_TREE_VIEW (sf->user_list),
            GTK_TREE_VIEW_COLUMN (sf->column));

    sf->cell = gtk_cell_renderer_toggle_new ();
    sf->column = gtk_tree_view_column_new_with_attributes (_("Add   "), sf->cell, "active" , 1, NULL);
    gtk_tree_view_append_column (GTK_TREE_VIEW (sf->user_list),
            GTK_TREE_VIEW_COLUMN (sf->column));
    g_signal_connect (sf->cell, "toggled", G_CALLBACK (add_right_clicked), sf);
    
    sf->cell = gtk_cell_renderer_toggle_new ();
    sf->column = gtk_tree_view_column_new_with_attributes (_("Modify"), sf->cell, "active", 2, NULL);
    gtk_tree_view_append_column (GTK_TREE_VIEW (sf->user_list),
            GTK_TREE_VIEW_COLUMN (sf->column));
    g_signal_connect (sf->cell, "toggled", G_CALLBACK (edit_right_clicked), sf);

    sf->cell = gtk_cell_renderer_toggle_new ();
    sf->column = gtk_tree_view_column_new_with_attributes (_("Delete"), sf->cell, "active", 3, NULL);
    gtk_tree_view_append_column (GTK_TREE_VIEW (sf->user_list),
            GTK_TREE_VIEW_COLUMN (sf->column));
    g_signal_connect (sf->cell, "toggled", G_CALLBACK (delete_right_clicked), sf);

    g_signal_connect(gtk_tree_view_get_selection(GTK_TREE_VIEW (sf->user_list)), "changed", G_CALLBACK (user_selected), sf);
}

ShareFolder *
share_folder_new (EGwConnection *ccnc, gchar *id)
{
    ShareFolder *new;
    new = (ShareFolder *) g_object_new (share_folder_get_type (), NULL);
    share_folder_construct (new);
    new->cnc = ccnc;
    new->container_id = id;
    if (ccnc && id)
    get_container_list(new);

    return (ShareFolder *) new;
}