====== Virtual system ======
{{tag> system virtual}}
A virtual system is not directly connected for online management. A virtual system is basically only a registration mode, where for each system in which a change is generated an implementation request (notification) is assigned to a particular administrator. The administrator must make sure that the change is made to the target system.
In other words, IdM "knows" what accounts and permissions the user should have on the system, but on the real system this is executed by an **implementer** (administrator).
The reason may be the need to manage a large number of systems without the need for demanding integration.
See a quickstart guide for creating a new virtual system with default mapping: [[tutorial:adm:how_to_create_virtual_system]].
The usage and configuration of virtual systems is described in the [[tutorial:adm:modules_vs|Admin tutorial]].
===== Notifications =====
After the request for updating a virtual system is created, the notification is sent to all implementers.
==== Virtual connector ====
For virtual systems, a new connector called **virtual-system-basic** (BasicVirtualConnector.class) was devised.
This connector provides an interface for external communication with a virtual system.
Virtual connector is the first implementation of the connector in the 'czechidm' connector framework.
Connector following operations of the 'czechidm' connector framework:
* **IcCanRead**,
* **IcCanCreate**,
* **IcCanUpdate**,
* **IcCanDelete**,
* **IcCanGenSchema**,
* **IcCanSearch** (Search in VS is supported only during reconciliation, it returns all accounts. As of now, no connector filter can be used.)
==== Deleting a virtual system ====
Before any virtual ystem is deleted in the CC module, it's necessary to call the VS module and enforce the deletion of all connected entities (on the deleted system).
For this is used '**SystemEventType.DELETE**' event and processor '**system-delete-processor**'.
The sequence of deleting a VS module:
- Check existing unresolved VS requests - If an unresolved vs request exists, then it isn't possible to delete the system (it throws an exception).
- Delete all archived VS requests for the system.
- Delete all VS accounts for connector key from the system.
- Delete VS account form definition for the system.
- Delete all VS system implementers for the system.