This topic covers how an EntityManager can lose its connection to the server and reconnect later.
By default, an EntityManager automatically and immediately tries to connect to the server upon construction; ordinarily you do not have to initiate a connection explicitly.
Various circumstances may cause an EntityManager to become disconnected.
In all three cases, the EntityManager enters a disconnected state, a fact easily determined by accessing its IsConnected property. You can also listen on the ConnectionStateChanged event.
The application decided to disconnect in examples #1 and #2. In the 3rd example, the application loses the connection involuntarily and without warning.
The EntityManager responds by setting itself in the disconnected state and then prepares to throw an EntityServerConnectionException. You can (and should) be ready to intercept and handle that exception by attaching a handler to the manager's EntityServerError event.
Your handler next decides how to proceed. Rather than shut down, you may choose to tell the rest of the application about the problem and continue running in a well-defined offline mode.
It is wise to listen to the .NET event that announces the gain and loss of network connectivity. The requisite event differs from one client platform to the next but there always is such an event.
However, do not depend upon it to reflect the true and complete state of affairs. A flakey connection could break in the middle of an attempt to connect. The network connection may be good but the middle tier server could be down. The EntityManager will disconnect and prepare to throw an exception whatever the cause. You can glean the details from the exception in the body of the EntityServerErrorEventArgs .
An EntityManager will not reconnect spontaneously. Once offline, it stays offline until you reconnect explicitly. A DevForce application with a well-stocked entity cache can operate offline effectively for a long time, albeit with limited functionality.
Your application must decide when to try to reconnect. It may decide to try again if a .NET event signals restored network access, or a retry timer fires, or in response to a user action.
Whatever the trigger, your code must call the EntityManager's Connect or ConnectAsync methods; only the async method is available in Silverlight.
As always, code defensively and be prepared for connectivity failures.