- Added support for ADD/MODIFY/DELETE functionalities for Keyring and Kwallet
stores in the GUI. - Updated the Glade file with version info. ............................................................
This commit is contained in:
parent
bed0ba9d0f
commit
b8aedf332e
@ -26,7 +26,7 @@ using System.Runtime.CompilerServices;
|
|||||||
// You can specify all the values or you can default the Revision and Build Numbers
|
// You can specify all the values or you can default the Revision and Build Numbers
|
||||||
// by using the '*' as shown below:
|
// by using the '*' as shown below:
|
||||||
|
|
||||||
[assembly: AssemblyVersion("1.5.*")]
|
[assembly: AssemblyVersion("1.6.*")]
|
||||||
|
|
||||||
//
|
//
|
||||||
// In order to sign your assembly you must specify a key to use. Refer to the
|
// In order to sign your assembly you must specify a key to use. Refer to the
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
/// FILE : CasaMain.cs
|
/// FILE : CasaMain.cs
|
||||||
/// DESCRIPTION : The main class for CASA application.
|
/// DESCRIPTION : The main class for CASA application.
|
||||||
/// AUTHORS : Jim Norman, CSL.Manojna
|
/// AUTHORS : Jim Norman, CSL.Manojna
|
||||||
/// UPDATED ON : 26 Sept, 05
|
/// UPDATED ON : 03 Jan, 06
|
||||||
///#################################################################
|
///#################################################################
|
||||||
|
|
||||||
|
|
||||||
@ -39,9 +39,7 @@ namespace Novell.CASA.GUI
|
|||||||
#region Glade Widgets
|
#region Glade Widgets
|
||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
Gtk.Window windowMain,
|
Gtk.Window windowMain;
|
||||||
windowLog;
|
|
||||||
|
|
||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
Gtk.TreeView tvLog;
|
Gtk.TreeView tvLog;
|
||||||
@ -82,8 +80,7 @@ namespace Novell.CASA.GUI
|
|||||||
labelLoginContinue2;
|
labelLoginContinue2;
|
||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
Gtk.Button okbuttonPersistentStorage,
|
Gtk.Button okbuttonPersistentStorage;
|
||||||
buttonNovell;
|
|
||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
Gtk.MenuItem mmiNew,
|
Gtk.MenuItem mmiNew,
|
||||||
@ -99,8 +96,8 @@ namespace Novell.CASA.GUI
|
|||||||
mmiEdit,
|
mmiEdit,
|
||||||
mmiOptions,
|
mmiOptions,
|
||||||
mmiDebug;
|
mmiDebug;
|
||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
Gtk.CheckMenuItem mmiShowTaskIcon;
|
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
@ -142,7 +139,7 @@ namespace Novell.CASA.GUI
|
|||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
string message = "miCASA services are not available";
|
string message = "miCASA services are not available";
|
||||||
|
//Console.WriteLine("CasaMain: EXCEPTION= "+e.ToString());
|
||||||
if (m_bShowDebug)
|
if (m_bShowDebug)
|
||||||
message = e.ToString();
|
message = e.ToString();
|
||||||
|
|
||||||
@ -562,7 +559,7 @@ namespace Novell.CASA.GUI
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
mmiNew.Sensitive = true;
|
//mmiNew.Sensitive = true;
|
||||||
mmiNewKey.Sensitive = false;
|
mmiNewKey.Sensitive = false;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -576,22 +573,23 @@ namespace Novell.CASA.GUI
|
|||||||
case Common.STORE_KDEWALLET:
|
case Common.STORE_KDEWALLET:
|
||||||
if( 0 != objKdeWallet.tvSecretIDKdeWallet.Selection.CountSelectedRows() )
|
if( 0 != objKdeWallet.tvSecretIDKdeWallet.Selection.CountSelectedRows() )
|
||||||
{
|
{
|
||||||
mmiNew.Sensitive = false;
|
mmiNew.Sensitive = mmiNewKey.Sensitive = true;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
mmiNew.Sensitive = false;
|
mmiNewKey.Sensitive = false;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Common.STORE_GNOMEKEYRING:
|
case Common.STORE_GNOMEKEYRING:
|
||||||
if( 0 != objGnomeKeyring.tvSecretIDGnomeKeyring.Selection.CountSelectedRows() )
|
if( 0 != objGnomeKeyring.tvSecretIDGnomeKeyring.Selection.CountSelectedRows() )
|
||||||
{
|
{
|
||||||
mmiNew.Sensitive = false;
|
//mmiNew.Sensitive = mmiNewKey.Sensitive = true;
|
||||||
|
mmiNew.Sensitive = true;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
mmiNew.Sensitive = false;
|
mmiNewKey.Sensitive = false;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -631,8 +629,8 @@ namespace Novell.CASA.GUI
|
|||||||
case Common.STORE_KDEWALLET:
|
case Common.STORE_KDEWALLET:
|
||||||
if( 0 != objKdeWallet.tvSecretIDKdeWallet.Selection.CountSelectedRows() )
|
if( 0 != objKdeWallet.tvSecretIDKdeWallet.Selection.CountSelectedRows() )
|
||||||
{
|
{
|
||||||
mmiView.Sensitive = true;
|
mmiView.Sensitive = mmiDelete.Sensitive = true;
|
||||||
mmiLink.Sensitive = mmiCopy.Sensitive = mmiDelete.Sensitive = false;
|
mmiLink.Sensitive = mmiCopy.Sensitive = false;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -640,10 +638,11 @@ namespace Novell.CASA.GUI
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Common.STORE_GNOMEKEYRING: if( 0 != objGnomeKeyring.tvSecretIDGnomeKeyring.Selection.CountSelectedRows() )
|
case Common.STORE_GNOMEKEYRING:
|
||||||
|
if( 0 != objGnomeKeyring.tvSecretIDGnomeKeyring.Selection.CountSelectedRows() )
|
||||||
{
|
{
|
||||||
mmiView.Sensitive = true;
|
mmiView.Sensitive = mmiDelete.Sensitive = true;
|
||||||
mmiLink.Sensitive = mmiCopy.Sensitive = mmiDelete.Sensitive = false;
|
mmiLink.Sensitive = mmiCopy.Sensitive = false;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -745,9 +744,11 @@ namespace Novell.CASA.GUI
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case Common.STORE_KDEWALLET:
|
case Common.STORE_KDEWALLET:
|
||||||
|
objKdeWallet.OnNewSecretActivated(obj, args);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Common.STORE_GNOMEKEYRING:
|
case Common.STORE_GNOMEKEYRING:
|
||||||
|
objGnomeKeyring.OnNewSecretActivated(obj, args);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -779,9 +780,11 @@ namespace Novell.CASA.GUI
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case Common.STORE_KDEWALLET:
|
case Common.STORE_KDEWALLET:
|
||||||
|
objKdeWallet.OnNewKeyActivated(obj, args);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Common.STORE_GNOMEKEYRING:
|
case Common.STORE_GNOMEKEYRING:
|
||||||
|
objGnomeKeyring.OnNewKeyActivated(obj, args);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -862,11 +865,11 @@ namespace Novell.CASA.GUI
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case Common.STORE_FIREFOX:
|
case Common.STORE_FIREFOX:
|
||||||
objFirefox.ViewKeyValues();
|
//objFirefox.ViewKeyValues();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Common.STORE_MOZILLA:
|
case Common.STORE_MOZILLA:
|
||||||
objMozilla.ViewKeyValues();
|
//objMozilla.ViewKeyValues();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Common.STORE_KDEWALLET:
|
case Common.STORE_KDEWALLET:
|
||||||
@ -958,9 +961,11 @@ namespace Novell.CASA.GUI
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case Common.STORE_KDEWALLET:
|
case Common.STORE_KDEWALLET:
|
||||||
|
objKdeWallet.OnDeleteActivated(obj, args);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Common.STORE_GNOMEKEYRING:
|
case Common.STORE_GNOMEKEYRING:
|
||||||
|
objGnomeKeyring.OnDeleteActivated(obj, args);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1230,7 +1235,7 @@ namespace Novell.CASA.GUI
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void PromptUserForStartup()
|
internal void PromptUserForStartup()
|
||||||
{
|
{
|
||||||
// prompt user
|
// prompt user
|
||||||
MessageDialog md=new MessageDialog(null,Gtk.DialogFlags.Modal,
|
MessageDialog md=new MessageDialog(null,Gtk.DialogFlags.Modal,
|
||||||
|
@ -68,7 +68,7 @@ public class Common
|
|||||||
|
|
||||||
//Limits
|
//Limits
|
||||||
public static int MAX_ARRAY_ELEMENTS = 10;
|
public static int MAX_ARRAY_ELEMENTS = 10;
|
||||||
public static int MAX_NATIVE_ELEMENTS = 5;
|
public static int MAX_NATIVE_ELEMENTS = 8;
|
||||||
|
|
||||||
public static string NATIVEINFO_FOLDERNAME = "Folder Name";
|
public static string NATIVEINFO_FOLDERNAME = "Folder Name";
|
||||||
public static string NATIVEINFO_TYPEID = "Type of Secret";
|
public static string NATIVEINFO_TYPEID = "Type of Secret";
|
||||||
@ -80,7 +80,10 @@ public class Common
|
|||||||
INDEX_NATIVEINFO_TYPEID = 1,
|
INDEX_NATIVEINFO_TYPEID = 1,
|
||||||
INDEX_NATIVEINFO_SYNC = 2,
|
INDEX_NATIVEINFO_SYNC = 2,
|
||||||
INDEX_NATIVEINFO_SYNCTYPE = 3,
|
INDEX_NATIVEINFO_SYNCTYPE = 3,
|
||||||
INDEX_NATIVEINFO_MODIFIEDTIME = 4;
|
INDEX_NATIVEINFO_MODIFIEDTIME = 4,
|
||||||
|
INDEX_NATIVEINFO_ACCESSEDTIME = 5,
|
||||||
|
INDEX_NATIVEINFO_CREATEDTIME = 6,
|
||||||
|
INDEX_NATIVEINFO_WALLETLASTACCESSEDTIME = 7;
|
||||||
|
|
||||||
|
|
||||||
public static string LINUX_HELP_PATH = "file:///opt/novell/CASA/help/";
|
public static string LINUX_HELP_PATH = "file:///opt/novell/CASA/help/";
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
/// FILE : GnomeKeyring.cs
|
/// FILE : GnomeKeyring.cs
|
||||||
/// DESCRIPTION : GUI implementation of GNOME-Keyring store.
|
/// DESCRIPTION : GUI implementation of GNOME-Keyring store.
|
||||||
/// AUTHORS : CSL.Manojna
|
/// AUTHORS : CSL.Manojna
|
||||||
/// UPDATED ON : 26 Sept, 05
|
/// UPDATED ON : 03 Jan, 06
|
||||||
///#################################################################
|
///#################################################################
|
||||||
|
|
||||||
|
|
||||||
@ -11,6 +11,8 @@ namespace Novell.CASA.GUI {
|
|||||||
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
|
using System.Collections;
|
||||||
|
using System.Collections.Specialized;
|
||||||
using Gtk;
|
using Gtk;
|
||||||
using Glade;
|
using Glade;
|
||||||
using Novell.CASA.MiCasa.Common;
|
using Novell.CASA.MiCasa.Common;
|
||||||
@ -26,11 +28,15 @@ public class GnomeKeyring : Store
|
|||||||
|
|
||||||
CellRendererText cellEditable;
|
CellRendererText cellEditable;
|
||||||
|
|
||||||
|
ArrayList arrDeletedKeys = null;
|
||||||
|
|
||||||
public bool IS_STORE_AGGREGATED = false;
|
public bool IS_STORE_AGGREGATED = false;
|
||||||
|
|
||||||
#region Glade Widgets
|
#region Glade Widgets
|
||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
|
public Gtk.Window windowMain;
|
||||||
|
|
||||||
public Gtk.TreeView tvSecretIDGnomeKeyring;
|
public Gtk.TreeView tvSecretIDGnomeKeyring;
|
||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
@ -38,7 +44,9 @@ public class GnomeKeyring : Store
|
|||||||
tvNativeInfoGnomeKeyring;
|
tvNativeInfoGnomeKeyring;
|
||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
Gtk.Dialog dialogManageSecret,
|
Gtk.Dialog dialogNewSecret,
|
||||||
|
dialogManageSecret,
|
||||||
|
dialogConfirmDelete,
|
||||||
dialogLogin;
|
dialogLogin;
|
||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
@ -49,7 +57,8 @@ public class GnomeKeyring : Store
|
|||||||
entryKey,
|
entryKey,
|
||||||
entryValue,
|
entryValue,
|
||||||
entryMasterPassword3,
|
entryMasterPassword3,
|
||||||
entryMasterPassword4;
|
entryMasterPassword4,
|
||||||
|
entryDeleteSecretID;
|
||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
Gtk.CheckButton cbuttonShowPassword;
|
Gtk.CheckButton cbuttonShowPassword;
|
||||||
@ -60,8 +69,8 @@ public class GnomeKeyring : Store
|
|||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
Gtk.Button buttonNewAdd,
|
Gtk.Button buttonNewAdd,
|
||||||
buttonNewRemove,
|
buttonNewRemove;
|
||||||
buttonManageOk;
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
Gtk.MenuItem cmiNewSecret,
|
Gtk.MenuItem cmiNewSecret,
|
||||||
cmiNewKey,
|
cmiNewKey,
|
||||||
@ -188,8 +197,9 @@ public class GnomeKeyring : Store
|
|||||||
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "menuRightClick", null);
|
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "menuRightClick", null);
|
||||||
gxmlTemp.Autoconnect (this);
|
gxmlTemp.Autoconnect (this);
|
||||||
menuRightClick.Popup(null, null, null, IntPtr.Zero, 3, Gtk.Global.CurrentEventTime);
|
menuRightClick.Popup(null, null, null, IntPtr.Zero, 3, Gtk.Global.CurrentEventTime);
|
||||||
|
|
||||||
if( 0 != tvSecretIDGnomeKeyring.Selection.CountSelectedRows() )
|
if( 0 != tvSecretIDGnomeKeyring.Selection.CountSelectedRows() )
|
||||||
cmiNewSecret.Sensitive = cmiNewKey.Sensitive = cmiLink.Sensitive = cmiCopy.Sensitive = cmiDelete.Sensitive = false;
|
cmiLink.Sensitive = cmiCopy.Sensitive = false;
|
||||||
else
|
else
|
||||||
cmiNewSecret.Sensitive = cmiNewKey.Sensitive = cmiView.Sensitive = cmiLink.Sensitive = cmiCopy.Sensitive = cmiDelete.Sensitive = false;
|
cmiNewSecret.Sensitive = cmiNewKey.Sensitive = cmiView.Sensitive = cmiLink.Sensitive = cmiCopy.Sensitive = cmiDelete.Sensitive = false;
|
||||||
}
|
}
|
||||||
@ -219,6 +229,11 @@ public class GnomeKeyring : Store
|
|||||||
values = null;
|
values = null;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
if( null == arrDeletedKeys )
|
||||||
|
arrDeletedKeys = new ArrayList();
|
||||||
|
else
|
||||||
|
arrDeletedKeys.Clear();
|
||||||
|
|
||||||
if( tvSecretIDGnomeKeyring.Selection.GetSelected (out model, out iter) )
|
if( tvSecretIDGnomeKeyring.Selection.GetSelected (out model, out iter) )
|
||||||
{
|
{
|
||||||
selected = (string) model.GetValue(iter, 0);
|
selected = (string) model.GetValue(iter, 0);
|
||||||
@ -228,25 +243,28 @@ public class GnomeKeyring : Store
|
|||||||
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "dialogManageSecret", null);
|
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "dialogManageSecret", null);
|
||||||
gxmlTemp.Autoconnect (this);
|
gxmlTemp.Autoconnect (this);
|
||||||
dialogManageSecret.TransientFor = (Gtk.Window)CasaMain.gxml.GetWidget("windowMain");
|
dialogManageSecret.TransientFor = (Gtk.Window)CasaMain.gxml.GetWidget("windowMain");
|
||||||
dialogManageSecret.Title = "VIEW";
|
dialogManageSecret.Title = "GnomeKeyring - Manage Secret";
|
||||||
|
|
||||||
cellEditable = new CellRendererText();
|
cellEditable = new CellRendererText();
|
||||||
cellEditable.Editable = false;
|
cellEditable.Editable = true;
|
||||||
//cellEditable.Edited += new EditedHandler(OnKeyValueEdited);
|
cellEditable.Edited += new EditedHandler(OnKeyValueEdited);
|
||||||
/// KEY:0 VALUE:1 VALUE-DUP:2 DIRTY-BIT:3
|
/// KEY:0 VALUE:1 VALUE-DUP:2 DIRTY-BIT:3 LINK:4
|
||||||
tsKeyValue = new TreeStore(typeof(string),typeof(string), typeof(string), typeof(bool));
|
tsKeyValue = new TreeStore(typeof(string),typeof(string), typeof(string), typeof(bool), typeof(string));
|
||||||
tvKeyValue.AppendColumn("Key",new CellRendererText(),"text",0);
|
tvKeyValue.AppendColumn("Key",new CellRendererText(),"text",0);
|
||||||
tvKeyValue.AppendColumn("Value",cellEditable,"text",2);
|
tvKeyValue.AppendColumn("Value",cellEditable,"text",2);
|
||||||
|
tvKeyValue.AppendColumn("Linked", new CellRendererText(), "text", 4);
|
||||||
|
|
||||||
entrySecretID.Text=selected;
|
entrySecretID.Text=selected;
|
||||||
|
|
||||||
for( int i=0; i< keys.Length; i++ )
|
for( int i=0; i< keys.Length; i++ )
|
||||||
{
|
{
|
||||||
if( (null != keys[i]) && (null != values[i]) )
|
if( (null != keys[i]) && (null != values[i]) )
|
||||||
tsKeyValue.AppendValues(keys[i], values[i], "********", false);
|
tsKeyValue.AppendValues(keys[i], values[i], "********", false, "No");
|
||||||
|
|
||||||
}
|
}
|
||||||
tvKeyValue.Model = tsKeyValue;
|
tvKeyValue.Model = tsKeyValue;
|
||||||
entryKey.Sensitive = entryValue.Sensitive = buttonNewAdd.Sensitive = buttonNewRemove.Sensitive = buttonManageOk.Sensitive = false;
|
//entryKey.HasFocus = true;
|
||||||
|
entryKey.Sensitive = entryValue.Sensitive = buttonNewAdd.Sensitive = buttonNewRemove.Sensitive = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch(Exception exp)
|
catch(Exception exp)
|
||||||
@ -263,15 +281,110 @@ public class GnomeKeyring : Store
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public void OnKeyValueEdited(object obj, EditedArgs args)
|
public void OnKeyValueEdited(object obj, EditedArgs args)
|
||||||
{
|
{
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.OnKeyValueEdited() - BEGIN");
|
||||||
|
|
||||||
|
TreeModel model;
|
||||||
|
TreeIter iter;
|
||||||
|
object val;
|
||||||
|
string KeyName = null,
|
||||||
|
KeyValue = null;
|
||||||
|
string[] Keys = null,
|
||||||
|
Values = null;
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
tvKeyValue.Selection.GetSelected (out model, out iter);
|
||||||
|
val = tsKeyValue.GetValue(iter,0);
|
||||||
|
KeyName = val.ToString();
|
||||||
|
if( true == cbuttonShowPassword.Active )
|
||||||
|
val = tsKeyValue.GetValue(iter,1);
|
||||||
|
else
|
||||||
|
val = tsKeyValue.GetValue(iter,2);
|
||||||
|
KeyValue = val.ToString();
|
||||||
|
|
||||||
|
tvSecretIDGnomeKeyring.Selection.GetSelected (out model, out iter);
|
||||||
|
|
||||||
|
if( false == entrySecretID.Editable )
|
||||||
|
{
|
||||||
|
if( ("" != args.NewText) && (KeyValue != args.NewText) )
|
||||||
|
if( Common.STATUS_SUCCESS == StoreDataInterface.UpdateStore(Common.STORE_GNOMEKEYRING, Common.OPERATION_MODIFY_KEY, KeyName, args.NewText, ref model, ref iter) )
|
||||||
|
{
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.OnKeyValueEdited() - StoreDataInterface.UpdateStore() succeeded");
|
||||||
|
tvKeyValue.Selection.GetSelected (out model, out iter);
|
||||||
|
tsKeyValue.SetValue(iter, 1, args.NewText);
|
||||||
|
tsKeyValue.SetValue(iter, 2, "********");
|
||||||
|
|
||||||
|
tvSecretIDGnomeKeyring.Selection.GetSelected (out model, out iter);
|
||||||
|
Keys = (string[]) model.GetValue(iter, 1);
|
||||||
|
Values = (string[]) model.GetValue(iter, 2);
|
||||||
|
for( int i=0; i< Keys.Length; i++ )
|
||||||
|
{
|
||||||
|
if( Keys[i] == KeyName )
|
||||||
|
{
|
||||||
|
Values[i] = args.NewText;
|
||||||
|
tsSecretIDGnomeKeyring.SetValue(iter, 2, Values);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
AggregateStore();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.OnKeyValueEdited() - ERROR: STATUS_STORE_UPDATEFAILED");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
tvKeyValue.Selection.GetSelected (out model, out iter);
|
||||||
|
tsKeyValue.SetValue(iter, 1, args.NewText);
|
||||||
|
tsKeyValue.SetValue(iter, 2, "********");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception exp)
|
||||||
|
{
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.OnKeyValueEdited() - EXCEPTION:" + exp.ToString());
|
||||||
|
}
|
||||||
|
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.OnKeyValueEdited() - END");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// ADD BUTTON CLICKED
|
/// ADD BUTTON CLICKED
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public void on_buttonNewAdd_clicked(object obj, EventArgs args)
|
public void on_buttonNewAdd_clicked(object obj, EventArgs args)
|
||||||
{
|
{
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonNewAdd_clicked() - BEGIN");
|
||||||
|
|
||||||
|
if( ("" != entryKey.Text) && ("" != entryValue.Text) )
|
||||||
|
{
|
||||||
|
TreeIter iterKey;
|
||||||
|
ArrayList arrKeys = null,
|
||||||
|
arrValues = null;
|
||||||
|
object val = null;
|
||||||
|
arrKeys = new ArrayList();
|
||||||
|
arrValues = new ArrayList();
|
||||||
|
|
||||||
|
if(tsKeyValue.GetIterFirst(out iterKey))
|
||||||
|
{
|
||||||
|
do
|
||||||
|
{
|
||||||
|
val = tsKeyValue.GetValue(iterKey,0);
|
||||||
|
arrKeys.Add(val.ToString());
|
||||||
|
val = tsKeyValue.GetValue(iterKey,1);
|
||||||
|
arrValues.Add(val.ToString());
|
||||||
|
}
|
||||||
|
while( tsKeyValue.IterNext(ref iterKey) );
|
||||||
|
}
|
||||||
|
if( -1 == (arrKeys.IndexOf(entryKey.Text)) )
|
||||||
|
iterKey = tsKeyValue.AppendValues(entryKey.Text, entryValue.Text, "********", true, "No");
|
||||||
|
|
||||||
|
//tvKeyValue.Selection.SelectIter(iterKey);
|
||||||
|
entryKey.Text = entryValue.Text = "";
|
||||||
|
entryKey.HasFocus = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonNewAdd_clicked() - END");
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -279,7 +392,26 @@ public class GnomeKeyring : Store
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public void on_buttonNewRemove_clicked(object obj, EventArgs args)
|
public void on_buttonNewRemove_clicked(object obj, EventArgs args)
|
||||||
{
|
{
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonNewRemove_clicked() - BEGIN");
|
||||||
|
|
||||||
|
TreeModel modelKey;
|
||||||
|
TreeIter iterKey;
|
||||||
|
|
||||||
|
if(tvKeyValue.Selection.GetSelected (out modelKey, out iterKey))
|
||||||
|
if( false == (bool)tsKeyValue.GetValue(iterKey,3) )
|
||||||
|
arrDeletedKeys.Add(tsKeyValue.GetValue(iterKey,0));
|
||||||
|
|
||||||
|
if( 0 != tvKeyValue.Selection.CountSelectedRows() )
|
||||||
|
{
|
||||||
|
TreeModel model;
|
||||||
|
TreeIter iter;
|
||||||
|
|
||||||
|
tvKeyValue.Selection.GetSelected (out model, out iter);
|
||||||
|
tsKeyValue.Remove(ref iter);
|
||||||
|
tvKeyValue.ColumnsAutosize();
|
||||||
|
}
|
||||||
|
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonNewRemove_clicked() - END");
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -376,12 +508,82 @@ public class GnomeKeyring : Store
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// MANAGE SECRET-ID DIALOG OK-BUTTON CLICKED
|
/// MANAGE SECRET-ID DIALOG OK-BUTTON CLICKED
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public void on_buttonManageOk_clicked(object obj, EventArgs args)
|
public void on_buttonManageOk_clicked(object obj, EventArgs args)
|
||||||
{
|
{
|
||||||
|
TreeModel modelSecret;
|
||||||
|
TreeIter iterSecret,
|
||||||
|
iterKey;
|
||||||
|
string NewKey = null,
|
||||||
|
NewValue = null;
|
||||||
|
string[] strDeletedKeys = null;
|
||||||
|
bool dirtyBit = false;
|
||||||
|
//ArrayList arrKeys = null,
|
||||||
|
// arrValues = null;
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if( (0 == tvKeyValue.Model.IterNChildren()) && tvSecretIDGnomeKeyring.Selection.GetSelected (out modelSecret, out iterSecret) )
|
||||||
|
{
|
||||||
|
if( Common.STATUS_SUCCESS == StoreDataInterface.UpdateStore(Common.STORE_GNOMEKEYRING, Common.OPERATION_DELETE_SECRET, "", "", ref modelSecret, ref iterSecret) )
|
||||||
|
{
|
||||||
|
tsSecretIDGnomeKeyring.Remove(ref iterSecret);
|
||||||
|
tvSecretIDGnomeKeyring.ColumnsAutosize();
|
||||||
|
tsNativeInfoGnomeKeyring.Clear();
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonManageOk_clicked() - DELETE_SECRET_SUCCEEDED");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonManageOk_clicked() - DELETE_SECRET_FAILED");
|
||||||
|
AggregateStore();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if( (null != arrDeletedKeys) && (arrDeletedKeys.Count > 0) )
|
||||||
|
{
|
||||||
|
tvSecretIDGnomeKeyring.Selection.GetSelected (out modelSecret, out iterSecret);
|
||||||
|
strDeletedKeys = (string[])arrDeletedKeys.ToArray(typeof(string));
|
||||||
|
for( int i=0; i < strDeletedKeys.Length; i++)
|
||||||
|
{
|
||||||
|
if( Common.STATUS_SUCCESS == StoreDataInterface.UpdateStore(Common.STORE_GNOMEKEYRING, Common.OPERATION_DELETE_KEY, strDeletedKeys[i], null, ref modelSecret, ref iterSecret) )
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonManageOk_clicked() - DELETE_KEY_SUCCEEDED.");
|
||||||
|
else
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonManageOk_clicked() - DELETE_KEY_FAILED.");
|
||||||
|
}
|
||||||
|
arrDeletedKeys.Clear();
|
||||||
|
AggregateStore();
|
||||||
|
}
|
||||||
|
|
||||||
|
if( tsKeyValue.GetIterFirst(out iterKey) && tvSecretIDGnomeKeyring.Selection.GetSelected (out modelSecret, out iterSecret) )
|
||||||
|
{
|
||||||
|
do
|
||||||
|
{
|
||||||
|
NewKey = (string) tsKeyValue.GetValue(iterKey,0);
|
||||||
|
NewValue = (string) tsKeyValue.GetValue(iterKey,1);
|
||||||
|
dirtyBit = (bool) tsKeyValue.GetValue(iterKey,3);
|
||||||
|
|
||||||
|
if( true == dirtyBit )
|
||||||
|
{
|
||||||
|
if( Common.STATUS_SUCCESS == StoreDataInterface.UpdateStore(Common.STORE_GNOMEKEYRING, Common.OPERATION_ADD_KEY, NewKey, NewValue, ref modelSecret, ref iterSecret) )
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonManageOk_clicked() - ADD_KEY_VALUE_SUCCEEDED.");
|
||||||
|
else
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonManageOk_clicked() - ADD_KEY_VALUE_FAILED.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while( tsKeyValue.IterNext(ref iterKey) );
|
||||||
|
AggregateStore();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception exp)
|
||||||
|
{
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonManageOk_clicked() - EXCEPTION:" + exp.ToString());
|
||||||
|
}
|
||||||
|
|
||||||
|
tsKeyValue.Dispose();
|
||||||
|
dialogManageSecret.Destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -399,6 +601,7 @@ public class GnomeKeyring : Store
|
|||||||
private void OntvSecretIDGnomeKeyringRowActivated( object obj, RowActivatedArgs args )
|
private void OntvSecretIDGnomeKeyringRowActivated( object obj, RowActivatedArgs args )
|
||||||
{
|
{
|
||||||
Logger.DbgLog("GUI:GnomeKeyring.OntvSecretIDGnomeKeyringRowActivated() - ViewKeyValues() called.");
|
Logger.DbgLog("GUI:GnomeKeyring.OntvSecretIDGnomeKeyringRowActivated() - ViewKeyValues() called.");
|
||||||
|
|
||||||
ViewKeyValues();
|
ViewKeyValues();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -408,12 +611,12 @@ public class GnomeKeyring : Store
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public void OnViewActivated(object obj, EventArgs args)
|
public void OnViewActivated(object obj, EventArgs args)
|
||||||
{
|
{
|
||||||
Logger.DbgLog("GUI:KdeWallet.OnViewActivated() - ViewKeyValues() called.");
|
Logger.DbgLog("GUI:GnomeKeyring.OnViewActivated() - ViewKeyValues() called.");
|
||||||
|
|
||||||
ViewKeyValues();
|
ViewKeyValues();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///#######################################################################
|
///#######################################################################
|
||||||
/// ADD NEW SECRET
|
/// ADD NEW SECRET
|
||||||
|
|
||||||
@ -422,7 +625,27 @@ public class GnomeKeyring : Store
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public void OnNewSecretActivated(object obj, EventArgs args)
|
public void OnNewSecretActivated(object obj, EventArgs args)
|
||||||
{
|
{
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.OnNewSecretActivated() - BEGIN");
|
||||||
|
|
||||||
|
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "dialogNewSecret", null);
|
||||||
|
gxmlTemp.Autoconnect (this);
|
||||||
|
dialogNewSecret.TransientFor = (Gtk.Window)CasaMain.gxml.GetWidget("windowMain");
|
||||||
|
dialogNewSecret.Title = "GnomeKeyring - New Secret";
|
||||||
|
|
||||||
|
cellEditable = new CellRendererText();
|
||||||
|
cellEditable.Editable = true;
|
||||||
|
cellEditable.Edited += new EditedHandler(OnKeyValueEdited);
|
||||||
|
/// KEY:0 VALUE:1 VALUE-DUP:2 DIRTY-BIT:3 LINK:4
|
||||||
|
tsKeyValue = new TreeStore(typeof(string),typeof(string), typeof(string), typeof(bool), typeof(string));
|
||||||
|
tvKeyValue.AppendColumn("Key",new CellRendererText(),"text",0);
|
||||||
|
tvKeyValue.AppendColumn("Value",cellEditable,"text",2);
|
||||||
|
tvKeyValue.AppendColumn("Linked",new CellRendererText(),"text",4);
|
||||||
|
tvKeyValue.Model = tsKeyValue;
|
||||||
|
tsKeyValue.Clear();
|
||||||
|
entrySecretID.HasFocus = true;
|
||||||
|
entrySecretID.Text = "";
|
||||||
|
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.OnNewSecretActivated() - END");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -434,10 +657,131 @@ public class GnomeKeyring : Store
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public void OnNewKeyActivated(object obj, EventArgs args)
|
public void OnNewKeyActivated(object obj, EventArgs args)
|
||||||
{
|
{
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.OnNewKeyActivated() - BEGIN");
|
||||||
|
|
||||||
|
ViewKeyValues();
|
||||||
|
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.OnNewKeyActivated() - END");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public void on_buttonNewOk_clicked(object obj, EventArgs args)
|
||||||
|
{
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonNewOk_clicked() - BEGIN");
|
||||||
|
|
||||||
|
TreeModel modelSecret;
|
||||||
|
TreeIter iterSecret,
|
||||||
|
iterKey;
|
||||||
|
string NewKey = null,
|
||||||
|
NewValue = null;
|
||||||
|
string[] Keys = null,
|
||||||
|
Values = null,
|
||||||
|
NativeKeys = null,
|
||||||
|
NativeValues = null;
|
||||||
|
object val = null;
|
||||||
|
ArrayList arrKeys = null,
|
||||||
|
arrValues = null;
|
||||||
|
|
||||||
|
if ((true == entrySecretID.Editable) && (entrySecretID.Text.IndexOf("*") > -1))
|
||||||
|
{
|
||||||
|
// prompt user
|
||||||
|
MessageDialog md=new MessageDialog(this.windowMain,Gtk.DialogFlags.Modal,
|
||||||
|
Gtk.MessageType.Warning,
|
||||||
|
Gtk.ButtonsType.Ok,
|
||||||
|
"Secret ID may not contain \"*\"");
|
||||||
|
|
||||||
|
md.Response += new ResponseHandler(md_Response);
|
||||||
|
md.SetPosition(Gtk.WindowPosition.CenterOnParent);
|
||||||
|
md.Modal = true;
|
||||||
|
md.Show();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( (true == entrySecretID.Editable) && ("" != entrySecretID.Text) && (tvKeyValue.Model.IterNChildren() > 0) )
|
||||||
|
{
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonNewOk_clicked() - Adding New Secrets and KeyValues.");
|
||||||
|
|
||||||
|
arrKeys = new ArrayList();
|
||||||
|
arrValues = new ArrayList();
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if(tsKeyValue.GetIterFirst(out iterKey))
|
||||||
|
{
|
||||||
|
do
|
||||||
|
{
|
||||||
|
val = tsKeyValue.GetValue(iterKey,0);
|
||||||
|
NewKey = val.ToString();
|
||||||
|
val = tsKeyValue.GetValue(iterKey,1);
|
||||||
|
NewValue = val.ToString();
|
||||||
|
|
||||||
|
if( -1 == (arrKeys.IndexOf(NewKey)) )
|
||||||
|
{
|
||||||
|
arrKeys.Add(NewKey);
|
||||||
|
arrValues.Add(NewValue);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while( tsKeyValue.IterNext(ref iterKey) );
|
||||||
|
|
||||||
|
Keys = (string[])arrKeys.ToArray(typeof(string));
|
||||||
|
Values = (string[])arrValues.ToArray(typeof(string));
|
||||||
|
NativeKeys = new string[Common.MAX_NATIVE_ELEMENTS];
|
||||||
|
NativeValues = new string[Common.MAX_NATIVE_ELEMENTS];
|
||||||
|
NativeKeys[Common.INDEX_NATIVEINFO_FOLDERNAME] = Common.NATIVEINFO_FOLDERNAME;
|
||||||
|
NativeKeys[Common.INDEX_NATIVEINFO_TYPEID] = Common.NATIVEINFO_TYPEID;
|
||||||
|
NativeKeys[Common.INDEX_NATIVEINFO_SYNC] = Common.NATIVEINFO_SYNC;
|
||||||
|
NativeKeys[Common.INDEX_NATIVEINFO_SYNCTYPE] = Common.NATIVEINFO_SYNCTYPE;
|
||||||
|
NativeKeys[Common.INDEX_NATIVEINFO_MODIFIEDTIME] = Common.NATIVEINFO_MODIFIEDTIME;
|
||||||
|
NativeValues[Common.INDEX_NATIVEINFO_FOLDERNAME] = null;
|
||||||
|
NativeValues[Common.INDEX_NATIVEINFO_TYPEID] = "Network Password";
|
||||||
|
NativeValues[Common.INDEX_NATIVEINFO_SYNC] = null;
|
||||||
|
NativeValues[Common.INDEX_NATIVEINFO_SYNCTYPE] = null;
|
||||||
|
NativeValues[Common.INDEX_NATIVEINFO_MODIFIEDTIME] = null;
|
||||||
|
|
||||||
|
iterSecret = tsSecretIDGnomeKeyring.AppendValues(entrySecretID.Text, Keys, Values, "CASAkeyring", NativeKeys, NativeValues);
|
||||||
|
modelSecret = tvSecretIDGnomeKeyring.Model;
|
||||||
|
|
||||||
|
if( Common.STATUS_SUCCESS == StoreDataInterface.UpdateStore(Common.STORE_GNOMEKEYRING, Common.OPERATION_ADD_SECRET, "", "", ref modelSecret, ref iterSecret) )
|
||||||
|
{
|
||||||
|
AggregateStore();
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonNewOk_clicked() - ADD_NEW_SECRET_SUCCEEDED.");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonNewOk_clicked() - ERROR: ADD_NEW_SECRET_FAILED");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception exp)
|
||||||
|
{
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonNewOk_clicked() - EXCEPTION:" + exp.ToString());
|
||||||
|
}
|
||||||
|
tsKeyValue.Dispose();
|
||||||
|
dialogNewSecret.Destroy();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonNewOk_clicked() - END");
|
||||||
|
}
|
||||||
|
|
||||||
|
private void md_Response(object o, ResponseArgs args)
|
||||||
|
{
|
||||||
|
MessageDialog md = (MessageDialog)o;
|
||||||
|
if (md != null)
|
||||||
|
{
|
||||||
|
md.Destroy();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void on_buttonNewCancel_clicked(object obj, EventArgs args)
|
||||||
|
{
|
||||||
|
dialogNewSecret.Destroy();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void on_helpbuttonNewSecret_clicked(object obj, EventArgs args)
|
||||||
|
{
|
||||||
|
Common.ShowHelpUrl("AddNewSecrets.htm");
|
||||||
|
}
|
||||||
|
|
||||||
///#######################################################################
|
///#######################################################################
|
||||||
/// LINK
|
/// LINK
|
||||||
|
|
||||||
@ -470,8 +814,64 @@ public class GnomeKeyring : Store
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public void OnDeleteActivated(object obj, EventArgs args)
|
public void OnDeleteActivated(object obj, EventArgs args)
|
||||||
{
|
{
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.OnDeleteActivated() - BEGIN");
|
||||||
|
if( 0 != tvSecretIDGnomeKeyring.Selection.CountSelectedRows() )
|
||||||
|
{
|
||||||
|
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "dialogConfirmDelete", null);
|
||||||
|
gxmlTemp.Autoconnect (this);
|
||||||
|
dialogConfirmDelete.TransientFor = (Gtk.Window)CasaMain.gxml.GetWidget("windowMain");
|
||||||
|
dialogNewSecret.Title = "GnomeKeyring - Delete Secret";
|
||||||
|
|
||||||
|
TreeModel model;
|
||||||
|
TreeIter iter;
|
||||||
|
string selected = null;
|
||||||
|
if( tvSecretIDGnomeKeyring.Selection.GetSelected (out model, out iter) )
|
||||||
|
{
|
||||||
|
selected = (string) model.GetValue (iter, 0);
|
||||||
|
if( (null != selected) && (selected.Length > 0) )
|
||||||
|
entryDeleteSecretID.Text = selected;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.OnDeleteActivated() - END");
|
||||||
|
}
|
||||||
|
|
||||||
|
public void on_buttonYes_clicked(object obj, EventArgs args)
|
||||||
|
{
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonYes_clicked() - BEGIN");
|
||||||
|
|
||||||
|
TreeModel model;
|
||||||
|
TreeIter iter;
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if( tvSecretIDGnomeKeyring.Selection.GetSelected (out model, out iter) )
|
||||||
|
{
|
||||||
|
if( Common.STATUS_SUCCESS == StoreDataInterface.UpdateStore(Common.STORE_GNOMEKEYRING, Common.OPERATION_DELETE_SECRET, "", "", ref model, ref iter) )
|
||||||
|
{
|
||||||
|
tsSecretIDGnomeKeyring.Remove(ref iter);
|
||||||
|
tvSecretIDGnomeKeyring.ColumnsAutosize();
|
||||||
|
tsNativeInfoGnomeKeyring.Clear();
|
||||||
|
dialogConfirmDelete.Destroy();
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonYes_clicked() - DELETE_SECRET_SUCCEEDED");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonYes_clicked() - DELETE_SECRET_FAILED");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception exp)
|
||||||
|
{
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonYes_clicked() - EXCEPTION:" + exp.ToString());
|
||||||
|
}
|
||||||
|
|
||||||
|
Logger.DbgLog("GUI:GnomeKeyring.on_buttonYes_clicked() - END");
|
||||||
|
}
|
||||||
|
|
||||||
|
public void on_buttonNo_clicked(object obj, EventArgs args)
|
||||||
|
{
|
||||||
|
dialogConfirmDelete.Destroy();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public void on_buttonhelpEditSecret_clicked(object obj, EventArgs args)
|
public void on_buttonhelpEditSecret_clicked(object obj, EventArgs args)
|
||||||
{
|
{
|
||||||
|
@ -3,13 +3,15 @@
|
|||||||
/// FILE : KdeWallet.cs
|
/// FILE : KdeWallet.cs
|
||||||
/// DESCRIPTION : GUI implementation of KDE-Wallet store.
|
/// DESCRIPTION : GUI implementation of KDE-Wallet store.
|
||||||
/// AUTHORS : CSL.Manojna
|
/// AUTHORS : CSL.Manojna
|
||||||
/// UPDATED ON : 26 Sept, 05
|
/// UPDATED ON : 03 Jan, 06
|
||||||
///#################################################################
|
///#################################################################
|
||||||
|
|
||||||
|
|
||||||
namespace Novell.CASA.GUI {
|
namespace Novell.CASA.GUI {
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
|
using System.Collections;
|
||||||
|
using System.Collections.Specialized;
|
||||||
using Gtk;
|
using Gtk;
|
||||||
using Glade;
|
using Glade;
|
||||||
using Novell.CASA.MiCasa.Common;
|
using Novell.CASA.MiCasa.Common;
|
||||||
@ -24,11 +26,15 @@ public class KdeWallet : Store
|
|||||||
|
|
||||||
CellRendererText cellEditable;
|
CellRendererText cellEditable;
|
||||||
|
|
||||||
|
ArrayList arrDeletedKeys = null;
|
||||||
|
|
||||||
public bool IS_STORE_AGGREGATED = false;
|
public bool IS_STORE_AGGREGATED = false;
|
||||||
|
|
||||||
#region Glade Widgets
|
#region Glade Widgets
|
||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
|
public Gtk.Window windowMain;
|
||||||
|
|
||||||
public Gtk.TreeView tvSecretIDKdeWallet;
|
public Gtk.TreeView tvSecretIDKdeWallet;
|
||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
@ -36,7 +42,9 @@ public class KdeWallet : Store
|
|||||||
tvNativeInfoKdeWallet;
|
tvNativeInfoKdeWallet;
|
||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
Gtk.Dialog dialogManageSecret,
|
Gtk.Dialog dialogNewSecret,
|
||||||
|
dialogManageSecret,
|
||||||
|
dialogConfirmDelete,
|
||||||
dialogLogin;
|
dialogLogin;
|
||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
@ -47,7 +55,8 @@ public class KdeWallet : Store
|
|||||||
entryKey,
|
entryKey,
|
||||||
entryValue,
|
entryValue,
|
||||||
entryMasterPassword3,
|
entryMasterPassword3,
|
||||||
entryMasterPassword4;
|
entryMasterPassword4,
|
||||||
|
entryDeleteSecretID;
|
||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
Gtk.CheckButton cbuttonShowPassword;
|
Gtk.CheckButton cbuttonShowPassword;
|
||||||
@ -56,10 +65,6 @@ public class KdeWallet : Store
|
|||||||
Gtk.Label label86,
|
Gtk.Label label86,
|
||||||
label88;
|
label88;
|
||||||
|
|
||||||
[Glade.Widget]
|
|
||||||
Gtk.Button buttonNewAdd,
|
|
||||||
buttonNewRemove,
|
|
||||||
buttonManageOk;
|
|
||||||
|
|
||||||
[Glade.Widget]
|
[Glade.Widget]
|
||||||
Gtk.MenuItem cmiNewSecret,
|
Gtk.MenuItem cmiNewSecret,
|
||||||
@ -188,7 +193,7 @@ public class KdeWallet : Store
|
|||||||
menuRightClick.Popup(null, null, null, IntPtr.Zero, 3, Gtk.Global.CurrentEventTime);
|
menuRightClick.Popup(null, null, null, IntPtr.Zero, 3, Gtk.Global.CurrentEventTime);
|
||||||
|
|
||||||
if( 0 != tvSecretIDKdeWallet.Selection.CountSelectedRows() )
|
if( 0 != tvSecretIDKdeWallet.Selection.CountSelectedRows() )
|
||||||
cmiNewSecret.Sensitive = cmiNewKey.Sensitive = cmiLink.Sensitive = cmiCopy.Sensitive = cmiDelete.Sensitive = false;
|
cmiLink.Sensitive = cmiCopy.Sensitive = false;
|
||||||
else
|
else
|
||||||
cmiNewSecret.Sensitive = cmiNewKey.Sensitive = cmiView.Sensitive = cmiLink.Sensitive = cmiCopy.Sensitive = cmiDelete.Sensitive = false;
|
cmiNewSecret.Sensitive = cmiNewKey.Sensitive = cmiView.Sensitive = cmiLink.Sensitive = cmiCopy.Sensitive = cmiDelete.Sensitive = false;
|
||||||
}
|
}
|
||||||
@ -220,6 +225,11 @@ public class KdeWallet : Store
|
|||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
if( null == arrDeletedKeys )
|
||||||
|
arrDeletedKeys = new ArrayList();
|
||||||
|
else
|
||||||
|
arrDeletedKeys.Clear();
|
||||||
|
|
||||||
if( tvSecretIDKdeWallet.Selection.GetSelected (out model, out iter) )
|
if( tvSecretIDKdeWallet.Selection.GetSelected (out model, out iter) )
|
||||||
{
|
{
|
||||||
selected = (string) model.GetValue(iter, 0);
|
selected = (string) model.GetValue(iter, 0);
|
||||||
@ -229,23 +239,26 @@ public class KdeWallet : Store
|
|||||||
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "dialogManageSecret", null);
|
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "dialogManageSecret", null);
|
||||||
gxmlTemp.Autoconnect (this);
|
gxmlTemp.Autoconnect (this);
|
||||||
dialogManageSecret.TransientFor = (Gtk.Window)CasaMain.gxml.GetWidget("windowMain");
|
dialogManageSecret.TransientFor = (Gtk.Window)CasaMain.gxml.GetWidget("windowMain");
|
||||||
dialogManageSecret.Title = "VIEW";
|
dialogManageSecret.Title = "KdeWallet - Manage Secret";
|
||||||
|
|
||||||
cellEditable = new CellRendererText();
|
cellEditable = new CellRendererText();
|
||||||
cellEditable.Editable = false;
|
cellEditable.Editable = true;
|
||||||
//cellEditable.Edited += new EditedHandler(OnKeyValueEdited);
|
cellEditable.Edited += new EditedHandler(OnKeyValueEdited);
|
||||||
/// KEY:0 VALUE:1 VALUE-DUP:2 DIRTY-BIT:3
|
/// KEY:0 VALUE:1 VALUE-DUP:2 DIRTY-BIT:3 LINK:4
|
||||||
tsKeyValue = new TreeStore(typeof(string),typeof(string), typeof(string), typeof(bool));
|
tsKeyValue = new TreeStore(typeof(string),typeof(string), typeof(string), typeof(bool), typeof(string));
|
||||||
tvKeyValue.AppendColumn("Key",new CellRendererText(),"text",0);
|
tvKeyValue.AppendColumn("Key",new CellRendererText(),"text",0);
|
||||||
tvKeyValue.AppendColumn("Value",cellEditable,"text",2);
|
tvKeyValue.AppendColumn("Value",cellEditable,"text",2);
|
||||||
|
tvKeyValue.AppendColumn("Linked", new CellRendererText(), "text", 4);
|
||||||
|
|
||||||
entrySecretID.Text = selected;
|
entrySecretID.Text = selected;
|
||||||
|
|
||||||
for( int i=0; i< keys.Length; i++ )
|
for( int i=0; i< keys.Length; i++ )
|
||||||
{
|
{
|
||||||
if( (null != keys[i]) && (null != values[i]) )
|
if( (null != keys[i]) && (null != values[i]) )
|
||||||
tsKeyValue.AppendValues(keys[i], values[i], "********", false);
|
tsKeyValue.AppendValues(keys[i], values[i], "********", false, "No");
|
||||||
}
|
}
|
||||||
tvKeyValue.Model = tsKeyValue;
|
tvKeyValue.Model = tsKeyValue;
|
||||||
entryKey.Sensitive = entryValue.Sensitive = buttonNewAdd.Sensitive = buttonNewRemove.Sensitive = buttonManageOk.Sensitive = false;
|
entryKey.HasFocus = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch(Exception exp)
|
catch(Exception exp)
|
||||||
@ -262,15 +275,109 @@ public class KdeWallet : Store
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public void OnKeyValueEdited(object obj, EditedArgs args)
|
public void OnKeyValueEdited(object obj, EditedArgs args)
|
||||||
{
|
{
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.OnKeyValueEdited() - BEGIN");
|
||||||
|
|
||||||
|
TreeModel model;
|
||||||
|
TreeIter iter;
|
||||||
|
object val;
|
||||||
|
string KeyName = null,
|
||||||
|
KeyValue = null;
|
||||||
|
string[] Keys = null,
|
||||||
|
Values = null;
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
tvKeyValue.Selection.GetSelected (out model, out iter);
|
||||||
|
val = tsKeyValue.GetValue(iter,0);
|
||||||
|
KeyName = val.ToString();
|
||||||
|
if( true == cbuttonShowPassword.Active )
|
||||||
|
val = tsKeyValue.GetValue(iter,1);
|
||||||
|
else
|
||||||
|
val = tsKeyValue.GetValue(iter,2);
|
||||||
|
KeyValue = val.ToString();
|
||||||
|
|
||||||
|
tvSecretIDKdeWallet.Selection.GetSelected (out model, out iter);
|
||||||
|
|
||||||
|
if( false == entrySecretID.Editable )
|
||||||
|
{
|
||||||
|
if( ("" != args.NewText) && (KeyValue != args.NewText) )
|
||||||
|
if( Common.STATUS_SUCCESS == StoreDataInterface.UpdateStore(Common.STORE_KDEWALLET, Common.OPERATION_MODIFY_KEY, KeyName, args.NewText, ref model, ref iter) )
|
||||||
|
{
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.OnKeyValueEdited() - StoreDataInterface.UpdateStore() succeeded");
|
||||||
|
tvKeyValue.Selection.GetSelected (out model, out iter);
|
||||||
|
tsKeyValue.SetValue(iter, 1, args.NewText);
|
||||||
|
tsKeyValue.SetValue(iter, 2, "********");
|
||||||
|
|
||||||
|
tvSecretIDKdeWallet.Selection.GetSelected (out model, out iter);
|
||||||
|
Keys = (string[]) model.GetValue(iter, 1);
|
||||||
|
Values = (string[]) model.GetValue(iter, 2);
|
||||||
|
for( int i=0; i< Keys.Length; i++ )
|
||||||
|
{
|
||||||
|
if( Keys[i] == KeyName )
|
||||||
|
{
|
||||||
|
Values[i] = args.NewText;
|
||||||
|
tsSecretIDKdeWallet.SetValue(iter, 2, Values);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
AggregateStore();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.OnKeyValueEdited() - ERROR: STATUS_STORE_UPDATEFAILED");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
tvKeyValue.Selection.GetSelected (out model, out iter);
|
||||||
|
tsKeyValue.SetValue(iter, 1, args.NewText);
|
||||||
|
tsKeyValue.SetValue(iter, 2, "********");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception exp)
|
||||||
|
{
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.OnKeyValueEdited() - EXCEPTION:" + exp.ToString());
|
||||||
|
}
|
||||||
|
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.OnKeyValueEdited() - END");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// ADD BUTTON CLICKED
|
/// ADD BUTTON CLICKED
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public void on_buttonNewAdd_clicked(object obj, EventArgs args)
|
public void on_buttonNewAdd_clicked(object obj, EventArgs args)
|
||||||
{
|
{
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonNewAdd_clicked() - BEGIN");
|
||||||
|
|
||||||
|
if( ("" != entryKey.Text) && ("" != entryValue.Text) )
|
||||||
|
{
|
||||||
|
TreeIter iterKey;
|
||||||
|
ArrayList arrKeys = null,
|
||||||
|
arrValues = null;
|
||||||
|
object val = null;
|
||||||
|
arrKeys = new ArrayList();
|
||||||
|
arrValues = new ArrayList();
|
||||||
|
|
||||||
|
if(tsKeyValue.GetIterFirst(out iterKey))
|
||||||
|
{
|
||||||
|
do
|
||||||
|
{
|
||||||
|
val = tsKeyValue.GetValue(iterKey,0);
|
||||||
|
arrKeys.Add(val.ToString());
|
||||||
|
val = tsKeyValue.GetValue(iterKey,1);
|
||||||
|
arrValues.Add(val.ToString());
|
||||||
|
}
|
||||||
|
while( tsKeyValue.IterNext(ref iterKey) );
|
||||||
|
}
|
||||||
|
if( -1 == (arrKeys.IndexOf(entryKey.Text)) )
|
||||||
|
iterKey = tsKeyValue.AppendValues(entryKey.Text, entryValue.Text, "********", true, "No");
|
||||||
|
|
||||||
|
//tvKeyValue.Selection.SelectIter(iterKey);
|
||||||
|
entryKey.Text = entryValue.Text = "";
|
||||||
|
entryKey.HasFocus = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonNewAdd_clicked() - END");
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -278,7 +385,28 @@ public class KdeWallet : Store
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public void on_buttonNewRemove_clicked(object obj, EventArgs args)
|
public void on_buttonNewRemove_clicked(object obj, EventArgs args)
|
||||||
{
|
{
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonNewRemove_clicked() - BEGIN");
|
||||||
|
|
||||||
|
TreeModel modelKey;
|
||||||
|
TreeIter iterKey;
|
||||||
|
|
||||||
|
if(tvKeyValue.Selection.GetSelected (out modelKey, out iterKey))
|
||||||
|
if( false == (bool)tsKeyValue.GetValue(iterKey,3) )
|
||||||
|
arrDeletedKeys.Add(tsKeyValue.GetValue(iterKey,0));
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if( 0 != tvKeyValue.Selection.CountSelectedRows() )
|
||||||
|
{
|
||||||
|
TreeModel model;
|
||||||
|
TreeIter iter;
|
||||||
|
|
||||||
|
tvKeyValue.Selection.GetSelected (out model, out iter);
|
||||||
|
tsKeyValue.Remove(ref iter);
|
||||||
|
tvKeyValue.ColumnsAutosize();
|
||||||
|
}
|
||||||
|
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonNewRemove_clicked() - END");
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -374,12 +502,83 @@ public class KdeWallet : Store
|
|||||||
entryMasterPassword3.HasFocus = true;
|
entryMasterPassword3.HasFocus = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// MANAGE SECRET-ID DIALOG OK-BUTTON CLICKED
|
/// MANAGE SECRET-ID DIALOG OK-BUTTON CLICKED
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public void on_buttonManageOk_clicked(object obj, EventArgs args)
|
public void on_buttonManageOk_clicked(object obj, EventArgs args)
|
||||||
{
|
{
|
||||||
|
TreeModel modelSecret;
|
||||||
|
TreeIter iterSecret,
|
||||||
|
iterKey;
|
||||||
|
string NewKey = null,
|
||||||
|
NewValue = null;
|
||||||
|
string[] strDeletedKeys = null;
|
||||||
|
bool dirtyBit = false;
|
||||||
|
//ArrayList arrKeys = null,
|
||||||
|
// arrValues = null;
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if( (0 == tvKeyValue.Model.IterNChildren()) && tvSecretIDKdeWallet.Selection.GetSelected (out modelSecret, out iterSecret) )
|
||||||
|
{
|
||||||
|
if( Common.STATUS_SUCCESS == StoreDataInterface.UpdateStore(Common.STORE_KDEWALLET, Common.OPERATION_DELETE_SECRET, "", "", ref modelSecret, ref iterSecret) )
|
||||||
|
{
|
||||||
|
tsSecretIDKdeWallet.Remove(ref iterSecret);
|
||||||
|
tvSecretIDKdeWallet.ColumnsAutosize();
|
||||||
|
tsNativeInfoKdeWallet.Clear();
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonManageOk_clicked() - DELETE_SECRET_SUCCEEDED");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonManageOk_clicked() - DELETE_SECRET_FAILED");
|
||||||
|
AggregateStore();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if( (null != arrDeletedKeys) && (arrDeletedKeys.Count > 0) )
|
||||||
|
{
|
||||||
|
tvSecretIDKdeWallet.Selection.GetSelected (out modelSecret, out iterSecret);
|
||||||
|
strDeletedKeys = (string[])arrDeletedKeys.ToArray(typeof(string));
|
||||||
|
for( int i=0; i < strDeletedKeys.Length; i++)
|
||||||
|
{
|
||||||
|
if( Common.STATUS_SUCCESS == StoreDataInterface.UpdateStore(Common.STORE_KDEWALLET, Common.OPERATION_DELETE_KEY, strDeletedKeys[i], null, ref modelSecret, ref iterSecret) )
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonManageOk_clicked() - DELETE_KEY_SUCCEEDED.");
|
||||||
|
else
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonManageOk_clicked() - DELETE_KEY_FAILED.");
|
||||||
|
}
|
||||||
|
arrDeletedKeys.Clear();
|
||||||
|
AggregateStore();
|
||||||
|
}
|
||||||
|
|
||||||
|
if( tsKeyValue.GetIterFirst(out iterKey) && tvSecretIDKdeWallet.Selection.GetSelected (out modelSecret, out iterSecret) )
|
||||||
|
{
|
||||||
|
do
|
||||||
|
{
|
||||||
|
NewKey = (string) tsKeyValue.GetValue(iterKey,0);
|
||||||
|
NewValue = (string) tsKeyValue.GetValue(iterKey,1);
|
||||||
|
dirtyBit = (bool) tsKeyValue.GetValue(iterKey,3);
|
||||||
|
|
||||||
|
if( true == dirtyBit )
|
||||||
|
{
|
||||||
|
if( Common.STATUS_SUCCESS == StoreDataInterface.UpdateStore(Common.STORE_KDEWALLET, Common.OPERATION_ADD_KEY, NewKey, NewValue, ref modelSecret, ref iterSecret) )
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonManageOk_clicked() - ADD_KEY_VALUE_SUCCEEDED.");
|
||||||
|
else
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonManageOk_clicked() - ADD_KEY_VALUE_FAILED.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while( tsKeyValue.IterNext(ref iterKey) );
|
||||||
|
AggregateStore();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception exp)
|
||||||
|
{
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonManageOk_clicked() - EXCEPTION:" + exp.ToString());
|
||||||
|
}
|
||||||
|
|
||||||
|
tsKeyValue.Dispose();
|
||||||
|
dialogManageSecret.Destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -407,14 +606,11 @@ public class KdeWallet : Store
|
|||||||
public void OnViewActivated(object obj, EventArgs args)
|
public void OnViewActivated(object obj, EventArgs args)
|
||||||
{
|
{
|
||||||
Logger.DbgLog("GUI:KdeWallet.OnViewActivated() - ViewKeyValues() called.");
|
Logger.DbgLog("GUI:KdeWallet.OnViewActivated() - ViewKeyValues() called.");
|
||||||
|
|
||||||
ViewKeyValues();
|
ViewKeyValues();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///#######################################################################
|
///#######################################################################
|
||||||
/// ADD NEW SECRET
|
/// ADD NEW SECRET
|
||||||
|
|
||||||
@ -423,7 +619,27 @@ public class KdeWallet : Store
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public void OnNewSecretActivated(object obj, EventArgs args)
|
public void OnNewSecretActivated(object obj, EventArgs args)
|
||||||
{
|
{
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.OnNewSecretActivated() - BEGIN");
|
||||||
|
|
||||||
|
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "dialogNewSecret", null);
|
||||||
|
gxmlTemp.Autoconnect (this);
|
||||||
|
dialogNewSecret.TransientFor = (Gtk.Window)CasaMain.gxml.GetWidget("windowMain");
|
||||||
|
dialogNewSecret.Title = "KdeWallet - New Secret";
|
||||||
|
|
||||||
|
cellEditable = new CellRendererText();
|
||||||
|
cellEditable.Editable = true;
|
||||||
|
cellEditable.Edited += new EditedHandler(OnKeyValueEdited);
|
||||||
|
/// KEY:0 VALUE:1 VALUE-DUP:2 DIRTY-BIT:3 LINK:4
|
||||||
|
tsKeyValue = new TreeStore(typeof(string),typeof(string), typeof(string), typeof(bool), typeof(string));
|
||||||
|
tvKeyValue.AppendColumn("Key",new CellRendererText(),"text",0);
|
||||||
|
tvKeyValue.AppendColumn("Value",cellEditable,"text",2);
|
||||||
|
tvKeyValue.AppendColumn("Linked",new CellRendererText(),"text",4);
|
||||||
|
tvKeyValue.Model = tsKeyValue;
|
||||||
|
tsKeyValue.Clear();
|
||||||
|
entrySecretID.HasFocus = true;
|
||||||
|
entrySecretID.Text = "";
|
||||||
|
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.OnNewSecretActivated() - END");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -435,10 +651,128 @@ public class KdeWallet : Store
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public void OnNewKeyActivated(object obj, EventArgs args)
|
public void OnNewKeyActivated(object obj, EventArgs args)
|
||||||
{
|
{
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.OnNewKeyActivated() - BEGIN");
|
||||||
|
|
||||||
|
ViewKeyValues();
|
||||||
|
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.OnNewKeyActivated() - END");
|
||||||
|
}
|
||||||
|
|
||||||
|
public void on_buttonNewOk_clicked(object obj, EventArgs args)
|
||||||
|
{
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonNewOk_clicked() - BEGIN");
|
||||||
|
|
||||||
|
TreeModel modelSecret;
|
||||||
|
TreeIter iterSecret,
|
||||||
|
iterKey;
|
||||||
|
string NewKey = null,
|
||||||
|
NewValue = null;
|
||||||
|
string[] Keys = null,
|
||||||
|
Values = null,
|
||||||
|
NativeKeys = null,
|
||||||
|
NativeValues = null;
|
||||||
|
object val = null;
|
||||||
|
ArrayList arrKeys = null,
|
||||||
|
arrValues = null;
|
||||||
|
|
||||||
|
if ((true == entrySecretID.Editable) && (entrySecretID.Text.IndexOf("*") > -1))
|
||||||
|
{
|
||||||
|
// prompt user
|
||||||
|
MessageDialog md=new MessageDialog(this.windowMain,Gtk.DialogFlags.Modal,
|
||||||
|
Gtk.MessageType.Warning,
|
||||||
|
Gtk.ButtonsType.Ok,
|
||||||
|
"Secret ID may not contain \"*\"");
|
||||||
|
|
||||||
|
md.Response += new ResponseHandler(md_Response);
|
||||||
|
md.SetPosition(Gtk.WindowPosition.CenterOnParent);
|
||||||
|
md.Modal = true;
|
||||||
|
md.Show();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( (true == entrySecretID.Editable) && ("" != entrySecretID.Text) && (tvKeyValue.Model.IterNChildren() > 0) )
|
||||||
|
{
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonNewOk_clicked() - Adding New Secrets and KeyValues.");
|
||||||
|
|
||||||
|
arrKeys = new ArrayList();
|
||||||
|
arrValues = new ArrayList();
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if(tsKeyValue.GetIterFirst(out iterKey))
|
||||||
|
{
|
||||||
|
do
|
||||||
|
{
|
||||||
|
val = tsKeyValue.GetValue(iterKey,0);
|
||||||
|
NewKey = val.ToString();
|
||||||
|
val = tsKeyValue.GetValue(iterKey,1);
|
||||||
|
NewValue = val.ToString();
|
||||||
|
|
||||||
|
if( -1 == (arrKeys.IndexOf(NewKey)) )
|
||||||
|
{
|
||||||
|
arrKeys.Add(NewKey);
|
||||||
|
arrValues.Add(NewValue);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while( tsKeyValue.IterNext(ref iterKey) );
|
||||||
|
|
||||||
|
Keys = (string[])arrKeys.ToArray(typeof(string));
|
||||||
|
Values = (string[])arrValues.ToArray(typeof(string));
|
||||||
|
NativeKeys = new string[Common.MAX_NATIVE_ELEMENTS];
|
||||||
|
NativeValues = new string[Common.MAX_NATIVE_ELEMENTS];
|
||||||
|
NativeKeys[Common.INDEX_NATIVEINFO_FOLDERNAME] = Common.NATIVEINFO_FOLDERNAME;
|
||||||
|
NativeKeys[Common.INDEX_NATIVEINFO_TYPEID] = Common.NATIVEINFO_TYPEID;
|
||||||
|
NativeKeys[Common.INDEX_NATIVEINFO_SYNC] = Common.NATIVEINFO_SYNC;
|
||||||
|
NativeKeys[Common.INDEX_NATIVEINFO_SYNCTYPE] = Common.NATIVEINFO_SYNCTYPE;
|
||||||
|
NativeKeys[Common.INDEX_NATIVEINFO_MODIFIEDTIME] = Common.NATIVEINFO_MODIFIEDTIME;
|
||||||
|
NativeValues[Common.INDEX_NATIVEINFO_FOLDERNAME] = "Passwords";
|
||||||
|
NativeValues[Common.INDEX_NATIVEINFO_TYPEID] = "Maps";
|
||||||
|
NativeValues[Common.INDEX_NATIVEINFO_SYNC] = null;
|
||||||
|
NativeValues[Common.INDEX_NATIVEINFO_SYNCTYPE] = null;
|
||||||
|
NativeValues[Common.INDEX_NATIVEINFO_MODIFIEDTIME] = null;
|
||||||
|
|
||||||
|
iterSecret = tsSecretIDKdeWallet.AppendValues(entrySecretID.Text, Keys, Values, "CASAwallet", NativeKeys, NativeValues);
|
||||||
|
modelSecret = tvSecretIDKdeWallet.Model;
|
||||||
|
|
||||||
|
if( Common.STATUS_SUCCESS == StoreDataInterface.UpdateStore(Common.STORE_KDEWALLET, Common.OPERATION_ADD_SECRET, "", "", ref modelSecret, ref iterSecret) )
|
||||||
|
{
|
||||||
|
AggregateStore();
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonNewOk_clicked() - ADD_NEW_SECRET_SUCCEEDED.");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonNewOk_clicked() - ERROR: ADD_NEW_SECRET_FAILED");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception exp)
|
||||||
|
{
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonNewOk_clicked() - EXCEPTION:" + exp.ToString());
|
||||||
|
}
|
||||||
|
tsKeyValue.Dispose();
|
||||||
|
dialogNewSecret.Destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonNewOk_clicked() - END");
|
||||||
|
}
|
||||||
|
|
||||||
|
private void md_Response(object o, ResponseArgs args)
|
||||||
|
{
|
||||||
|
MessageDialog md = (MessageDialog)o;
|
||||||
|
if (md != null)
|
||||||
|
{
|
||||||
|
md.Destroy();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void on_buttonNewCancel_clicked(object obj, EventArgs args)
|
||||||
|
{
|
||||||
|
dialogNewSecret.Destroy();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void on_helpbuttonNewSecret_clicked(object obj, EventArgs args)
|
||||||
|
{
|
||||||
|
Common.ShowHelpUrl("AddNewSecrets.htm");
|
||||||
|
}
|
||||||
///#######################################################################
|
///#######################################################################
|
||||||
/// LINK
|
/// LINK
|
||||||
|
|
||||||
@ -464,14 +798,69 @@ public class KdeWallet : Store
|
|||||||
|
|
||||||
|
|
||||||
///#######################################################################
|
///#######################################################################
|
||||||
// DELETE SECRET
|
/// DELETE SECRET
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// DELETE Secret
|
/// DELETE Secret
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public void OnDeleteActivated(object obj, EventArgs args)
|
public void OnDeleteActivated(object obj, EventArgs args)
|
||||||
{
|
{
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.OnDeleteActivated() - BEGIN");
|
||||||
|
if( 0 != tvSecretIDKdeWallet.Selection.CountSelectedRows() )
|
||||||
|
{
|
||||||
|
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "dialogConfirmDelete", null);
|
||||||
|
gxmlTemp.Autoconnect (this);
|
||||||
|
dialogConfirmDelete.TransientFor = (Gtk.Window)CasaMain.gxml.GetWidget("windowMain");
|
||||||
|
dialogConfirmDelete.Title = "KdeWallet - Delete Secret";
|
||||||
|
|
||||||
|
TreeModel model;
|
||||||
|
TreeIter iter;
|
||||||
|
string selected = null;
|
||||||
|
if( tvSecretIDKdeWallet.Selection.GetSelected (out model, out iter) )
|
||||||
|
{
|
||||||
|
selected = (string) model.GetValue (iter, 0);
|
||||||
|
if( (null != selected) && (selected.Length > 0) )
|
||||||
|
entryDeleteSecretID.Text = selected;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.OnDeleteActivated() - END");
|
||||||
|
}
|
||||||
|
|
||||||
|
public void on_buttonYes_clicked(object obj, EventArgs args)
|
||||||
|
{
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonYes_clicked() - BEGIN");
|
||||||
|
|
||||||
|
TreeModel model;
|
||||||
|
TreeIter iter;
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if( tvSecretIDKdeWallet.Selection.GetSelected (out model, out iter) )
|
||||||
|
{
|
||||||
|
if( Common.STATUS_SUCCESS == StoreDataInterface.UpdateStore(Common.STORE_KDEWALLET, Common.OPERATION_DELETE_SECRET, "", "", ref model, ref iter) )
|
||||||
|
{
|
||||||
|
tsSecretIDKdeWallet.Remove(ref iter);
|
||||||
|
tvSecretIDKdeWallet.ColumnsAutosize();
|
||||||
|
tsNativeInfoKdeWallet.Clear();
|
||||||
|
dialogConfirmDelete.Destroy();
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonYes_clicked() - DELETE_SECRET_SUCCEEDED");
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonYes_clicked() - DELETE_SECRET_FAILED");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception exp)
|
||||||
|
{
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonYes_clicked() - EXCEPTION:" + exp.ToString());
|
||||||
|
}
|
||||||
|
|
||||||
|
Logger.DbgLog("GUI:KdeWallet.on_buttonYes_clicked() - END");
|
||||||
|
}
|
||||||
|
|
||||||
|
public void on_buttonNo_clicked(object obj, EventArgs args)
|
||||||
|
{
|
||||||
|
dialogConfirmDelete.Destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void on_buttonhelpEditSecret_clicked(object obj, EventArgs args)
|
public void on_buttonhelpEditSecret_clicked(object obj, EventArgs args)
|
||||||
|
@ -256,7 +256,7 @@ public class MiCasa : Store
|
|||||||
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "dialogManageSecret", null);
|
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "dialogManageSecret", null);
|
||||||
gxmlTemp.Autoconnect (this);
|
gxmlTemp.Autoconnect (this);
|
||||||
dialogManageSecret.TransientFor = (Gtk.Window)CasaMain.gxml.GetWidget("windowMain");
|
dialogManageSecret.TransientFor = (Gtk.Window)CasaMain.gxml.GetWidget("windowMain");
|
||||||
dialogManageSecret.Title = "ADD / VIEW / EDIT / LINK";
|
dialogManageSecret.Title = "MiCasa - Manage Secret";
|
||||||
|
|
||||||
cellEditable = new CellRendererText();
|
cellEditable = new CellRendererText();
|
||||||
cellEditable.Editable = true;
|
cellEditable.Editable = true;
|
||||||
@ -269,7 +269,6 @@ public class MiCasa : Store
|
|||||||
tvKeyValue.RowActivated += new RowActivatedHandler(tvKeyValue_RowActivated);
|
tvKeyValue.RowActivated += new RowActivatedHandler(tvKeyValue_RowActivated);
|
||||||
|
|
||||||
entrySecretID.Text = selected;
|
entrySecretID.Text = selected;
|
||||||
|
|
||||||
SecretStore ss = GetMiCasaStore();
|
SecretStore ss = GetMiCasaStore();
|
||||||
bool bHasLinks = false;
|
bool bHasLinks = false;
|
||||||
|
|
||||||
@ -563,12 +562,10 @@ public class MiCasa : Store
|
|||||||
iterKey;
|
iterKey;
|
||||||
string NewKey = null,
|
string NewKey = null,
|
||||||
NewValue = null;
|
NewValue = null;
|
||||||
string[] Keys = null,
|
string[] strDeletedKeys = null;
|
||||||
Values = null,
|
|
||||||
strDeletedKeys = null;
|
|
||||||
bool dirtyBit = false;
|
bool dirtyBit = false;
|
||||||
ArrayList arrKeys = null,
|
//ArrayList arrKeys = null,
|
||||||
arrValues = null;
|
// arrValues = null;
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
@ -673,7 +670,7 @@ public class MiCasa : Store
|
|||||||
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "dialogNewSecret", null);
|
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "dialogNewSecret", null);
|
||||||
gxmlTemp.Autoconnect (this);
|
gxmlTemp.Autoconnect (this);
|
||||||
dialogNewSecret.TransientFor = (Gtk.Window)CasaMain.gxml.GetWidget("windowMain");
|
dialogNewSecret.TransientFor = (Gtk.Window)CasaMain.gxml.GetWidget("windowMain");
|
||||||
dialogNewSecret.Title = "ADD NEW SECRET";
|
dialogNewSecret.Title = "MiCasa - New Secret";
|
||||||
|
|
||||||
cellEditable = new CellRendererText();
|
cellEditable = new CellRendererText();
|
||||||
cellEditable.Editable = true;
|
cellEditable.Editable = true;
|
||||||
@ -866,6 +863,8 @@ public class MiCasa : Store
|
|||||||
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "dialogConfirmDelete", null);
|
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "dialogConfirmDelete", null);
|
||||||
gxmlTemp.Autoconnect (this);
|
gxmlTemp.Autoconnect (this);
|
||||||
dialogConfirmDelete.TransientFor = (Gtk.Window)CasaMain.gxml.GetWidget("windowMain");
|
dialogConfirmDelete.TransientFor = (Gtk.Window)CasaMain.gxml.GetWidget("windowMain");
|
||||||
|
dialogConfirmDelete.Title = "MiCasa - Delete Secret";
|
||||||
|
|
||||||
TreeModel model;
|
TreeModel model;
|
||||||
TreeIter iter;
|
TreeIter iter;
|
||||||
string selected = null;
|
string selected = null;
|
||||||
@ -933,6 +932,7 @@ public class MiCasa : Store
|
|||||||
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "dialogLinkKeyValue", null);
|
Glade.XML gxmlTemp = new Glade.XML (Common.GladeFile, "dialogLinkKeyValue", null);
|
||||||
gxmlTemp.Autoconnect (this);
|
gxmlTemp.Autoconnect (this);
|
||||||
dialogLinkKeyValue.TransientFor = (Gtk.Window)CasaMain.gxml.GetWidget("dialogNewSecret");
|
dialogLinkKeyValue.TransientFor = (Gtk.Window)CasaMain.gxml.GetWidget("dialogNewSecret");
|
||||||
|
dialogConfirmDelete.Title = "MiCasa - Link Keys";
|
||||||
dialogLinkKeyValue.Modal = true;
|
dialogLinkKeyValue.Modal = true;
|
||||||
|
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
/// Abstracts the back-end and acts as an interface
|
/// Abstracts the back-end and acts as an interface
|
||||||
/// to the GUI.
|
/// to the GUI.
|
||||||
/// AUTHORS : Manohar, CSL.Manojna
|
/// AUTHORS : Manohar, CSL.Manojna
|
||||||
/// UPDATED ON : 24 Sept, 2005
|
/// UPDATED ON : 03 Jan, 06
|
||||||
///#################################################################
|
///#################################################################
|
||||||
|
|
||||||
|
|
||||||
@ -22,14 +22,13 @@ namespace Novell.CASA.GUI {
|
|||||||
using Gtk;
|
using Gtk;
|
||||||
using Novell.CASA.DataEngines;
|
using Novell.CASA.DataEngines;
|
||||||
|
|
||||||
|
|
||||||
public class StoreDataInterface
|
public class StoreDataInterface
|
||||||
{
|
{
|
||||||
|
|
||||||
private static XmlDocument ccfDoc;
|
private static XmlDocument ccfDoc;
|
||||||
private static AD ad;
|
private static AD ad;
|
||||||
|
|
||||||
private static string CCFXML_ELEMENT_MICASA_KEYCHAIN = "Keychain",
|
private const string CCFXML_ELEMENT_MICASA_KEYCHAIN = "Keychain",
|
||||||
CCFXML_ELEMENT_GKEYRING_KEYRING = "Keyring",
|
CCFXML_ELEMENT_GKEYRING_KEYRING = "Keyring",
|
||||||
CCFXML_ELEMENT_KWALLET_WALLET = "Wallet",
|
CCFXML_ELEMENT_KWALLET_WALLET = "Wallet",
|
||||||
CCFXML_ELEMENT_SECRET = "Secret",
|
CCFXML_ELEMENT_SECRET = "Secret",
|
||||||
@ -45,7 +44,8 @@ namespace Novell.CASA.GUI {
|
|||||||
CCFXML_ELEMENT_TIME_ACCESSED = "Accessed",
|
CCFXML_ELEMENT_TIME_ACCESSED = "Accessed",
|
||||||
CCFXML_ATTRIBUTE_ID = "ID",
|
CCFXML_ATTRIBUTE_ID = "ID",
|
||||||
CCFXML_ATTRIBUTE_MICASA_SYNCH = "Synch",
|
CCFXML_ATTRIBUTE_MICASA_SYNCH = "Synch",
|
||||||
CCFXML_ATTRIBUTE_GKEYRING_TYPE = "Type";
|
CCFXML_ATTRIBUTE_GKEYRING_TYPE = "Type",
|
||||||
|
CCFXML_ATTRIBUTE_WALLETLASTACCESSEDTIME="LastAcctime";
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -63,6 +63,9 @@ namespace Novell.CASA.GUI {
|
|||||||
{
|
{
|
||||||
ccfDoc = new XmlDocument();
|
ccfDoc = new XmlDocument();
|
||||||
ad = new AD();
|
ad = new AD();
|
||||||
|
|
||||||
|
//Init CCF from a XML Document -FIXME: -Remove this
|
||||||
|
//ccfDoc.Load("ccfv3.xml");
|
||||||
}
|
}
|
||||||
catch(Exception exp)
|
catch(Exception exp)
|
||||||
{
|
{
|
||||||
@ -94,7 +97,6 @@ namespace Novell.CASA.GUI {
|
|||||||
catch(Exception exp)
|
catch(Exception exp)
|
||||||
{
|
{
|
||||||
Logger.DbgLog("GUI:StoreDataInterface.AggregateStore() - EXCEPTION" + exp.ToString());
|
Logger.DbgLog("GUI:StoreDataInterface.AggregateStore() - EXCEPTION" + exp.ToString());
|
||||||
//Common.ShowErrorDialog(exp);
|
|
||||||
return( Common.STATUS_STORE_AGGREGATEFAILED );
|
return( Common.STATUS_STORE_AGGREGATEFAILED );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -118,7 +120,6 @@ namespace Novell.CASA.GUI {
|
|||||||
catch(Exception exp)
|
catch(Exception exp)
|
||||||
{
|
{
|
||||||
Logger.DbgLog("GUI:StoreDataInterface.RefreshAllStores() - EXCEPTION" + exp.ToString());
|
Logger.DbgLog("GUI:StoreDataInterface.RefreshAllStores() - EXCEPTION" + exp.ToString());
|
||||||
//Common.ShowErrorDialog(exp);
|
|
||||||
return( Common.STATUS_STORE_AGGREGATEFAILED );
|
return( Common.STATUS_STORE_AGGREGATEFAILED );
|
||||||
}
|
}
|
||||||
Logger.DbgLog("GUI:StoreDataInterface.RefreshAllStores() - END");
|
Logger.DbgLog("GUI:StoreDataInterface.RefreshAllStores() - END");
|
||||||
@ -376,7 +377,6 @@ namespace Novell.CASA.GUI {
|
|||||||
catch(Exception exp)
|
catch(Exception exp)
|
||||||
{
|
{
|
||||||
Logger.DbgLog("GUI:StoreDataInterface.ReadStore() - EXCEPTION" + exp.ToString());
|
Logger.DbgLog("GUI:StoreDataInterface.ReadStore() - EXCEPTION" + exp.ToString());
|
||||||
//Common.ShowErrorDialog( exp );
|
|
||||||
return( Common.STATUS_STORE_READFAILED );
|
return( Common.STATUS_STORE_READFAILED );
|
||||||
}
|
}
|
||||||
ShowDocOnConsole("READ STORE:");
|
ShowDocOnConsole("READ STORE:");
|
||||||
@ -396,13 +396,15 @@ namespace Novell.CASA.GUI {
|
|||||||
Logger.DbgLog("GUI:StoreDataInterface.UpdateStore()");
|
Logger.DbgLog("GUI:StoreDataInterface.UpdateStore()");
|
||||||
|
|
||||||
//TreeStore row elements
|
//TreeStore row elements
|
||||||
|
string storeChainKey = null;
|
||||||
string SecretID = null;
|
string SecretID = null;
|
||||||
string keyChainID = null;
|
string keyChainID = null;
|
||||||
string[] strKeyArray = new string[Common.MAX_ARRAY_ELEMENTS];
|
string[] strKeyArray = new string[Common.MAX_ARRAY_ELEMENTS];
|
||||||
string[] strValueArray = new string[Common.MAX_ARRAY_ELEMENTS];
|
string[] strValueArray = new string[Common.MAX_ARRAY_ELEMENTS];
|
||||||
|
string[] strNativeValueArray = new string[Common.MAX_NATIVE_ELEMENTS];
|
||||||
|
|
||||||
//XPATH query strings
|
//XPATH query strings
|
||||||
|
string ccfRootStorePath = null;
|
||||||
string ccfKeyChainPath = null;
|
string ccfKeyChainPath = null;
|
||||||
string ccfSecretPath = null;
|
string ccfSecretPath = null;
|
||||||
|
|
||||||
@ -417,6 +419,7 @@ namespace Novell.CASA.GUI {
|
|||||||
strKeyArray = (string[]) model.GetValue (iter, 1);
|
strKeyArray = (string[]) model.GetValue (iter, 1);
|
||||||
strValueArray = (string[]) model.GetValue (iter, 2);
|
strValueArray = (string[]) model.GetValue (iter, 2);
|
||||||
keyChainID = (string) model.GetValue (iter, 3);
|
keyChainID = (string) model.GetValue (iter, 3);
|
||||||
|
strNativeValueArray = (string[]) model.GetValue (iter, 5);
|
||||||
|
|
||||||
|
|
||||||
try
|
try
|
||||||
@ -425,20 +428,21 @@ namespace Novell.CASA.GUI {
|
|||||||
//Form the query to reach to an element for modify\delete\add
|
//Form the query to reach to an element for modify\delete\add
|
||||||
if( Common.STORE_MICASA == storeIDentifier )
|
if( Common.STORE_MICASA == storeIDentifier )
|
||||||
{
|
{
|
||||||
|
storeChainKey = CCFXML_ELEMENT_MICASA_KEYCHAIN;
|
||||||
|
ccfRootStorePath = "//CCF/miCASA";
|
||||||
if( Common.OPERATION_MODIFY_KEY == operation || Common.OPERATION_DELETE_KEY == operation )
|
if( Common.OPERATION_MODIFY_KEY == operation || Common.OPERATION_DELETE_KEY == operation )
|
||||||
{
|
{
|
||||||
ccfSecretPath = "//CCF/miCASA/Keychain[@ID='" + keyChainID + "']/Secret[@ID='" + SecretID + "']/Key[@ID='" + keyID + "']";
|
ccfSecretPath = "//CCF/miCASA/Keychain[@ID='" + keyChainID + "']/Secret[@ID='" + SecretID + "']/Key[@ID='" + keyID + "']";
|
||||||
}
|
}
|
||||||
else if( Common.OPERATION_DELETE_SECRET == operation )
|
else if( Common.OPERATION_DELETE_SECRET == operation )
|
||||||
{
|
{
|
||||||
//ccfSecretPath="//CCF/miCASA/Keychain[@ID='"+keyChainID+"']/Secret[@ID='"+SecretID+"']";
|
|
||||||
ccfKeyChainPath = "//CCF/miCASA/Keychain[@ID='" + keyChainID + "']";
|
ccfKeyChainPath = "//CCF/miCASA/Keychain[@ID='" + keyChainID + "']";
|
||||||
ccfSecretPath = "Secret[@ID='" + SecretID + "']";
|
ccfSecretPath = "Secret[@ID='" + SecretID + "']";
|
||||||
}
|
}
|
||||||
else if( Common.OPERATION_ADD_SECRET == operation )
|
else if( Common.OPERATION_ADD_SECRET == operation )
|
||||||
{
|
{
|
||||||
ccfKeyChainPath = "//CCF/miCASA/Keychain[@ID='" + keyChainID + "']";
|
ccfKeyChainPath = "//CCF/miCASA/Keychain[@ID='" + keyChainID + "']";
|
||||||
ccfSecretPath = "";
|
ccfSecretPath = "//CCF/miCASA/Keychain[@ID='" + keyChainID + "']/Secret[@ID='" + SecretID + "']";
|
||||||
|
|
||||||
//Create the Secret element
|
//Create the Secret element
|
||||||
newSecretElement = ccfDoc.CreateElement(CCFXML_ELEMENT_SECRET);
|
newSecretElement = ccfDoc.CreateElement(CCFXML_ELEMENT_SECRET);
|
||||||
@ -471,6 +475,10 @@ namespace Novell.CASA.GUI {
|
|||||||
newAccessedTime.InnerText = "9012";
|
newAccessedTime.InnerText = "9012";
|
||||||
newTime.AppendChild(newAccessedTime);
|
newTime.AppendChild(newAccessedTime);
|
||||||
newSecretElement.AppendChild(newTime);
|
newSecretElement.AppendChild(newTime);
|
||||||
|
//Create the keychain element
|
||||||
|
newKeychainElement = ccfDoc.CreateElement(storeChainKey);
|
||||||
|
newKeychainElement.SetAttribute(CCFXML_ATTRIBUTE_ID,keyChainID);
|
||||||
|
newKeychainElement.AppendChild(newSecretElement);
|
||||||
}
|
}
|
||||||
else if( Common.OPERATION_ADD_KEY == operation )
|
else if( Common.OPERATION_ADD_KEY == operation )
|
||||||
{
|
{
|
||||||
@ -478,7 +486,121 @@ namespace Novell.CASA.GUI {
|
|||||||
ccfSecretPath = "";
|
ccfSecretPath = "";
|
||||||
|
|
||||||
//Create the Key element
|
//Create the Key element
|
||||||
//strKeyArray[0]-[n] -If Support needed for multiple keys at once
|
newKeyElement = ccfDoc.CreateElement(CCFXML_ELEMENT_KEY);
|
||||||
|
newKeyElement.SetAttribute(CCFXML_ATTRIBUTE_ID,keyID);
|
||||||
|
XmlElement newValue = ccfDoc.CreateElement(CCFXML_ELEMENT_VALUE);
|
||||||
|
newValue.InnerText = valueToBeModfied;
|
||||||
|
newKeyElement.AppendChild(newValue);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if( Common.STORE_GNOMEKEYRING == storeIDentifier )
|
||||||
|
{
|
||||||
|
storeChainKey = CCFXML_ELEMENT_GKEYRING_KEYRING;
|
||||||
|
ccfRootStorePath = "//CCF/GK";
|
||||||
|
if( Common.OPERATION_MODIFY_KEY == operation || Common.OPERATION_DELETE_KEY == operation )
|
||||||
|
{
|
||||||
|
ccfSecretPath = "//CCF/GK/Keyring[@ID='" + keyChainID + "']/Secret[@ID='" + SecretID + "']/Key[@ID='" + keyID + "']";
|
||||||
|
//Console.WriteLine("OPERATION_MODIFY_KEY-OR-OPERATION_DELETE_KEY:ccfSecretPath:"+ccfSecretPath);//FIXME:Remove this line
|
||||||
|
}
|
||||||
|
else if( Common.OPERATION_DELETE_SECRET == operation )
|
||||||
|
{
|
||||||
|
ccfKeyChainPath = "//CCF/GK/Keyring[@ID='" + keyChainID + "']";
|
||||||
|
ccfSecretPath = "Secret[@ID='" + SecretID + "']";
|
||||||
|
//Console.WriteLine("OPERATION_DELETE_SECRET:ccfKeyChainPath:"+ccfKeyChainPath);//FIXME:Remove this line
|
||||||
|
//Console.WriteLine("OPERATION_DELETE_SECRET:ccfSecretPath:"+ccfSecretPath);//FIXME:Remove this line
|
||||||
|
}
|
||||||
|
else if( Common.OPERATION_ADD_SECRET == operation )
|
||||||
|
{
|
||||||
|
string typeID = strNativeValueArray[Common.INDEX_NATIVEINFO_TYPEID];
|
||||||
|
string walletLastAccessedTime = strNativeValueArray[Common.INDEX_NATIVEINFO_WALLETLASTACCESSEDTIME];
|
||||||
|
ccfKeyChainPath = "//CCF/GK/Keyring[@ID='" + keyChainID + "']";//Default keyChainID:CASAKeyring
|
||||||
|
ccfSecretPath = "//CCF/GK/Keyring[@ID='" + keyChainID + "']/Secret[@ID='" + SecretID + "']";
|
||||||
|
//Console.WriteLine("OPERATION_ADD_SECRET:ccfKeyChainPath:"+ccfKeyChainPath);//FIXME:Remove this line
|
||||||
|
//Console.WriteLine("OPERATION_ADD_SECRET:ccfSecretPath:"+ccfSecretPath);//FIXME:Remove this line
|
||||||
|
|
||||||
|
//Create the Secret element
|
||||||
|
newSecretElement = ccfDoc.CreateElement(CCFXML_ELEMENT_SECRET);
|
||||||
|
newSecretElement.SetAttribute(CCFXML_ATTRIBUTE_ID,SecretID);
|
||||||
|
newSecretElement.SetAttribute(CCFXML_ATTRIBUTE_GKEYRING_TYPE,typeID); //Default typeID:Password
|
||||||
|
|
||||||
|
//Add all keys from strKeyArray to the new secret
|
||||||
|
for( int i=0; i< strKeyArray.Length; i++)
|
||||||
|
{
|
||||||
|
XmlElement newKey = ccfDoc.CreateElement(CCFXML_ELEMENT_KEY);
|
||||||
|
newKey.SetAttribute(CCFXML_ATTRIBUTE_ID,strKeyArray[i]);
|
||||||
|
XmlElement newValue = ccfDoc.CreateElement(CCFXML_ELEMENT_VALUE);
|
||||||
|
newValue.InnerText = strValueArray[i];
|
||||||
|
newKey.AppendChild(newValue);
|
||||||
|
newSecretElement.AppendChild(newKey);
|
||||||
|
}
|
||||||
|
|
||||||
|
//Create the keychain element
|
||||||
|
newKeychainElement = ccfDoc.CreateElement(storeChainKey);
|
||||||
|
newKeychainElement.SetAttribute(CCFXML_ATTRIBUTE_ID,keyChainID);
|
||||||
|
//newKeychainElement.SetAttribute(CCFXML_ATTRIBUTE_WALLETLASTACCESSEDTIME,walletLastAccessedTime);
|
||||||
|
newKeychainElement.AppendChild(newSecretElement);
|
||||||
|
}
|
||||||
|
else if( Common.OPERATION_ADD_KEY == operation )
|
||||||
|
{
|
||||||
|
ccfKeyChainPath = "//CCF/GK/Keyring[@ID='" + keyChainID + "']/Secret[@ID='" + SecretID + "']";
|
||||||
|
ccfSecretPath = "";
|
||||||
|
|
||||||
|
//Create the Key element
|
||||||
|
newKeyElement = ccfDoc.CreateElement(CCFXML_ELEMENT_KEY);
|
||||||
|
newKeyElement.SetAttribute(CCFXML_ATTRIBUTE_ID,keyID);
|
||||||
|
XmlElement newValue = ccfDoc.CreateElement(CCFXML_ELEMENT_VALUE);
|
||||||
|
newValue.InnerText = valueToBeModfied;
|
||||||
|
newKeyElement.AppendChild(newValue);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if( Common.STORE_KDEWALLET == storeIDentifier )
|
||||||
|
{
|
||||||
|
string folderName = strNativeValueArray[Common.INDEX_NATIVEINFO_FOLDERNAME];
|
||||||
|
string typeID = strNativeValueArray[Common.INDEX_NATIVEINFO_TYPEID];
|
||||||
|
storeChainKey = CCFXML_ELEMENT_KWALLET_WALLET;
|
||||||
|
ccfRootStorePath = "//CCF/KWallet";
|
||||||
|
|
||||||
|
if( Common.OPERATION_MODIFY_KEY == operation || Common.OPERATION_DELETE_KEY == operation )
|
||||||
|
{
|
||||||
|
ccfSecretPath = "//CCF/KWallet/Wallet[@ID='" + keyChainID + "']/Folder[@Name='" + folderName + "']/Type[@ID='" + typeID + "']/Secret[@ID='" + SecretID + "']/Key[@ID='" + keyID + "']";
|
||||||
|
//Console.WriteLine("OPERATION_MODIFY_KEY-OR-OPERATION_DELETE_KEY:ccfSecretPath:"+ccfSecretPath);//FIXME:Remove this line
|
||||||
|
}
|
||||||
|
else if( Common.OPERATION_DELETE_SECRET == operation )
|
||||||
|
{
|
||||||
|
ccfKeyChainPath = "//CCF/KWallet/Wallet[@ID='" + keyChainID + "']/Folder[@Name='" + folderName + "']/Type[@ID='" + typeID + "']";
|
||||||
|
ccfSecretPath = "Secret[@ID='" + SecretID + "']";
|
||||||
|
//Console.WriteLine("OPERATION_DELETE_SECRET:ccfKeyChainPath:"+ccfKeyChainPath);//FIXME:Remove this line
|
||||||
|
//Console.WriteLine("OPERATION_DELETE_SECRET:ccfSecretPath:"+ccfSecretPath);//FIXME:Remove this line
|
||||||
|
}
|
||||||
|
else if( Common.OPERATION_ADD_SECRET == operation )
|
||||||
|
{
|
||||||
|
ccfKeyChainPath = "//CCF/KWallet/Wallet[@ID='" + keyChainID + "']/Folder[@Name='" + folderName + "']/Type[@ID='" + typeID + "']";
|
||||||
|
ccfSecretPath = "//CCF/KWallet/Wallet[@ID='" + keyChainID + "']/Folder[@Name='" + folderName + "']/Type[@ID='" + typeID + "']/Secret[@ID='" + SecretID + "']";
|
||||||
|
//Console.WriteLine("OPERATION_ADD_SECRET:ccfKeyChainPath:"+ccfKeyChainPath);//FIXME:Remove this line
|
||||||
|
//Console.WriteLine("OPERATION_ADD_SECRET:ccfSecretPath:"+ccfSecretPath);//FIXME:Remove this line
|
||||||
|
|
||||||
|
//Create the Secret element
|
||||||
|
newSecretElement = ccfDoc.CreateElement(CCFXML_ELEMENT_SECRET);
|
||||||
|
newSecretElement.SetAttribute(CCFXML_ATTRIBUTE_ID,SecretID);
|
||||||
|
|
||||||
|
//Add all keys from strKeyArray to the new secret
|
||||||
|
for( int i=0; i< strKeyArray.Length; i++)
|
||||||
|
{
|
||||||
|
XmlElement newKey = ccfDoc.CreateElement(CCFXML_ELEMENT_KEY);
|
||||||
|
newKey.SetAttribute(CCFXML_ATTRIBUTE_ID,strKeyArray[i]);
|
||||||
|
XmlElement newValue = ccfDoc.CreateElement(CCFXML_ELEMENT_VALUE);
|
||||||
|
newValue.InnerText = strValueArray[i];
|
||||||
|
newKey.AppendChild(newValue);
|
||||||
|
newSecretElement.AppendChild(newKey);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
else if( Common.OPERATION_ADD_KEY == operation )
|
||||||
|
{
|
||||||
|
ccfKeyChainPath = "//CCF/KWallet/Wallet[@ID='" + keyChainID + "']/Folder[@Name='" + folderName + "']/Type[@ID='" + typeID + "']/Secret[@ID='" + SecretID + "']";
|
||||||
|
ccfSecretPath = "";
|
||||||
|
|
||||||
|
//Create the Key element
|
||||||
newKeyElement = ccfDoc.CreateElement(CCFXML_ELEMENT_KEY);
|
newKeyElement = ccfDoc.CreateElement(CCFXML_ELEMENT_KEY);
|
||||||
newKeyElement.SetAttribute(CCFXML_ATTRIBUTE_ID,keyID);
|
newKeyElement.SetAttribute(CCFXML_ATTRIBUTE_ID,keyID);
|
||||||
XmlElement newValue = ccfDoc.CreateElement(CCFXML_ELEMENT_VALUE);
|
XmlElement newValue = ccfDoc.CreateElement(CCFXML_ELEMENT_VALUE);
|
||||||
@ -489,7 +611,9 @@ namespace Novell.CASA.GUI {
|
|||||||
else
|
else
|
||||||
return( Common.STATUS_STORE_UNSUPPORTEDOPERATION );
|
return( Common.STATUS_STORE_UNSUPPORTEDOPERATION );
|
||||||
|
|
||||||
//Execute the query for modify\delete\add
|
|
||||||
|
|
||||||
|
//Execution of the query's
|
||||||
if( Common.OPERATION_MODIFY_KEY == operation )
|
if( Common.OPERATION_MODIFY_KEY == operation )
|
||||||
{
|
{
|
||||||
//For Modify operation get to the Node in the tree which needs to be modified
|
//For Modify operation get to the Node in the tree which needs to be modified
|
||||||
@ -498,7 +622,8 @@ namespace Novell.CASA.GUI {
|
|||||||
foreach ( XmlNode key in keylist )
|
foreach ( XmlNode key in keylist )
|
||||||
{
|
{
|
||||||
key.ChildNodes[0].InnerText=valueToBeModfied ;
|
key.ChildNodes[0].InnerText=valueToBeModfied ;
|
||||||
ad.SetSecret(key.ParentNode,storeIDentifier);
|
//Console.WriteLine("EXECUTING OPERATION_MODIFY_KEY:Modifying"+ccfSecretPath);//FIXME:Remove this line
|
||||||
|
ad.SetSecret(key.ParentNode,operation,storeIDentifier);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if( Common.OPERATION_DELETE_SECRET == operation )
|
else if( Common.OPERATION_DELETE_SECRET == operation )
|
||||||
@ -512,6 +637,7 @@ namespace Novell.CASA.GUI {
|
|||||||
XmlNodeList secretNodelist = keychain.SelectNodes(ccfSecretPath);
|
XmlNodeList secretNodelist = keychain.SelectNodes(ccfSecretPath);
|
||||||
foreach ( XmlNode secret in secretNodelist )
|
foreach ( XmlNode secret in secretNodelist )
|
||||||
{
|
{
|
||||||
|
//Console.WriteLine("EXECUTING OPERATION_DELETE_SECRET:Deleting"+ccfSecretPath);//FIXME:Remove this line
|
||||||
ad.Remove(secret,storeIDentifier);
|
ad.Remove(secret,storeIDentifier);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -524,69 +650,169 @@ namespace Novell.CASA.GUI {
|
|||||||
|
|
||||||
foreach ( XmlNode key in keylist )
|
foreach ( XmlNode key in keylist )
|
||||||
{
|
{
|
||||||
//key.ChildNodes[0].InnerText=valueToBeModfied ;
|
|
||||||
XmlNode keyParentNode = key.ParentNode;
|
XmlNode keyParentNode = key.ParentNode;
|
||||||
key.ParentNode.RemoveChild(key);
|
key.ParentNode.RemoveChild(key);
|
||||||
|
//Console.WriteLine("EXECUTING OPERATION_DELETE_KEY:Deleting"+ccfSecretPath);//FIXME:Remove this line
|
||||||
ad.SetSecret(keyParentNode,storeIDentifier);
|
ad.SetSecret(keyParentNode,storeIDentifier);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if( Common.OPERATION_ADD_SECRET == operation )
|
else if( Common.OPERATION_ADD_SECRET == operation )
|
||||||
|
{
|
||||||
|
//ShowDocOnConsole("BEFORE CALL TO SETSECRET");//FIXME:Remove this
|
||||||
|
|
||||||
|
if(( Common.STORE_MICASA == storeIDentifier )||( Common.STORE_GNOMEKEYRING == storeIDentifier ))
|
||||||
{
|
{
|
||||||
//Add a new secret to the keychain
|
//Add a new secret to the keychain
|
||||||
XmlNode root = ccfDoc.DocumentElement;
|
XmlNode root = ccfDoc.DocumentElement;
|
||||||
XmlNodeList keychainNodeList = root.SelectNodes(ccfKeyChainPath);
|
XmlNodeList keychainNodeList = root.SelectNodes(ccfKeyChainPath);
|
||||||
|
//Console.WriteLine("ADD_SECRET:ccfKeyChainPath="+ccfKeyChainPath);//FIXME:Remove this line
|
||||||
|
|
||||||
if( (null == keychainNodeList) || (0 == keychainNodeList.Count) )
|
if( (null == keychainNodeList) || (0 == keychainNodeList.Count) )
|
||||||
{
|
{//No root keychain path for this wallet. Hence New Keychain to be created
|
||||||
newKeychainElement = ccfDoc.CreateElement(CCFXML_ELEMENT_MICASA_KEYCHAIN);
|
//Expected path to be existing in CCF is eg://CCF/miCASA
|
||||||
newKeychainElement.SetAttribute(CCFXML_ATTRIBUTE_ID,keyChainID);
|
keychainNodeList = root.SelectNodes(ccfRootStorePath);
|
||||||
ccfKeyChainPath = "//CCF/miCASA";
|
|
||||||
keychainNodeList = root.SelectNodes(ccfKeyChainPath);
|
|
||||||
XmlNode miCASANode = keychainNodeList.Item(0);
|
XmlNode miCASANode = keychainNodeList.Item(0);
|
||||||
|
|
||||||
if( null != miCASANode )
|
if( null != miCASANode )
|
||||||
{
|
{
|
||||||
|
//Console.WriteLine("ADD_SECRET:Appending to ccfRootStorePath="+ccfRootStorePath);//FIXME:Remove this line
|
||||||
miCASANode.AppendChild(newKeychainElement);
|
miCASANode.AppendChild(newKeychainElement);
|
||||||
newKeychainElement.AppendChild(newSecretElement);
|
//ShowDocOnConsole("AFTER APENDING TO miCASANode");//FIXME:Remove this
|
||||||
ccfSecretPath = "//CCF/miCASA/Keychain[@ID='" + keyChainID + "']/Secret[@ID='" + SecretID + "']";
|
//Console.WriteLine("ADD_SECRET:ccfSecretPath="+ccfSecretPath);//FIXME:Remove this line
|
||||||
keychainNodeList = root.SelectNodes(ccfSecretPath);
|
keychainNodeList = root.SelectNodes(ccfSecretPath);
|
||||||
XmlNode SecretNode = keychainNodeList.Item(0);
|
XmlNode SecretNode = keychainNodeList.Item(0);
|
||||||
ad.SetSecret(SecretNode,storeIDentifier);
|
//Console.WriteLine("EXECUTING OPERATION_ADD_SECRET:Adding"+ccfSecretPath);//FIXME:Remove this line
|
||||||
|
ad.SetSecret(SecretNode,operation,storeIDentifier);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{//Root keychain path exists for this wallet
|
||||||
|
//Console.WriteLine("ADD_SECRET:Appending to ccfKeyChainPath="+ccfKeyChainPath);//FIXME:Remove this line
|
||||||
XmlNode keychain = keychainNodeList.Item(0);
|
XmlNode keychain = keychainNodeList.Item(0);
|
||||||
keychain.AppendChild(newSecretElement);
|
keychain.AppendChild(newSecretElement);
|
||||||
XmlNode lastChild = keychain.LastChild;
|
XmlNode lastChild = keychain.LastChild;
|
||||||
ad.SetSecret(lastChild,storeIDentifier);
|
//ShowDocOnConsole("BEFORE CALL TO SETSECRET");//FIXME:Remove this
|
||||||
|
//Console.WriteLine("EXECUTING OPERATION_ADD_SECRET:Adding Secret to existing keychain");//FIXME:Remove this line
|
||||||
|
int errCode=ad.SetSecret(lastChild,operation,storeIDentifier);
|
||||||
|
//Console.WriteLine("OPERATION_ADD_SECRET Returned:errCode"+errCode);//FIXME:Remove this line
|
||||||
}
|
}
|
||||||
|
}//Common.STORE_MICASA \ STORE_GNOMEKEYRING
|
||||||
|
else
|
||||||
|
if( Common.STORE_KDEWALLET == storeIDentifier )
|
||||||
|
{
|
||||||
|
string folderName = strNativeValueArray[Common.INDEX_NATIVEINFO_FOLDERNAME];
|
||||||
|
string typeID = strNativeValueArray[Common.INDEX_NATIVEINFO_TYPEID];
|
||||||
|
XmlNode root = ccfDoc.DocumentElement;
|
||||||
|
ccfKeyChainPath = "//CCF/KWallet/Wallet[@ID='" + keyChainID + "']"; //CASAwallet
|
||||||
|
XmlNodeList keychainNodeList = root.SelectNodes(ccfKeyChainPath);
|
||||||
|
if( (null == keychainNodeList) || (0 == keychainNodeList.Count) )
|
||||||
|
{//Wallet:CASAwallet does not exist. Hence create all
|
||||||
|
XmlElement folder;
|
||||||
|
XmlElement type;
|
||||||
|
newKeychainElement = ccfDoc.CreateElement(storeChainKey);//Wallet
|
||||||
|
newKeychainElement.SetAttribute(CCFXML_ATTRIBUTE_ID,keyChainID);
|
||||||
|
folder = ccfDoc.CreateElement(CCFXML_ELEMENT_FOLDER);
|
||||||
|
folder.SetAttribute(CCFXML_ATTRIBUTE_FOLDERNAME,folderName);
|
||||||
|
type = ccfDoc.CreateElement(CCFXML_ELEMENT_TYPE);
|
||||||
|
type.SetAttribute(CCFXML_ATTRIBUTE_ID,typeID);
|
||||||
|
|
||||||
|
//Join all of them
|
||||||
|
type.AppendChild(newSecretElement);
|
||||||
|
folder.AppendChild(type);
|
||||||
|
newKeychainElement.AppendChild(folder);
|
||||||
|
//Append the keychain to the root
|
||||||
|
keychainNodeList = root.SelectNodes(ccfRootStorePath);
|
||||||
|
XmlNode rootNode = keychainNodeList.Item(0);
|
||||||
|
if( null != rootNode )
|
||||||
|
rootNode.AppendChild(newKeychainElement);
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{//Wallet:CASAwallet exists. Hence check for folder
|
||||||
|
ccfKeyChainPath = "//CCF/KWallet/Wallet[@ID='" + keyChainID + "']/Folder[@Name='" + folderName + "']"; //Password
|
||||||
|
XmlNodeList keychainFolderNodeList = root.SelectNodes(ccfKeyChainPath);
|
||||||
|
if( (null == keychainFolderNodeList) || (0 == keychainFolderNodeList.Count) )
|
||||||
|
{//folderName:Password does not exist. Hence create folder & type
|
||||||
|
XmlElement folder;
|
||||||
|
XmlElement type;
|
||||||
|
folder = ccfDoc.CreateElement(CCFXML_ELEMENT_FOLDER);
|
||||||
|
folder.SetAttribute(CCFXML_ATTRIBUTE_FOLDERNAME,folderName);
|
||||||
|
type = ccfDoc.CreateElement(CCFXML_ELEMENT_TYPE);
|
||||||
|
type.SetAttribute(CCFXML_ATTRIBUTE_ID,typeID);
|
||||||
|
|
||||||
|
//Append secret to type
|
||||||
|
type.AppendChild(newSecretElement);
|
||||||
|
//Append type to folder
|
||||||
|
folder.AppendChild(type);
|
||||||
|
//Append folder to the existing keychainNodeList
|
||||||
|
XmlNode keychainNode = keychainNodeList.Item(0);
|
||||||
|
if( null != keychainNode )
|
||||||
|
keychainNode.AppendChild(folder);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{//Wallet:CASAwallet & folder exists. Hence check for type
|
||||||
|
ccfKeyChainPath = "//CCF/KWallet/Wallet[@ID='" + keyChainID + "']/Folder[@Name='" + folderName + "']/Type[@ID='" + typeID + "']"; //Maps
|
||||||
|
XmlNodeList keychainTypeNodeList = root.SelectNodes(ccfKeyChainPath);
|
||||||
|
if( (null == keychainTypeNodeList) || (0 == keychainTypeNodeList.Count) )
|
||||||
|
{//type:Maps does not exist. Hence create folder & type
|
||||||
|
XmlElement type;
|
||||||
|
type = ccfDoc.CreateElement(CCFXML_ELEMENT_TYPE);
|
||||||
|
type.SetAttribute(CCFXML_ATTRIBUTE_ID,typeID);
|
||||||
|
//Append Secret to type
|
||||||
|
type.AppendChild(newSecretElement);
|
||||||
|
//Append type to the existing keychainFolderNodeList
|
||||||
|
XmlNode keychainFolderNode = keychainFolderNodeList.Item(0);
|
||||||
|
if( null != keychainFolderNode )
|
||||||
|
keychainFolderNode.AppendChild(type);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
//Invoke setsecret
|
||||||
|
//ShowDocOnConsole("AFTER ADD to CCF");//FIXME:Remove this
|
||||||
|
ccfKeyChainPath = "//CCF/KWallet/Wallet[@ID='" + keyChainID + "']/Folder[@Name='" + folderName + "']/Type[@ID='" + typeID + "']";
|
||||||
|
root = ccfDoc.DocumentElement;
|
||||||
|
//Console.WriteLine("ADD_SECRET:ccfSecretPath="+ccfSecretPath);//FIXME:Remove this line
|
||||||
|
//Console.WriteLine("ADD_SECRET:ccfKeyChainPath="+ccfKeyChainPath);//FIXME:Remove this line
|
||||||
|
XmlNodeList secretNodeList = root.SelectNodes(ccfKeyChainPath);
|
||||||
|
XmlNode SecretNode = secretNodeList.Item(0);
|
||||||
|
XmlNode lastChild = SecretNode.LastChild; //The newly added secret
|
||||||
|
if(lastChild!=null)
|
||||||
|
{
|
||||||
|
//Console.WriteLine("EXECUTING OPERATION_ADD_SECRET:Adding"+ccfSecretPath);//FIXME:Remove this line
|
||||||
|
ad.SetSecret(lastChild,operation,storeIDentifier);
|
||||||
|
}
|
||||||
|
}//STORE_KDEWALLET
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
else if( Common.OPERATION_ADD_KEY == operation )
|
else if( Common.OPERATION_ADD_KEY == operation )
|
||||||
{
|
{
|
||||||
//Add a new KN\KV to the keychain-Secret
|
//Add a new KN\KV to the keychain-Secret
|
||||||
|
//Console.WriteLine("EXECUTING OPERATION_ADD_KEY:Adding"+ccfKeyChainPath);//FIXME:Remove this line
|
||||||
XmlNode root = ccfDoc.DocumentElement;
|
XmlNode root = ccfDoc.DocumentElement;
|
||||||
XmlNodeList keyNodeList = root.SelectNodes(ccfKeyChainPath);
|
XmlNodeList keyNodeList = root.SelectNodes(ccfKeyChainPath);
|
||||||
XmlNode keyNode=keyNodeList.Item(0);
|
XmlNode keyNode=keyNodeList.Item(0);
|
||||||
XmlNode lastChild = keyNode.LastChild;
|
XmlNode lastChild = keyNode.LastChild;
|
||||||
keyNode.InsertBefore(newKeyElement,lastChild);
|
keyNode.InsertBefore(newKeyElement,lastChild);
|
||||||
ad.SetSecret(keyNode,storeIDentifier);
|
//ShowDocOnConsole("JUST BEFORE CALL TO SETSECRET-ADDKEY");//FIXME:Remove this
|
||||||
|
int errcode=ad.SetSecret(keyNode,Common.OPERATION_ADD_SECRET,storeIDentifier);
|
||||||
|
//ShowDocOnConsole("SetSecret returned errcode="+errcode);//FIXME:Remove this
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
catch(Exception exp)
|
catch(Exception exp)
|
||||||
{
|
{
|
||||||
|
//Console.WriteLine("Exception"+exp.ToString());//FIXME:Remove this line
|
||||||
Logger.DbgLog("GUI:StoreDataInterface.UpdateStore() - EXCEPTION" + exp.ToString());
|
Logger.DbgLog("GUI:StoreDataInterface.UpdateStore() - EXCEPTION" + exp.ToString());
|
||||||
//Common.ShowErrorDialog( exp );
|
|
||||||
return( Common.STATUS_STORE_UPDATEFAILED );
|
return( Common.STATUS_STORE_UPDATEFAILED );
|
||||||
}
|
}
|
||||||
|
|
||||||
ShowDocOnConsole("UPDATE STORE:");
|
|
||||||
return( Common.STATUS_SUCCESS );
|
return( Common.STATUS_SUCCESS );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///#######################################################################
|
///#######################################################################
|
||||||
/// DUMP THE XML CCF ON CONSOLE
|
/// DUMP THE XML CCF ON CONSOLE
|
||||||
|
|
||||||
@ -603,6 +829,7 @@ namespace Novell.CASA.GUI {
|
|||||||
Console.WriteLine("\n#######################################################");
|
Console.WriteLine("\n#######################################################");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
///###########################################################################
|
///###########################################################################
|
||||||
|
@ -1807,7 +1807,7 @@ their backend stores.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
</widget>
|
</widget>
|
||||||
<packing>
|
<packing>
|
||||||
@ -1828,7 +1828,7 @@ their backend stores.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
</widget>
|
</widget>
|
||||||
<packing>
|
<packing>
|
||||||
@ -2006,7 +2006,7 @@ their backend stores.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
</widget>
|
</widget>
|
||||||
<packing>
|
<packing>
|
||||||
@ -2227,7 +2227,7 @@ their backend stores.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
</widget>
|
</widget>
|
||||||
<packing>
|
<packing>
|
||||||
@ -3302,7 +3302,7 @@ their backend stores.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
</widget>
|
</widget>
|
||||||
<packing>
|
<packing>
|
||||||
@ -3830,7 +3830,7 @@ prompted for the Master Password at startup.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
</widget>
|
</widget>
|
||||||
<packing>
|
<packing>
|
||||||
@ -3851,7 +3851,7 @@ prompted for the Master Password at startup.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
</widget>
|
</widget>
|
||||||
<packing>
|
<packing>
|
||||||
@ -3871,7 +3871,7 @@ prompted for the Master Password at startup.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
</widget>
|
</widget>
|
||||||
<packing>
|
<packing>
|
||||||
@ -4997,7 +4997,7 @@ prompted for the Master Password at startup.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
<signal name="activate" handler="on_entryMasterPassword3_activate" last_modification_time="Tue, 27 Sep 2005 10:46:32 GMT"/>
|
<signal name="activate" handler="on_entryMasterPassword3_activate" last_modification_time="Tue, 27 Sep 2005 10:46:32 GMT"/>
|
||||||
</widget>
|
</widget>
|
||||||
@ -5019,7 +5019,7 @@ prompted for the Master Password at startup.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
<signal name="activate" handler="on_entryMasterPassword4_activate" last_modification_time="Tue, 27 Sep 2005 04:37:31 GMT"/>
|
<signal name="activate" handler="on_entryMasterPassword4_activate" last_modification_time="Tue, 27 Sep 2005 04:37:31 GMT"/>
|
||||||
</widget>
|
</widget>
|
||||||
@ -5491,7 +5491,7 @@ prompted for the Master Password at startup.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
</widget>
|
</widget>
|
||||||
<packing>
|
<packing>
|
||||||
@ -5512,7 +5512,7 @@ prompted for the Master Password at startup.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
</widget>
|
</widget>
|
||||||
<packing>
|
<packing>
|
||||||
@ -5691,7 +5691,7 @@ prompted for the Master Password at startup.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
</widget>
|
</widget>
|
||||||
<packing>
|
<packing>
|
||||||
@ -6638,7 +6638,7 @@ prompted for the Master Password at startup.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
</widget>
|
</widget>
|
||||||
<packing>
|
<packing>
|
||||||
@ -6659,7 +6659,7 @@ prompted for the Master Password at startup.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
</widget>
|
</widget>
|
||||||
<packing>
|
<packing>
|
||||||
@ -6704,7 +6704,7 @@ prompted for the Master Password at startup.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
</widget>
|
</widget>
|
||||||
<packing>
|
<packing>
|
||||||
@ -6747,7 +6747,7 @@ prompted for the Master Password at startup.</property>
|
|||||||
<property name="max_length">0</property>
|
<property name="max_length">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
<property name="has_frame">True</property>
|
<property name="has_frame">True</property>
|
||||||
<property name="invisible_char">*</property>
|
<property name="invisible_char" translatable="yes">*</property>
|
||||||
<property name="activates_default">False</property>
|
<property name="activates_default">False</property>
|
||||||
</widget>
|
</widget>
|
||||||
<packing>
|
<packing>
|
||||||
|
Loading…
Reference in New Issue
Block a user