mirror of
https://github.com/Kopano-dev/kopano-ol-extension.git
synced 2023-10-10 13:37:40 +02:00
Cleaned up ZPushLocalStore, merged into IStore.
This commit is contained in:
parent
65a46510c1
commit
d1bbb221b4
@ -39,7 +39,7 @@ namespace Acacia.Features.GAB
|
|||||||
private readonly Dictionary<string, GABHandler> _gabsByDomainName = new Dictionary<string, GABHandler>();
|
private readonly Dictionary<string, GABHandler> _gabsByDomainName = new Dictionary<string, GABHandler>();
|
||||||
private readonly HashSet<string> _gabFolders = new HashSet<string>();
|
private readonly HashSet<string> _gabFolders = new HashSet<string>();
|
||||||
private readonly HashSet<string> _domains = new HashSet<string>();
|
private readonly HashSet<string> _domains = new HashSet<string>();
|
||||||
private ZPushLocalStore _store;
|
private IStore _store;
|
||||||
private int _processing;
|
private int _processing;
|
||||||
|
|
||||||
public FeatureGAB()
|
public FeatureGAB()
|
||||||
@ -316,11 +316,11 @@ namespace Acacia.Features.GAB
|
|||||||
// Delete any contacts folders in the local store
|
// Delete any contacts folders in the local store
|
||||||
if (DeleteExistingFolder)
|
if (DeleteExistingFolder)
|
||||||
{
|
{
|
||||||
using (ZPushLocalStore store = ZPushLocalStore.GetInstance(ThisAddIn.Instance))
|
using (IStore store = ZPushLocalStore.GetInstance(ThisAddIn.Instance))
|
||||||
{
|
{
|
||||||
if (store != null)
|
if (store != null)
|
||||||
{
|
{
|
||||||
using (IFolder root = store.RootFolder)
|
using (IFolder root = store.GetRootFolder())
|
||||||
{
|
{
|
||||||
foreach (IFolder folder in root.GetSubFolders<IFolder>())
|
foreach (IFolder folder in root.GetSubFolders<IFolder>())
|
||||||
{
|
{
|
||||||
@ -416,7 +416,7 @@ namespace Acacia.Features.GAB
|
|||||||
return null;
|
return null;
|
||||||
|
|
||||||
// Try to find the existing GAB
|
// Try to find the existing GAB
|
||||||
using (IFolder root = _store.RootFolder)
|
using (IFolder root = _store.GetRootFolder())
|
||||||
{
|
{
|
||||||
IAddressBook gab = FindGABForDomain(root, domainName);
|
IAddressBook gab = FindGABForDomain(root, domainName);
|
||||||
if (gab == null)
|
if (gab == null)
|
||||||
@ -538,7 +538,7 @@ namespace Acacia.Features.GAB
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
bool deletedSomething = false;
|
bool deletedSomething = false;
|
||||||
using (IFolder root = _store.RootFolder)
|
using (IFolder root = _store.GetRootFolder())
|
||||||
{
|
{
|
||||||
foreach (IFolder subfolder in root.GetSubFolders<IFolder>())
|
foreach (IFolder subfolder in root.GetSubFolders<IFolder>())
|
||||||
{
|
{
|
||||||
|
@ -57,6 +57,13 @@ namespace Acacia.Stubs
|
|||||||
|
|
||||||
IRecipient ResolveRecipient(string name);
|
IRecipient ResolveRecipient(string name);
|
||||||
|
|
||||||
|
IStore AddFileStore(string path);
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Returns the stores. The caller is responsible for disposing.
|
||||||
|
/// </summary>
|
||||||
|
IEnumerable<IStore> Stores { get; }
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -54,6 +54,7 @@ namespace Acacia.Stubs
|
|||||||
|
|
||||||
IEnumerable<FolderType> GetSubFolders<FolderType>()
|
IEnumerable<FolderType> GetSubFolders<FolderType>()
|
||||||
where FolderType : IFolder;
|
where FolderType : IFolder;
|
||||||
|
IEnumerable<IFolder> GetSubFolders();
|
||||||
|
|
||||||
FolderType GetSubFolder<FolderType>(string name)
|
FolderType GetSubFolder<FolderType>(string name)
|
||||||
where FolderType : IFolder;
|
where FolderType : IFolder;
|
||||||
|
@ -24,9 +24,18 @@ namespace Acacia.Stubs
|
|||||||
{
|
{
|
||||||
public interface IStore : IDisposable
|
public interface IStore : IDisposable
|
||||||
{
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Returns the root folder.
|
||||||
|
/// </summary>
|
||||||
|
/// <returns>The root folder. The caller is responsible for disposing.</returns>
|
||||||
IFolder GetRootFolder();
|
IFolder GetRootFolder();
|
||||||
IItem GetItemFromID(string id);
|
IItem GetItemFromID(string id);
|
||||||
string DisplayName { get; }
|
string DisplayName { get; }
|
||||||
string StoreID { get; }
|
string StoreID { get; }
|
||||||
|
|
||||||
|
bool IsFileStore { get; }
|
||||||
|
string FilePath { get; }
|
||||||
|
|
||||||
|
void EmptyDeletedItems();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -94,7 +94,7 @@ namespace Acacia.Stubs.OutlookWrappers
|
|||||||
Microsoft.Office.Core.COMAddIns addIns = _app.COMAddIns;
|
Microsoft.Office.Core.COMAddIns addIns = _app.COMAddIns;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
foreach(Microsoft.Office.Core.COMAddIn comAddin in addIns)
|
foreach (Microsoft.Office.Core.COMAddIn comAddin in addIns)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
@ -196,13 +196,44 @@ namespace Acacia.Stubs.OutlookWrappers
|
|||||||
using (ComRelease com = new ComRelease())
|
using (ComRelease com = new ComRelease())
|
||||||
{
|
{
|
||||||
NSOutlook.NameSpace session = com.Add(_app.Session);
|
NSOutlook.NameSpace session = com.Add(_app.Session);
|
||||||
NSOutlook.Recipient recipient = session.CreateRecipient(name);
|
// Add recipient, unlock after Resolve (which might throw) to wrap
|
||||||
|
NSOutlook.Recipient recipient = com.Add(session.CreateRecipient(name));
|
||||||
if (recipient == null)
|
if (recipient == null)
|
||||||
return null;
|
return null;
|
||||||
com.Add(recipient);
|
|
||||||
recipient.Resolve();
|
recipient.Resolve();
|
||||||
return Mapping.Wrap(com.Remove(recipient));
|
return Mapping.Wrap(com.Remove(recipient));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public IStore AddFileStore(string path)
|
||||||
|
{
|
||||||
|
using (ComRelease com = new ComRelease())
|
||||||
|
{
|
||||||
|
NSOutlook.NameSpace session = com.Add(_app.Session);
|
||||||
|
|
||||||
|
// Add the store
|
||||||
|
session.AddStore(path);
|
||||||
|
|
||||||
|
// And fetch it and wrap
|
||||||
|
NSOutlook.Stores stores = com.Add(session.Stores);
|
||||||
|
return StoreWrapper.Wrap(stores[stores.Count]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public IEnumerable<IStore> Stores
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
using (ComRelease com = new ComRelease())
|
||||||
|
{
|
||||||
|
NSOutlook.NameSpace session = com.Add(_app.Session);
|
||||||
|
NSOutlook.Stores stores = com.Add(session.Stores);
|
||||||
|
foreach (NSOutlook.Store store in stores)
|
||||||
|
{
|
||||||
|
yield return StoreWrapper.Wrap(store);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -296,6 +296,11 @@ namespace Acacia.Stubs.OutlookWrappers
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public IEnumerable<IFolder> GetSubFolders()
|
||||||
|
{
|
||||||
|
return GetSubFolders<IFolder>();
|
||||||
|
}
|
||||||
|
|
||||||
public FolderType GetSubFolder<FolderType>(string name)
|
public FolderType GetSubFolder<FolderType>(string name)
|
||||||
where FolderType : IFolder
|
where FolderType : IFolder
|
||||||
{
|
{
|
||||||
|
@ -24,9 +24,9 @@ using NSOutlook = Microsoft.Office.Interop.Outlook;
|
|||||||
|
|
||||||
namespace Acacia.Stubs.OutlookWrappers
|
namespace Acacia.Stubs.OutlookWrappers
|
||||||
{
|
{
|
||||||
public class StoreWrapper : ComWrapper, IStore
|
class StoreWrapper : ComWrapper, IStore
|
||||||
{
|
{
|
||||||
public static IStore Wrap(NSOutlook.Store store)
|
internal static IStore Wrap(NSOutlook.Store store)
|
||||||
{
|
{
|
||||||
return store == null ? null : new StoreWrapper(store);
|
return store == null ? null : new StoreWrapper(store);
|
||||||
}
|
}
|
||||||
@ -64,5 +64,30 @@ namespace Acacia.Stubs.OutlookWrappers
|
|||||||
|
|
||||||
public string DisplayName { get { return _store.DisplayName; } }
|
public string DisplayName { get { return _store.DisplayName; } }
|
||||||
public string StoreID { get { return _store.StoreID; } }
|
public string StoreID { get { return _store.StoreID; } }
|
||||||
|
|
||||||
|
public bool IsFileStore { get { return _store.IsDataFileStore; } }
|
||||||
|
public string FilePath { get { return _store.FilePath; } }
|
||||||
|
|
||||||
|
public void EmptyDeletedItems()
|
||||||
|
{
|
||||||
|
using (ComRelease com = new ComRelease())
|
||||||
|
{
|
||||||
|
NSOutlook.MAPIFolder f = _store.GetDefaultFolder(NSOutlook.OlDefaultFolders.olFolderDeletedItems);
|
||||||
|
if (f != null)
|
||||||
|
{
|
||||||
|
com.Add(f);
|
||||||
|
|
||||||
|
// Normal enumeration fails when deleting. Do it like this.
|
||||||
|
NSOutlook.Folders folders = com.Add(f.Folders);
|
||||||
|
for (int i = folders.Count; i > 0; --i)
|
||||||
|
com.Add(folders[i]).Delete();
|
||||||
|
|
||||||
|
NSOutlook.Items items = com.Add(f.Items);
|
||||||
|
for (int i = items.Count; i > 0; --i)
|
||||||
|
com.Add(items[i]).Delete();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,58 +30,32 @@ namespace Acacia.ZPush
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Manages a local store in which Z-Push data is stored.
|
/// Manages a local store in which Z-Push data is stored.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// TODO: merge with Store where possible
|
public static class ZPushLocalStore
|
||||||
public class ZPushLocalStore : ComWrapper
|
|
||||||
{
|
{
|
||||||
private NSOutlook.Store _store;
|
/// <summary>
|
||||||
|
/// Returns or creates the local store.
|
||||||
public IFolder RootFolder
|
/// </summary>
|
||||||
|
/// <returns>The store, or null on error. If a store is returned, the caller is responsible for disposing.</returns>
|
||||||
|
public static IStore GetInstance(IAddIn addIn)
|
||||||
{
|
{
|
||||||
get
|
IStore store = OpenOrCreateInstance(addIn);
|
||||||
|
if (store == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
try
|
||||||
{
|
{
|
||||||
return Mapping.Wrap<IFolder>(_store.GetRootFolder());
|
HideAllFolders(store);
|
||||||
|
return store;
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
store.Dispose();
|
||||||
|
throw e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public string StoreId { get { return _store.StoreID; } }
|
private static IStore OpenOrCreateInstance(IAddIn addIn)
|
||||||
|
{
|
||||||
private ZPushLocalStore(NSOutlook.Store store)
|
|
||||||
{
|
|
||||||
this._store = store;
|
|
||||||
HideAllFolders();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void DoRelease()
|
|
||||||
{
|
|
||||||
ComRelease.Release(_store);
|
|
||||||
_store = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
private bool IsCustomFolder(IFolder folder)
|
|
||||||
{
|
|
||||||
return Features.GAB.FeatureGAB.IsGABContactsFolder(folder);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void HideAllFolders()
|
|
||||||
{
|
|
||||||
if (GlobalOptions.INSTANCE.LocalFolders_Hide)
|
|
||||||
{
|
|
||||||
// Hide the folders that are not custom folders
|
|
||||||
using (ComRelease com = new ComRelease())
|
|
||||||
{
|
|
||||||
foreach (NSOutlook.Folder sub in com.Add(com.Add(_store.GetRootFolder()).Folders))
|
|
||||||
{
|
|
||||||
using (IFolder wrapped = Mapping.Wrap<IFolder>(sub))
|
|
||||||
{
|
|
||||||
wrapped.AttrHidden = !IsCustomFolder(wrapped);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static ZPushLocalStore GetInstance(IAddIn addIn)
|
|
||||||
{
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
// Try to find the existing store
|
// Try to find the existing store
|
||||||
@ -94,9 +68,9 @@ namespace Acacia.ZPush
|
|||||||
Logger.Instance.Debug(typeof(ZPushLocalStore), "Opening store with prefix {0}", prefix);
|
Logger.Instance.Debug(typeof(ZPushLocalStore), "Opening store with prefix {0}", prefix);
|
||||||
|
|
||||||
// See if a store with this prefix exists
|
// See if a store with this prefix exists
|
||||||
NSOutlook.Store store = FindInstance(addIn, prefix);
|
IStore store = FindInstance(addIn, prefix);
|
||||||
if (store != null)
|
if (store != null)
|
||||||
return new ZPushLocalStore(store);
|
return store;
|
||||||
|
|
||||||
// Doesn't exist, create it
|
// Doesn't exist, create it
|
||||||
Logger.Instance.Debug(typeof(ZPushLocalStore), "No existing store found");
|
Logger.Instance.Debug(typeof(ZPushLocalStore), "No existing store found");
|
||||||
@ -114,8 +88,7 @@ namespace Acacia.ZPush
|
|||||||
|
|
||||||
// Path found, create the store
|
// Path found, create the store
|
||||||
Logger.Instance.Info(typeof(ZPushLocalStore), "Creating new store: {0}", path);
|
Logger.Instance.Info(typeof(ZPushLocalStore), "Creating new store: {0}", path);
|
||||||
addIn.RawApp.Session.AddStore(path);
|
store = addIn.AddFileStore(path);
|
||||||
store = addIn.RawApp.Session.Stores[addIn.RawApp.Session.Stores.Count];
|
|
||||||
Logger.Instance.Debug(typeof(ZPushLocalStore), "Created new store: {0}", store.FilePath);
|
Logger.Instance.Debug(typeof(ZPushLocalStore), "Created new store: {0}", store.FilePath);
|
||||||
|
|
||||||
// Set the display name
|
// Set the display name
|
||||||
@ -125,7 +98,7 @@ namespace Acacia.ZPush
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Done
|
// Done
|
||||||
return new ZPushLocalStore(store);
|
return store;
|
||||||
}
|
}
|
||||||
catch(System.Exception e)
|
catch(System.Exception e)
|
||||||
{
|
{
|
||||||
@ -134,38 +107,42 @@ namespace Acacia.ZPush
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static NSOutlook.Store FindInstance(IAddIn addIn, string prefix)
|
private static IStore FindInstance(IAddIn addIn, string prefix)
|
||||||
{
|
{
|
||||||
foreach (NSOutlook.Store store in addIn.RawApp.Session.Stores)
|
foreach (IStore store in addIn.Stores)
|
||||||
{
|
{
|
||||||
if (store.IsDataFileStore && store.FilePath.StartsWith(prefix))
|
if (store.IsFileStore && store.FilePath.StartsWith(prefix))
|
||||||
{
|
{
|
||||||
Logger.Instance.Info(typeof(ZPushLocalStore), "Opening existing store: {0}", store.FilePath);
|
Logger.Instance.Info(typeof(ZPushLocalStore), "Opening existing store: {0}", store.FilePath);
|
||||||
return store;
|
return store;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
store.Dispose();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void EmptyDeletedItems()
|
private static bool IsCustomFolder(IFolder folder)
|
||||||
{
|
{
|
||||||
using (ComRelease com = new ComRelease())
|
return Features.GAB.FeatureGAB.IsGABContactsFolder(folder);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void HideAllFolders(IStore store)
|
||||||
|
{
|
||||||
|
if (GlobalOptions.INSTANCE.LocalFolders_Hide)
|
||||||
{
|
{
|
||||||
NSOutlook.MAPIFolder f = _store.GetDefaultFolder(NSOutlook.OlDefaultFolders.olFolderDeletedItems);
|
// Hide the folders that are not custom folders
|
||||||
if (f != null)
|
using (ComRelease com = new ComRelease())
|
||||||
{
|
{
|
||||||
com.Add(f);
|
foreach(IFolder sub in store.GetRootFolder().GetSubFolders())
|
||||||
|
{
|
||||||
// Normal enumeration fails when deleting. Do it like this.
|
sub.AttrHidden = !IsCustomFolder(sub);
|
||||||
NSOutlook.Folders folders = com.Add(f.Folders);
|
}
|
||||||
for (int i = folders.Count; i > 0; --i)
|
|
||||||
com.Add(folders[i]).Delete();
|
|
||||||
|
|
||||||
NSOutlook.Items items = com.Add(f.Items);
|
|
||||||
for (int i = items.Count; i > 0; --i)
|
|
||||||
com.Add(items[i]).Delete();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user