Click or drag to resize

SingleInstancePluginAttribute Class

Specifies plugin which allows only single instance per iikoFront group. While all plugin instances are loaded by each iikoFront by default, this attribute restricts only one iikoFront to load single plugin instance.
Inheritance Hierarchy
SystemObject
  SystemAttribute
    Resto.Front.Api.V5.AttributesSingleInstancePluginAttribute

Namespace:  Resto.Front.Api.V5.Attributes
Assembly:  Resto.Front.Api.V5 (in Resto.Front.Api.V5.dll)
Syntax
C#
public sealed class SingleInstancePluginAttribute : Attribute

The SingleInstancePluginAttribute type exposes the following members.

Constructors
  NameDescription
Public methodSingleInstancePluginAttribute
Initializes a new instance of the SingleInstancePluginAttribute class
Top
Properties
  NameDescription
Public propertyTypeId
When implemented in a derived class, gets a unique identifier for this Attribute.
(Inherited from Attribute.)
Top
Methods
  NameDescription
Public methodEquals
Returns a value that indicates whether this instance is equal to a specified object.
(Inherited from Attribute.)
Public methodGetHashCode
Returns the hash code for this instance.
(Inherited from Attribute.)
Public methodGetType
Gets the Type of the current instance.
(Inherited from Object.)
Public methodIsDefaultAttribute
When overridden in a derived class, indicates whether the value of this instance is the default value for the derived class.
(Inherited from Attribute.)
Public methodMatch
When overridden in a derived class, returns a value that indicates whether this instance equals a specified object.
(Inherited from Attribute.)
Public methodToString
Returns a string that represents the current object.
(Inherited from Object.)
Top
Remarks
Apply this attribute to your root plugin class (which implements IFrontPlugin), if plugin will be installed to all iikoFronts, but several plugin instances shouldn't process same data and notifications.
For example, this can be useful for monitoring and publishing order changes to external server. Single plugin instance is enough for such tasks and multiple instances may be unwanted. Multiple plugin instances on each iikoFront will see same data due to synchronization between iikoFronts, so parallel repeated processing will lead to duplicated server calls.
Examples
[SingleInstancePlugin]
public sealed class MyPlugin : MarshalByRefObject, IFrontPlugin
{ ... }
See Also