summaryrefslogtreecommitdiff
path: root/java/demo/Ice/session/ReapThread.java
blob: 25def1ff2554d93319117a820c27a20d5e89f219 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
// **********************************************************************
//
// Copyright (c) 2003-2006 ZeroC, Inc. All rights reserved.
//
// This copy of Ice is licensed to you under the terms described in the
// ICE_LICENSE file included in this distribution.
//
// **********************************************************************

import Demo.*;

class ReapThread extends Thread
{ 
    static class SessionProxyPair
    {
	SessionProxyPair(Demo.SessionPrx p, SessionI s)
	{
	    proxy = p;
	    session = s;
	}

	Demo.SessionPrx proxy;
	SessionI session;
    };

    synchronized public void
    run()
    {
	while(!_terminated)
	{
	    try
	    {
		wait(_timeout);
	    }
	    catch(InterruptedException e)
	    {
	    }
	    
	    if(!_terminated)
	    {
		java.util.Iterator p = _sessions.iterator();
		while(p.hasNext())
		{
		    SessionProxyPair s = (SessionProxyPair)p.next();
		    try
		    {
			//
			// Session destruction may take time in a
			// real-world example. Therefore the current time
			// is computed for each iteration.
			//
			if((System.currentTimeMillis() - s.session.timestamp()) > _timeout)
			{
			    String name = s.proxy.getName();
			    s.proxy.destroy();
			    System.out.println("The session " + name + " has timed out.");
			    p.remove();
			}
		    }
		    catch(Ice.ObjectNotExistException e)
		    {
			p.remove();
		    }
		}
	    }
	}
    }

    synchronized public void
    terminate()
    {
	_terminated = true;
	notify();
	
	_sessions.clear();
    }

    synchronized public void
    add(SessionPrx proxy, SessionI session)
    {
	_sessions.add(new SessionProxyPair(proxy, session));
    }

    private final long _timeout = 10 * 1000; // 10 seconds.
    private boolean _terminated = false;
    private java.util.List _sessions = new java.util.LinkedList();
}