CASATrayApp was merged into the GUI. Removing now.
This commit is contained in:
		| @@ -1,145 +0,0 @@ | |||||||
| <VisualStudioProject> |  | ||||||
|     <CSHARP |  | ||||||
|         ProjectType = "Local" |  | ||||||
|         ProductVersion = "7.10.3077" |  | ||||||
|         SchemaVersion = "2.0" |  | ||||||
|         ProjectGuid = "{358575F1-A305-43F8-8B9D-0BEC8C1376B1}" |  | ||||||
|     > |  | ||||||
|         <Build> |  | ||||||
|             <Settings |  | ||||||
|                 ApplicationIcon = "" |  | ||||||
|                 AssemblyKeyContainerName = "" |  | ||||||
|                 AssemblyName = "CASATrayApp" |  | ||||||
|                 AssemblyOriginatorKeyFile = "" |  | ||||||
|                 DefaultClientScript = "JScript" |  | ||||||
|                 DefaultHTMLPageLayout = "Grid" |  | ||||||
|                 DefaultTargetSchema = "IE50" |  | ||||||
|                 DelaySign = "false" |  | ||||||
|                 OutputType = "WinExe" |  | ||||||
|                 PreBuildEvent = "" |  | ||||||
|                 PostBuildEvent = "" |  | ||||||
|                 RootNamespace = "CASATrayApp" |  | ||||||
|                 RunPostBuildEvent = "OnBuildSuccess" |  | ||||||
|                 StartupObject = "TrayCasa" |  | ||||||
|             > |  | ||||||
|                 <Config |  | ||||||
|                     Name = "Debug" |  | ||||||
|                     AllowUnsafeBlocks = "false" |  | ||||||
|                     BaseAddress = "285212672" |  | ||||||
|                     CheckForOverflowUnderflow = "false" |  | ||||||
|                     ConfigurationOverrideFile = "" |  | ||||||
|                     DefineConstants = "W32" |  | ||||||
|                     DocumentationFile = "" |  | ||||||
|                     DebugSymbols = "true" |  | ||||||
|                     FileAlignment = "4096" |  | ||||||
|                     IncrementalBuild = "false" |  | ||||||
|                     NoStdLib = "false" |  | ||||||
|                     NoWarn = "" |  | ||||||
|                     Optimize = "false" |  | ||||||
|                     OutputPath = "..\c_gui\Release\" |  | ||||||
|                     RegisterForComInterop = "false" |  | ||||||
|                     RemoveIntegerChecks = "false" |  | ||||||
|                     TreatWarningsAsErrors = "false" |  | ||||||
|                     WarningLevel = "4" |  | ||||||
|                 /> |  | ||||||
|                 <Config |  | ||||||
|                     Name = "Release" |  | ||||||
|                     AllowUnsafeBlocks = "false" |  | ||||||
|                     BaseAddress = "285212672" |  | ||||||
|                     CheckForOverflowUnderflow = "false" |  | ||||||
|                     ConfigurationOverrideFile = "" |  | ||||||
|                     DefineConstants = "W32" |  | ||||||
|                     DocumentationFile = "" |  | ||||||
|                     DebugSymbols = "false" |  | ||||||
|                     FileAlignment = "4096" |  | ||||||
|                     IncrementalBuild = "false" |  | ||||||
|                     NoStdLib = "false" |  | ||||||
|                     NoWarn = "" |  | ||||||
|                     Optimize = "true" |  | ||||||
|                     OutputPath = "bin\Release\" |  | ||||||
|                     RegisterForComInterop = "false" |  | ||||||
|                     RemoveIntegerChecks = "false" |  | ||||||
|                     TreatWarningsAsErrors = "false" |  | ||||||
|                     WarningLevel = "4" |  | ||||||
|                 /> |  | ||||||
|             </Settings> |  | ||||||
|             <References> |  | ||||||
|                 <Reference |  | ||||||
|                     Name = "System" |  | ||||||
|                     AssemblyName = "System" |  | ||||||
|                     HintPath = "C:\WINDOWS\Microsoft.NET\Framework\v1.1.4322\System.dll" |  | ||||||
|                 /> |  | ||||||
|                 <Reference |  | ||||||
|                     Name = "System.Data" |  | ||||||
|                     AssemblyName = "System.Data" |  | ||||||
|                     HintPath = "C:\WINDOWS\Microsoft.NET\Framework\v1.1.4322\System.Data.dll" |  | ||||||
|                 /> |  | ||||||
|                 <Reference |  | ||||||
|                     Name = "System.Drawing" |  | ||||||
|                     AssemblyName = "System.Drawing" |  | ||||||
|                     HintPath = "C:\WINDOWS\Microsoft.NET\Framework\v1.1.4322\System.Drawing.dll" |  | ||||||
|                 /> |  | ||||||
|                 <Reference |  | ||||||
|                     Name = "System.Windows.Forms" |  | ||||||
|                     AssemblyName = "System.Windows.Forms" |  | ||||||
|                     HintPath = "C:\WINDOWS\Microsoft.NET\Framework\v1.1.4322\System.Windows.Forms.dll" |  | ||||||
|                 /> |  | ||||||
|                 <Reference |  | ||||||
|                     Name = "System.XML" |  | ||||||
|                     AssemblyName = "System.Xml" |  | ||||||
|                     HintPath = "C:\WINDOWS\Microsoft.NET\Framework\v1.1.4322\System.XML.dll" |  | ||||||
|                 /> |  | ||||||
|                 <Reference |  | ||||||
|                     Name = "Novell.CASA.Common" |  | ||||||
|                     Project = "{57CD94A2-5B4A-40C3-8189-CB760FB78357}" |  | ||||||
|                     Package = "{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}" |  | ||||||
|                 /> |  | ||||||
|                 <Reference |  | ||||||
|                     Name = "atk-sharp" |  | ||||||
|                     AssemblyName = "atk-sharp" |  | ||||||
|                     HintPath = "..\extern\w32\gtk-sharp-2.0\atk-sharp.dll" |  | ||||||
|                 /> |  | ||||||
|                 <Reference |  | ||||||
|                     Name = "gdk-sharp" |  | ||||||
|                     AssemblyName = "gdk-sharp" |  | ||||||
|                     HintPath = "..\extern\w32\gtk-sharp-2.0\gdk-sharp.dll" |  | ||||||
|                 /> |  | ||||||
|                 <Reference |  | ||||||
|                     Name = "glade-sharp" |  | ||||||
|                     AssemblyName = "glade-sharp" |  | ||||||
|                     HintPath = "..\extern\w32\gtk-sharp-2.0\glade-sharp.dll" |  | ||||||
|                 /> |  | ||||||
|                 <Reference |  | ||||||
|                     Name = "glib-sharp" |  | ||||||
|                     AssemblyName = "glib-sharp" |  | ||||||
|                     HintPath = "..\extern\w32\gtk-sharp-2.0\glib-sharp.dll" |  | ||||||
|                 /> |  | ||||||
|                 <Reference |  | ||||||
|                     Name = "gtk-sharp" |  | ||||||
|                     AssemblyName = "gtk-sharp" |  | ||||||
|                     HintPath = "..\extern\w32\gtk-sharp-2.0\gtk-sharp.dll" |  | ||||||
|                 /> |  | ||||||
|                 <Reference |  | ||||||
|                     Name = "pango-sharp" |  | ||||||
|                     AssemblyName = "pango-sharp" |  | ||||||
|                     HintPath = "..\extern\w32\gtk-sharp-2.0\pango-sharp.dll" |  | ||||||
|                 /> |  | ||||||
|                 <Reference |  | ||||||
|                     Name = "Novell.CASA.miCASAWrapper" |  | ||||||
|                     Project = "{E21DD887-22F4-4935-9851-409715F663B0}" |  | ||||||
|                     Package = "{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}" |  | ||||||
|                 /> |  | ||||||
|             </References> |  | ||||||
|         </Build> |  | ||||||
|         <Files> |  | ||||||
|             <Include> |  | ||||||
|                 <File |  | ||||||
|                     RelPath = "TrayCasa.cs" |  | ||||||
|                     SubType = "Code" |  | ||||||
|                     BuildAction = "Compile" |  | ||||||
|                 /> |  | ||||||
|             </Include> |  | ||||||
|         </Files> |  | ||||||
|     </CSHARP> |  | ||||||
| </VisualStudioProject> |  | ||||||
|  |  | ||||||
| @@ -1,48 +0,0 @@ | |||||||
| <VisualStudioProject> |  | ||||||
|     <CSHARP LastOpenVersion = "7.10.3077" > |  | ||||||
|         <Build> |  | ||||||
|             <Settings ReferencePath = "D:\casa\extern\w32\gtk-sharp-2.0\" > |  | ||||||
|                 <Config |  | ||||||
|                     Name = "Debug" |  | ||||||
|                     EnableASPDebugging = "false" |  | ||||||
|                     EnableASPXDebugging = "false" |  | ||||||
|                     EnableUnmanagedDebugging = "false" |  | ||||||
|                     EnableSQLServerDebugging = "false" |  | ||||||
|                     RemoteDebugEnabled = "false" |  | ||||||
|                     RemoteDebugMachine = "" |  | ||||||
|                     StartAction = "Project" |  | ||||||
|                     StartArguments = "" |  | ||||||
|                     StartPage = "" |  | ||||||
|                     StartProgram = "" |  | ||||||
|                     StartURL = "" |  | ||||||
|                     StartWorkingDirectory = "" |  | ||||||
|                     StartWithIE = "true" |  | ||||||
|                 /> |  | ||||||
|                 <Config |  | ||||||
|                     Name = "Release" |  | ||||||
|                     EnableASPDebugging = "false" |  | ||||||
|                     EnableASPXDebugging = "false" |  | ||||||
|                     EnableUnmanagedDebugging = "false" |  | ||||||
|                     EnableSQLServerDebugging = "false" |  | ||||||
|                     RemoteDebugEnabled = "false" |  | ||||||
|                     RemoteDebugMachine = "" |  | ||||||
|                     StartAction = "Project" |  | ||||||
|                     StartArguments = "" |  | ||||||
|                     StartPage = "" |  | ||||||
|                     StartProgram = "" |  | ||||||
|                     StartURL = "" |  | ||||||
|                     StartWorkingDirectory = "" |  | ||||||
|                     StartWithIE = "true" |  | ||||||
|                 /> |  | ||||||
|             </Settings> |  | ||||||
|         </Build> |  | ||||||
|         <OtherProjectSettings |  | ||||||
|             CopyProjectDestinationFolder = "" |  | ||||||
|             CopyProjectUncPath = "" |  | ||||||
|             CopyProjectOption = "0" |  | ||||||
|             ProjectView = "ProjectFiles" |  | ||||||
|             ProjectTrust = "0" |  | ||||||
|         /> |  | ||||||
|     </CSHARP> |  | ||||||
| </VisualStudioProject> |  | ||||||
|  |  | ||||||
| @@ -1,20 +0,0 @@ | |||||||
| # |  | ||||||
| # configure environment |  | ||||||
| # |  | ||||||
| TARGET = CASATrayApp |  | ||||||
| CS_NAME = $(TARGET)$(xtra).$(EXE) |  | ||||||
| include global.mak |  | ||||||
| include defaults.$(PLAT) |  | ||||||
| include rules.mak |  | ||||||
|  |  | ||||||
|  |  | ||||||
| # |  | ||||||
| # target object and source files |  | ||||||
| # |  | ||||||
| include src.$(PLAT) |  | ||||||
| include objs.$(PLAT) |  | ||||||
|  |  | ||||||
| # |  | ||||||
| # targets |  | ||||||
| # |  | ||||||
| include target.cs |  | ||||||
| @@ -1,369 +0,0 @@ | |||||||
| // mcs -pkg:gtk-sharp TrayLib.cs TrayTest.cs -out:TrayTest.exe |  | ||||||
| using Gtk; |  | ||||||
| using Glade; |  | ||||||
| using System; |  | ||||||
| using System.IO; |  | ||||||
| using System.Diagnostics; |  | ||||||
| using System.Threading; |  | ||||||
|  |  | ||||||
| using Novell.CASA; |  | ||||||
| using Novell.CASA.MiCasa.Common; |  | ||||||
| using Novell.CASA.MiCasa.Communication; |  | ||||||
|  |  | ||||||
|   |  | ||||||
| public class TrayCasa |  | ||||||
| { |  | ||||||
|  |  | ||||||
| 	[Glade.Widget]  |  | ||||||
| 	Gtk.Label			label86, |  | ||||||
| 						label88; |  | ||||||
|  |  | ||||||
| 	[Glade.Widget]  |  | ||||||
| 	Gtk.Entry	 		entryMasterPassword1,  |  | ||||||
| 						entryMasterPassword2,  |  | ||||||
| 						entryMasterPassword3,  |  | ||||||
| 						entryMasterPassword4; |  | ||||||
|  |  | ||||||
| 	[Glade.Widget]  |  | ||||||
| 	Gtk.Dialog 			dialogLogin; |  | ||||||
|  |  | ||||||
| #if W32 |  | ||||||
| 	private static System.Windows.Forms.NotifyIcon		notifyIcon; |  | ||||||
| 	public static System.Drawing.Icon					m_iconNormal; |  | ||||||
| 	public static System.Drawing.Icon					m_iconLocked; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	Gtk.Window mainWindow = new Window("Test"); |  | ||||||
| 	private static bool firstInstance; |  | ||||||
| 	 |  | ||||||
|  |  | ||||||
| 	public static void Main() |  | ||||||
| 	{ |  | ||||||
|  |  | ||||||
| 		// check for already running				 |  | ||||||
| 		//Mutex mutex = new Mutex(false, "Local\\"+"CASATray", out firstInstance);  |  | ||||||
| 		 |  | ||||||
| 		//if (firstInstance) |  | ||||||
| 		{ |  | ||||||
| 			// initialises the application |  | ||||||
| 			Application.Init(); |  | ||||||
| 			// creates the tray icon |  | ||||||
| 			TrayCasa casaTray = new TrayCasa(); |  | ||||||
| 			// runs application |  | ||||||
| 			Application.Run();	 |  | ||||||
|  |  | ||||||
| 		//	mutex.ReleaseMutex(); |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|   |  | ||||||
| 	public TrayCasa() |  | ||||||
| 	{ |  | ||||||
|  |  | ||||||
| #if W32		 |  | ||||||
| 		Stream		s = null; |  | ||||||
| 		notifyIcon = new System.Windows.Forms.NotifyIcon(); |  | ||||||
| 		try  |  | ||||||
| 		{ |  | ||||||
| 			s = File.OpenRead("../images/notify1.ico"); |  | ||||||
| 			m_iconNormal = new System.Drawing.Icon(s); |  | ||||||
| 			notifyIcon.Icon = m_iconNormal; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		catch (Exception e) |  | ||||||
| 		{ |  | ||||||
| 			//MessageBox.Show("File 'notify.ico' cannot be found", "Error"); |  | ||||||
| 			Console.WriteLine(e.ToString()); |  | ||||||
| 			Console.WriteLine("File 'notify.ico' cannot be found"); |  | ||||||
| 			return; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		finally  |  | ||||||
| 		{ |  | ||||||
| 			if (s != null)  |  | ||||||
| 			{ |  | ||||||
| 				s.Close();					 |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		try  |  | ||||||
| 		{ |  | ||||||
| 			s = File.OpenRead("../images/notifyLocked.ico"); |  | ||||||
| 			m_iconLocked = new System.Drawing.Icon(s); |  | ||||||
| 			 |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		catch (Exception e) |  | ||||||
| 		{			 |  | ||||||
| 			Console.WriteLine("File 'notifyLocked.ico' cannot be found"); |  | ||||||
| 			return; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		finally  |  | ||||||
| 		{ |  | ||||||
| 			if (s != null)  |  | ||||||
| 			{ |  | ||||||
| 				s.Close();					 |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 		//notifyIcon.Click +=new EventHandler(notifyIcon_Click); |  | ||||||
| 		notifyIcon.DoubleClick +=new EventHandler(notifyIcon_DoubleClick); |  | ||||||
| 		notifyIcon.MouseUp +=new System.Windows.Forms.MouseEventHandler(notifyIcon_MouseUp); |  | ||||||
| 		notifyIcon.Text = "CASA Manager"; |  | ||||||
| 		notifyIcon.Visible = true;	 |  | ||||||
| #endif	 |  | ||||||
| #if LINUX |  | ||||||
| 		/* in order to receive signals, we need a eventbox,	because Gtk.Image doesn't receive signals */ |  | ||||||
| 		EventBox eb = new EventBox(); |  | ||||||
| 		eb.Add(new Image(Stock.MissingImage, IconSize.Menu)); // using stock icon |  | ||||||
| 		// hooking event |  | ||||||
| 		eb.ButtonPressEvent += new ButtonPressEventHandler (this.OnImageClick); |  | ||||||
| 		Egg.TrayIcon icon = new Egg.TrayIcon("Test"); |  | ||||||
| 		icon.Add(eb); |  | ||||||
| 		// showing the trayicon |  | ||||||
| 		icon.ShowAll(); |  | ||||||
| #endif |  | ||||||
| 	} |  | ||||||
| 	 |  | ||||||
| 	private void ShowContextMenu() |  | ||||||
| 	{ |  | ||||||
| 		Menu popupMenu = new Menu(); // creates the menu  |  | ||||||
|   |  | ||||||
| 		MenuItem miSep = new MenuItem(); |  | ||||||
| 		MenuItem miSep2 = new MenuItem(); |  | ||||||
| 		MenuItem miSep3 = new MenuItem(); |  | ||||||
|  |  | ||||||
| 		ImageMenuItem menuLaunchGUI = new ImageMenuItem ("Launch CASAManager"); |  | ||||||
| 		Image appimg = new Image(Stock.New, IconSize.Menu); |  | ||||||
| 		menuLaunchGUI.Image = appimg; // sets the menu item's image |  | ||||||
| 		menuLaunchGUI.Activated +=new EventHandler(menuLaunchGUI_Activated);		 |  | ||||||
| 		popupMenu.Add(menuLaunchGUI); |  | ||||||
| 		popupMenu.Add(miSep); |  | ||||||
|  |  | ||||||
| 		ImageMenuItem menuLockMiCasa = new ImageMenuItem ("Lock Secrets");	 |  | ||||||
| 	 |  | ||||||
| 		//appimg = new Image(Stock.Close, IconSize.Menu); |  | ||||||
| 		appimg = new Image("gtk-dialog-authentication", IconSize.Menu); |  | ||||||
| 		menuLockMiCasa.Image = appimg; // sets the menu item's image		 |  | ||||||
| 		menuLockMiCasa.Activated +=new EventHandler(menuLockMiCasa_Activated);		 |  | ||||||
|  |  | ||||||
| 		ImageMenuItem menuUnLockMiCasa = new ImageMenuItem ("Unlock Secrets...");		 |  | ||||||
| 		appimg = new Image(Stock.Open, IconSize.Menu); |  | ||||||
| 		menuUnLockMiCasa.Image = appimg; // sets the menu item's image |  | ||||||
| 		menuUnLockMiCasa.Activated +=new EventHandler(menuLockMiCasa_Activated); |  | ||||||
|  |  | ||||||
| 		if (MiCASAStore.IsLocked()) |  | ||||||
| 		{ |  | ||||||
| 			menuLockMiCasa.Sensitive = false;			 |  | ||||||
| 		} |  | ||||||
| 		else |  | ||||||
| 		{ |  | ||||||
| 			menuUnLockMiCasa.Sensitive = false; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		popupMenu.Add(menuLockMiCasa); |  | ||||||
| 		popupMenu.Add(menuUnLockMiCasa); |  | ||||||
| 	 |  | ||||||
| 		popupMenu.Add(miSep2); |  | ||||||
|  |  | ||||||
| 		ImageMenuItem menuDestroyMiCasa = new ImageMenuItem ("Destroy Secrets"); |  | ||||||
| 		appimg = new Image(Stock.Delete, IconSize.Menu); |  | ||||||
| 		menuDestroyMiCasa.Image = appimg; // sets the menu item's image |  | ||||||
| 		menuDestroyMiCasa.Activated +=new EventHandler(menuDestroyMiCasa_Activated); |  | ||||||
| 		popupMenu.Add(menuDestroyMiCasa); |  | ||||||
|  |  | ||||||
| 		ImageMenuItem menuOptionsMiCasa = new ImageMenuItem ("Options ...."); |  | ||||||
| 		menuOptionsMiCasa.Sensitive = false; |  | ||||||
| 		popupMenu.Add(menuOptionsMiCasa); |  | ||||||
| 		 |  | ||||||
| 		popupMenu.Add(miSep3); |  | ||||||
|  |  | ||||||
| 		// creates a menu item with no image as default |  | ||||||
| 		ImageMenuItem menuPopup1 = new ImageMenuItem ("Exit");				 |  | ||||||
| 		appimg = new Image(Stock.Quit, IconSize.Menu); |  | ||||||
| 		menuPopup1.Image = appimg; // sets the menu item's image |  | ||||||
| 		popupMenu.Add(menuPopup1); // adds the menu item to the menu |  | ||||||
| 		 |  | ||||||
| 		// hooks a event when the user clicks the icon |  | ||||||
| 		menuPopup1.Activated += new EventHandler(this.OnPopupClick); |  | ||||||
| 		popupMenu.ShowAll(); // shows everything |  | ||||||
| 		 |  | ||||||
| 		// pops up the actual menu when the user right clicks |  | ||||||
| 		//popupMenu.Popup(null, null, null, IntPtr.Zero, args.Event.Button, args.Event.Time); |  | ||||||
| 		 |  | ||||||
| 		popupMenu.Popup(); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	private void OnImageClick (object o, ButtonPressEventArgs args) // handler for mouse click |  | ||||||
| 	{ |  | ||||||
| 		if (args.Event.Button == 3) //right click |  | ||||||
| 		{ |  | ||||||
| 			ShowContextMenu(); |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 	private void OnPopupClick(object o, EventArgs args) |  | ||||||
| 	{ |  | ||||||
| 		Application.Quit(); // quits the application when the users clicks the popup menu |  | ||||||
| 	} |  | ||||||
| #if W32 |  | ||||||
| 	private void notifyIcon_MouseUp(object sender, System.Windows.Forms.MouseEventArgs e) |  | ||||||
| 	{		 |  | ||||||
| 		if (e.Button == System.Windows.Forms.MouseButtons.Right) |  | ||||||
| 			ShowContextMenu(); |  | ||||||
| 	} |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| 	private void menuLaunchGUI_Activated(object sender, EventArgs e) |  | ||||||
| 	{ |  | ||||||
| 		// launch the GUI |  | ||||||
| 		Process myProcess = new Process(); |  | ||||||
| #if W32 |  | ||||||
| 		ProcessStartInfo myProcessStartInfo = new ProcessStartInfo("CASAManager.exe"); |  | ||||||
| #else |  | ||||||
| 		ProcessStartInfo myProcessStartInfo = new ProcessStartInfo("mono"); |  | ||||||
| 		myProcessStartInfo.Arguments = "/opt/novell/CASA/bin/CASAManager.exe"; |  | ||||||
| #endif								 |  | ||||||
| 		myProcessStartInfo.UseShellExecute = false; |  | ||||||
| 		myProcessStartInfo.RedirectStandardOutput = true; |  | ||||||
| 		myProcess.StartInfo = myProcessStartInfo; |  | ||||||
| 		myProcess.Start(); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	private void menuLockMiCasa_Activated(object sender, EventArgs e) |  | ||||||
| 	{ |  | ||||||
|  |  | ||||||
| 		if (MiCASAStore.IsLocked()) |  | ||||||
| 		{ |  | ||||||
| 			//if( false == miCASA.IsSecretPersistent(1,"") ) |  | ||||||
| 			{    		     |  | ||||||
| 				//Logger.DbgLog("GUI:CasaMain.Login() - IsMasterPasswordSet returned false");    		     |  | ||||||
| #if W32 |  | ||||||
| 				Glade.XML gxmlTemp = new Glade.XML ("../images/casa-1.5.glade", "dialogLogin", null); |  | ||||||
| #endif |  | ||||||
| #if LINUX |  | ||||||
| 				Glade.XML gxmlTemp = new Glade.XML ("/opt/novell/CASA/images/casa-1.5.glade", "dialogLogin", null); |  | ||||||
| #endif |  | ||||||
| 				gxmlTemp.Autoconnect (this); |  | ||||||
| 				//dialogLogin.TransientFor = windowMain;         |  | ||||||
| 				 |  | ||||||
| 				label86.Text = "Enter your Master Password to unlock your secrets"; |  | ||||||
| 				entryMasterPassword3.Text=""; |  | ||||||
| 				label88.Hide(); |  | ||||||
| 				entryMasterPassword4.Hide(); |  | ||||||
| 				dialogLogin.Show(); |  | ||||||
| 			}						 |  | ||||||
| 		} |  | ||||||
| 		else |  | ||||||
| 		{ |  | ||||||
| 			MiCasaRequestReply.Send(MiCasaRequestReply.VERB_LOCK_STORE);			 |  | ||||||
| #if W32	 |  | ||||||
| 			notifyIcon.Icon = m_iconLocked; |  | ||||||
| #endif |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	private void menuDestroyMiCasa_Activated(object sender, EventArgs e) |  | ||||||
| 	{ |  | ||||||
| 		// prompt user 						 |  | ||||||
| 		MessageDialog md=new MessageDialog(mainWindow,Gtk.DialogFlags.Modal, |  | ||||||
| 				Gtk.MessageType.Warning, |  | ||||||
| 				Gtk.ButtonsType.OkCancel, |  | ||||||
| 				"This will destroy all of your secrets.\r\nAre you sure?"); |  | ||||||
|  |  | ||||||
| 			md.SetPosition(Gtk.WindowPosition.Center); |  | ||||||
| 			md.Response +=new ResponseHandler(md_Response); |  | ||||||
| 			md.Modal = true; |  | ||||||
| 			md.Show();						 |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	private void md_Response2(object o, ResponseArgs args) |  | ||||||
| 	{ |  | ||||||
| 		MessageDialog md = (MessageDialog)o; |  | ||||||
| 		if (md != null) |  | ||||||
| 		{ |  | ||||||
| 			md.Destroy();			 |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	private void md_Response(object o, ResponseArgs args) |  | ||||||
| 	{ |  | ||||||
| 		if (args.ResponseId.Equals(Gtk.ResponseType.Ok)) |  | ||||||
| 		{ |  | ||||||
| 			MiCasaRequestReply.Send(MiCasaRequestReply.VERB_REMOVE_ALL_SECRETS); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		MessageDialog md = (MessageDialog)o; |  | ||||||
| 		if (md != null) |  | ||||||
| 		{ |  | ||||||
| 			md.Destroy();			 |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	// test code |  | ||||||
| 	public void okbuttonLogin_clicked(object abj, EventArgs args) |  | ||||||
| 	{     |  | ||||||
| 		if( 0 == miCASA.SetMasterPassword(0, entryMasterPassword3.Text) ) |  | ||||||
| 		{ |  | ||||||
| 			// unlock it |  | ||||||
| 			MiCasaRequestReply.Send(MiCasaRequestReply.VERB_UNLOCK_STORE, entryMasterPassword3.Text); |  | ||||||
| #if W32 |  | ||||||
| 			notifyIcon.Icon = m_iconNormal; |  | ||||||
| #endif |  | ||||||
| 			dialogLogin.Destroy();   |  | ||||||
| 		 |  | ||||||
| 		} |  | ||||||
| 		else |  | ||||||
| 		{ |  | ||||||
| 			// prompt user 						 |  | ||||||
| 			MessageDialog md=new MessageDialog(mainWindow,Gtk.DialogFlags.Modal, |  | ||||||
| 				Gtk.MessageType.Warning, |  | ||||||
| 				Gtk.ButtonsType.Ok, |  | ||||||
| 				"Master Password entered is incorrect"); |  | ||||||
|  |  | ||||||
| 			md.Response +=new ResponseHandler(md_Response2); |  | ||||||
| 			md.SetPosition(Gtk.WindowPosition.Center);		 |  | ||||||
| 			md.Modal = true; |  | ||||||
| 			md.Show(); |  | ||||||
| 		}				 |  | ||||||
| 	} |  | ||||||
|      |  | ||||||
|      |  | ||||||
|      |  | ||||||
| 	public void closebuttonLogin_clicked(object abj, EventArgs args) |  | ||||||
| 	{ |  | ||||||
| 		dialogLogin.Destroy();   |  | ||||||
| 	} |  | ||||||
|      |  | ||||||
|      |  | ||||||
| 	public void OnDialogLoginDeleted(object obj, DeleteEventArgs args)  |  | ||||||
| 	{		    			 |  | ||||||
| 		args.RetVal = true;        		 |  | ||||||
| 	} |  | ||||||
|      |  | ||||||
| 	public void on_entryMasterPassword3_activate(object obj, EventArgs args) |  | ||||||
| 	{ |  | ||||||
| 		if( true == entryMasterPassword4.Visible ) |  | ||||||
| 			entryMasterPassword4.HasFocus = true; |  | ||||||
| 		else if( "" != entryMasterPassword3.Text ) |  | ||||||
| 			okbuttonLogin_clicked(obj, args); |  | ||||||
| 	} |  | ||||||
|      |  | ||||||
| 	public void on_entryMasterPassword4_activate(object obj, EventArgs args) |  | ||||||
| 	{ |  | ||||||
| 		okbuttonLogin_clicked(obj, args); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|     /* |  | ||||||
| 	public bool IsMasterPasswordSet() |  | ||||||
| 	{		    	 |  | ||||||
| 		string MICASA_PASSCODE_BY_MASTER_PASSWD_FILE = "/.miCASAPCByMPasswd"; |  | ||||||
| 		string fileName = Environment.GetEnvironmentVariable("HOME")+MICASA_PASSCODE_BY_MASTER_PASSWD_FILE;           		 |  | ||||||
| 		return (File.Exists(fileName)); |  | ||||||
| 	} |  | ||||||
| 	*/ |  | ||||||
|  |  | ||||||
| 	private void notifyIcon_DoubleClick(object sender, EventArgs e) |  | ||||||
| 	{ |  | ||||||
| 		menuLockMiCasa_Activated(sender, e); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -1,243 +0,0 @@ | |||||||
| using System; |  | ||||||
| using System.Runtime.InteropServices; |  | ||||||
|   |  | ||||||
| using Gtk; |  | ||||||
| using Gdk; |  | ||||||
|   |  | ||||||
| namespace Egg |  | ||||||
| { |  | ||||||
| 	public class TrayIcon : Plug |  | ||||||
| 	{ |  | ||||||
| 		int stamp; |  | ||||||
| 		Orientation orientation; |  | ||||||
| 		 |  | ||||||
| 		int selection_atom; |  | ||||||
| 		int manager_atom; |  | ||||||
| 		int system_tray_opcode_atom; |  | ||||||
| 		int orientation_atom; |  | ||||||
| 		IntPtr manager_window; |  | ||||||
| 		FilterFunc filter; |  | ||||||
| 		 |  | ||||||
| 		public TrayIcon (string name) |  | ||||||
| 		{ |  | ||||||
| 			Title = name; |  | ||||||
| 			stamp = 1; |  | ||||||
| 			orientation = Orientation.Horizontal; |  | ||||||
| 			AddEvents ((int)EventMask.PropertyChangeMask); |  | ||||||
| 			filter = new FilterFunc (ManagerFilter); |  | ||||||
| 		} |  | ||||||
|   |  | ||||||
| 		protected override void OnRealized () |  | ||||||
| 		{ |  | ||||||
| 			base.OnRealized (); |  | ||||||
| 			Display display = Screen.Display; |  | ||||||
| 			IntPtr xdisplay = gdk_x11_display_get_xdisplay (display.Handle); |  | ||||||
| 			selection_atom = XInternAtom (xdisplay, "_NET_SYSTEM_TRAY_S" + Screen.Number.ToString (), false); |  | ||||||
| 			manager_atom = XInternAtom (xdisplay, "MANAGER", false); |  | ||||||
| 			system_tray_opcode_atom = XInternAtom (xdisplay, "_NET_SYSTEM_TRAY_OPCODE", false); |  | ||||||
| 			orientation_atom = XInternAtom (xdisplay, "_NET_SYSTEM_TRAY_ORIENTATION", false); |  | ||||||
| 			UpdateManagerWindow (); |  | ||||||
| 			//Screen.RootWindow.AddFilter (filter); |  | ||||||
| 		} |  | ||||||
|   |  | ||||||
| 		protected override void OnUnrealized () |  | ||||||
| 		{ |  | ||||||
| 			if (manager_window != IntPtr.Zero) |  | ||||||
| 			{ |  | ||||||
| 				Gdk.Window gdkwin = Gdk.Window.LookupForDisplay (Display, (uint)manager_window); |  | ||||||
| 				//gdkwin.RemoveFilter (filter); |  | ||||||
| 			} |  | ||||||
| 			 |  | ||||||
| 			//Screen.RootWindow.RemoveFilter (filter); |  | ||||||
| 			base.OnUnrealized (); |  | ||||||
| 		} |  | ||||||
|   |  | ||||||
| 		private void UpdateManagerWindow () |  | ||||||
| 		{ |  | ||||||
| 			IntPtr xdisplay = gdk_x11_display_get_xdisplay (Display.Handle); |  | ||||||
| 			if (manager_window != IntPtr.Zero) |  | ||||||
| 			{ |  | ||||||
| 				Gdk.Window gdkwin = Gdk.Window.LookupForDisplay (Display, (uint)manager_window); |  | ||||||
| 				//gdkwin.RemoveFilter (filter); |  | ||||||
| 			} |  | ||||||
|   |  | ||||||
| 			XGrabServer (xdisplay); |  | ||||||
|   |  | ||||||
| 			manager_window = XGetSelectionOwner (xdisplay, selection_atom); |  | ||||||
| 			if (manager_window != IntPtr.Zero) |  | ||||||
| 				XSelectInput (xdisplay, manager_window, EventMask.StructureNotifyMask | EventMask.PropertyChangeMask); |  | ||||||
| 			XUngrabServer (xdisplay); |  | ||||||
| 			XFlush (xdisplay); |  | ||||||
|   |  | ||||||
| 			if (manager_window != IntPtr.Zero)  |  | ||||||
| 			{ |  | ||||||
| 				Gdk.Window gdkwin = Gdk.Window.LookupForDisplay (Display, (uint)manager_window); |  | ||||||
| 				//gdkwin.AddFilter (filter); |  | ||||||
| 				SendDockRequest (); |  | ||||||
| 				GetOrientationProperty (); |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
|   |  | ||||||
| 		private void SendDockRequest () |  | ||||||
| 		{ |  | ||||||
| 			SendManagerMessage (SystemTrayMessage.RequestDock, manager_window, Id, 0, 0); |  | ||||||
| 		} |  | ||||||
|   |  | ||||||
| 		private void SendManagerMessage (SystemTrayMessage message, IntPtr window, uint data1, uint data2, uint data3) |  | ||||||
| 		{ |  | ||||||
| 			XClientMessageEvent ev = new XClientMessageEvent (); |  | ||||||
| 			IntPtr display; |  | ||||||
|   |  | ||||||
| 			ev.type = XEventName.ClientMessage; |  | ||||||
| 			ev.window = window; |  | ||||||
| 			ev.message_type = (IntPtr)system_tray_opcode_atom; |  | ||||||
| 			ev.format = 32; |  | ||||||
| 			ev.ptr1 = gdk_x11_get_server_time (GdkWindow.Handle); |  | ||||||
| 			ev.ptr2 = (IntPtr)message; |  | ||||||
| 			ev.ptr3 = (IntPtr)data1; |  | ||||||
| 			ev.ptr4 = (IntPtr)data2; |  | ||||||
| 			ev.ptr5 = (IntPtr)data3; |  | ||||||
|   |  | ||||||
| 			display = gdk_x11_display_get_xdisplay (Display.Handle); |  | ||||||
| 			gdk_error_trap_push (); |  | ||||||
| 			XSendEvent (display, manager_window, false, EventMask.NoEventMask, ref ev); |  | ||||||
| 			gdk_error_trap_pop (); |  | ||||||
| 		} |  | ||||||
|   |  | ||||||
| 		private FilterReturn ManagerFilter (IntPtr xevent, Event evnt) |  | ||||||
| 		{ |  | ||||||
| 			//TODO: Implement; |  | ||||||
| 			return FilterReturn.Continue; |  | ||||||
| 		} |  | ||||||
|   |  | ||||||
| 		private void GetOrientationProperty () |  | ||||||
| 		{ |  | ||||||
| 			//TODO: Implement; |  | ||||||
| 		} |  | ||||||
|   |  | ||||||
| 		[DllImport ("gdk-x11-2.0")] |  | ||||||
| 		static extern IntPtr gdk_x11_display_get_xdisplay (IntPtr display); |  | ||||||
| 		[DllImport ("gdk-x11-2.0")] |  | ||||||
| 		static extern IntPtr gdk_x11_get_server_time (IntPtr window); |  | ||||||
| 		[DllImport ("gdk-x11-2.0")] |  | ||||||
| 		static extern void gdk_error_trap_push (); |  | ||||||
| 		[DllImport ("gdk-x11-2.0")] |  | ||||||
| 		static extern void gdk_error_trap_pop (); |  | ||||||
| 		 |  | ||||||
| 		[DllImport ("libX11", EntryPoint="XInternAtom")] |  | ||||||
| 		extern static int XInternAtom(IntPtr display, string atom_name, bool only_if_exists); |  | ||||||
| 		[DllImport ("libX11")] |  | ||||||
| 		extern static void XGrabServer (IntPtr display); |  | ||||||
| 		[DllImport ("libX11")] |  | ||||||
| 		extern static void XUngrabServer (IntPtr display); |  | ||||||
| 		[DllImport ("libX11")] |  | ||||||
| 		extern static int XFlush (IntPtr display); |  | ||||||
| 		[DllImport ("libX11")] |  | ||||||
| 		extern static IntPtr XGetSelectionOwner (IntPtr display, int atom); |  | ||||||
| 		[DllImport ("libX11")] |  | ||||||
| 		extern static IntPtr XSelectInput (IntPtr window, IntPtr display, EventMask mask); |  | ||||||
| 		[DllImport ("libX11", EntryPoint="XSendEvent")] |  | ||||||
| 		extern static int XSendEvent(IntPtr display, IntPtr window, bool propagate, EventMask event_mask, ref XClientMessageEvent send_event); |  | ||||||
| 	} |  | ||||||
|   |  | ||||||
| 	[Flags] |  | ||||||
| 	internal enum EventMask  |  | ||||||
| 	{ |  | ||||||
| 		NoEventMask             = 0, |  | ||||||
| 		KeyPressMask            = 1<<0, |  | ||||||
| 		KeyReleaseMask          = 1<<1, |  | ||||||
| 		ButtonPressMask         = 1<<2, |  | ||||||
| 		ButtonReleaseMask       = 1<<3, |  | ||||||
| 		EnterWindowMask         = 1<<4, |  | ||||||
| 		LeaveWindowMask         = 1<<5, |  | ||||||
| 		PointerMotionMask       = 1<<6, |  | ||||||
| 		PointerMotionHintMask   = 1<<7, |  | ||||||
| 		Button1MotionMask       = 1<<8, |  | ||||||
| 		Button2MotionMask       = 1<<9, |  | ||||||
| 		Button3MotionMask       = 1<<10, |  | ||||||
| 		Button4MotionMask       = 1<<11, |  | ||||||
| 		Button5MotionMask       = 1<<12, |  | ||||||
| 		ButtonMotionMask        = 1<<13, |  | ||||||
| 		KeymapStateMask         = 1<<14, |  | ||||||
| 		ExposureMask            = 1<<15, |  | ||||||
| 		VisibilityChangeMask    = 1<<16, |  | ||||||
| 		StructureNotifyMask     = 1<<17, |  | ||||||
| 		ResizeRedirectMask      = 1<<18, |  | ||||||
| 		SubstructureNotifyMask  = 1<<19, |  | ||||||
| 		SubstructureRedirectMask= 1<<20, |  | ||||||
| 		FocusChangeMask         = 1<<21, |  | ||||||
| 		PropertyChangeMask      = 1<<22, |  | ||||||
| 		ColormapChangeMask      = 1<<23, |  | ||||||
| 		OwnerGrabButtonMask     = 1<<24 |  | ||||||
| 	} |  | ||||||
|   |  | ||||||
| 	internal enum SystemTrayMessage |  | ||||||
| 	{ |  | ||||||
| 		RequestDock, |  | ||||||
| 		BeginMessage, |  | ||||||
| 		CancelMessage |  | ||||||
| 	} |  | ||||||
|   |  | ||||||
| 	internal enum SystemTrayOrientation |  | ||||||
| 	{ |  | ||||||
| 		Horz, |  | ||||||
| 		Vert |  | ||||||
| 	} |  | ||||||
| 	 |  | ||||||
| 	[StructLayout(LayoutKind.Sequential)] |  | ||||||
| 	internal struct XClientMessageEvent  |  | ||||||
| 	{ |  | ||||||
| 		internal XEventName     type; |  | ||||||
| 		internal IntPtr         serial; |  | ||||||
| 		internal bool           send_event; |  | ||||||
| 		internal IntPtr         display; |  | ||||||
| 		internal IntPtr         window; |  | ||||||
| 		internal IntPtr         message_type; |  | ||||||
| 		internal int            format; |  | ||||||
| 		internal IntPtr         ptr1; |  | ||||||
| 		internal IntPtr         ptr2; |  | ||||||
| 		internal IntPtr         ptr3; |  | ||||||
| 		internal IntPtr         ptr4; |  | ||||||
| 		internal IntPtr         ptr5; |  | ||||||
| 	} |  | ||||||
|   |  | ||||||
| 	internal enum XEventName  |  | ||||||
| 	{ |  | ||||||
| 		KeyPress                = 2, |  | ||||||
| 		KeyRelease              = 3, |  | ||||||
| 		ButtonPress             = 4, |  | ||||||
| 		ButtonRelease           = 5, |  | ||||||
| 		MotionNotify            = 6, |  | ||||||
| 		EnterNotify             = 7, |  | ||||||
| 		LeaveNotify             = 8, |  | ||||||
| 		FocusIn                 = 9, |  | ||||||
| 		FocusOut                = 10, |  | ||||||
| 		KeymapNotify            = 11, |  | ||||||
| 		Expose                  = 12, |  | ||||||
| 		GraphicsExpose          = 13, |  | ||||||
| 		NoExpose                = 14, |  | ||||||
| 		VisibilityNotify        = 15, |  | ||||||
| 		CreateNotify            = 16, |  | ||||||
| 		DestroyNotify           = 17, |  | ||||||
| 		UnmapNotify             = 18, |  | ||||||
| 		MapNotify               = 19, |  | ||||||
| 		MapRequest              = 20, |  | ||||||
| 		ReparentNotify          = 21, |  | ||||||
| 		ConfigureNotify         = 22, |  | ||||||
| 		ConfigureRequest        = 23, |  | ||||||
| 		GravityNotify           = 24, |  | ||||||
| 		ResizeRequest           = 25, |  | ||||||
| 		CirculateNotify         = 26, |  | ||||||
| 		CirculateRequest        = 27, |  | ||||||
| 		PropertyNotify          = 28, |  | ||||||
| 		SelectionClear          = 29, |  | ||||||
| 		SelectionRequest        = 30, |  | ||||||
| 		SelectionNotify         = 31, |  | ||||||
| 		ColormapNotify          = 32, |  | ||||||
| 		ClientMessage           = 33, |  | ||||||
| 		MappingNotify           = 34, |  | ||||||
| 		TimerNotify             = 100, |  | ||||||
| 		 |  | ||||||
| 		LASTEvent |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -1,3 +0,0 @@ | |||||||
| OBJS=\ |  | ||||||
| 	TrayCasa \ |  | ||||||
| 	TrayLib  |  | ||||||
| @@ -1,3 +0,0 @@ | |||||||
| SRC=\ |  | ||||||
| 	TrayCasa.cs \ |  | ||||||
| 	TrayLib.cs |  | ||||||
		Reference in New Issue
	
	Block a user