diff options
author | vnugent <public@vaughnnugent.com> | 2023-06-22 21:16:28 -0400 |
---|---|---|
committer | vnugent <public@vaughnnugent.com> | 2023-06-22 21:16:28 -0400 |
commit | 1a8ab1457244d15b19ddcc94958f645f5ec2abc7 (patch) | |
tree | 3994806e0737cf6f519a72cca8836c6e81eac7e2 /plugins/ObjectCacheServer/src/Distribution/INodeDiscoveryCollection.cs | |
parent | dc0fc53fd3c3f6c32c8b0d063922c7018fa2c48f (diff) |
Save checkpoint
Diffstat (limited to 'plugins/ObjectCacheServer/src/Distribution/INodeDiscoveryCollection.cs')
-rw-r--r-- | plugins/ObjectCacheServer/src/Distribution/INodeDiscoveryCollection.cs | 58 |
1 files changed, 0 insertions, 58 deletions
diff --git a/plugins/ObjectCacheServer/src/Distribution/INodeDiscoveryCollection.cs b/plugins/ObjectCacheServer/src/Distribution/INodeDiscoveryCollection.cs deleted file mode 100644 index d69da40..0000000 --- a/plugins/ObjectCacheServer/src/Distribution/INodeDiscoveryCollection.cs +++ /dev/null @@ -1,58 +0,0 @@ -/* -* Copyright (c) 2023 Vaughn Nugent -* -* Library: VNLib -* Package: ObjectCacheServer -* File: INodeDiscoveryCollection.cs -* -* INodeDiscoveryCollection.cs is part of ObjectCacheServer which is -* part of the larger VNLib collection of libraries and utilities. -* -* ObjectCacheServer is free software: you can redistribute it and/or modify -* it under the terms of the GNU Affero General Public License as -* published by the Free Software Foundation, either version 3 of the -* License, or (at your option) any later version. -* -* ObjectCacheServer is distributed in the hope that it will be useful, -* but WITHOUT ANY WARRANTY; without even the implied warranty of -* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -* GNU Affero General Public License for more details. -* -* You should have received a copy of the GNU Affero General Public License -* along with this program. If not, see https://www.gnu.org/licenses/. -*/ - -using System.Collections.Generic; - -using VNLib.Data.Caching.Extensions; - -namespace VNLib.Data.Caching.ObjectCache.Server.Distribution -{ - internal interface INodeDiscoveryCollection - { - /// <summary> - /// Begins a new discovery and gets an enumerator for the discovery process - /// </summary> - /// <returns>An enumerator that simplifies discovery of unique nodes</returns> - INodeDiscoveryEnumerator BeginDiscovery(); - - /// <summary> - /// Begins a new discovery and gets an enumerator for the discovery process - /// </summary> - /// <param name="initialPeers">An initial collection of peers to add to the enumeration</param> - /// <returns>An enumerator that simplifies discovery of unique nodes</returns> - INodeDiscoveryEnumerator BeginDiscovery(IEnumerable<ICachePeerAdvertisment> initialPeers); - - /// <summary> - /// Gets a snapshot of all discovered nodes in the current collection. - /// </summary> - /// <returns>The current collection of notes</returns> - ICachePeerAdvertisment[] GetAllNodes(); - - /// <summary> - /// Completes a discovery process and updates the collection with the results - /// </summary> - /// <param name="enumerator">The enumerator used to collect discovered nodes</param> - void CompleteDiscovery(INodeDiscoveryEnumerator enumerator); - } -} |