svn-gvsig-desktop / branches / MULTITHREADING_DEVELOPMENT / libraries / libRemoteServices / src / org / gvsig / remoteClient / taskplanning / retrieving / RequestManager.java @ 5292
History | View | Annotate | Download (5.2 KB)
1 |
/*
|
---|---|
2 |
* Created on 01-oct-2005
|
3 |
*/
|
4 |
package org.gvsig.remoteClient.taskplanning.retrieving; |
5 |
|
6 |
import java.io.File; |
7 |
import java.net.MalformedURLException; |
8 |
import java.util.ArrayList; |
9 |
import java.util.TreeMap; |
10 |
import java.util.Vector; |
11 |
|
12 |
import org.gvsig.remoteClient.taskplanning.IQueue; |
13 |
|
14 |
/**
|
15 |
* pa administrar les tasques (la hist?ria aquella
|
16 |
* de que hi haja una cola per a cada servidor)
|
17 |
* @author Luis W. Sevilla (sevilla_lui@gva.es)
|
18 |
*/
|
19 |
public class RequestManager { |
20 |
private boolean debug = true; |
21 |
|
22 |
private static RequestManager instance; |
23 |
private TreeMap serversTable = new TreeMap(); |
24 |
private RequestManager() {} // Avoid public instantiation |
25 |
|
26 |
public static RequestManager getInstance() { |
27 |
if (instance == null) |
28 |
instance = new RequestManager();
|
29 |
return instance;
|
30 |
} |
31 |
|
32 |
|
33 |
public URLRequest addURLRequest(URLRequest request, RetrieveListener listener) {
|
34 |
try {
|
35 |
if (downloadedFiles.contains(request)) {
|
36 |
for (int i = 0; i < downloadedFiles.size(); i++) { |
37 |
URLRequest r = (URLRequest) downloadedFiles.get(i); |
38 |
if (r.equals(request)) {
|
39 |
System.out.println(request.getUrl()+" is cached at '"+r.getFileName()+"'"); |
40 |
request.setFileName(r.getFileName()); /* Uaaah!
|
41 |
* Si no pose a?? l'event es
|
42 |
* dispara abans que haja
|
43 |
* retornat el request
|
44 |
* reasignat i confon el
|
45 |
* sufixe.
|
46 |
*/
|
47 |
request = r; |
48 |
break;
|
49 |
} |
50 |
} |
51 |
|
52 |
|
53 |
synchronized (this) { |
54 |
if (request.getStatus() == RetrieveEvent.REQUEST_CANCELLED ||
|
55 |
request.getStatus() == RetrieveEvent.REQUEST_FAILED) { |
56 |
// The last requested URL was cancelled or it failed but now it is required again
|
57 |
// so, I have to remove it and add again.
|
58 |
removeURLRequest(request); |
59 |
return addURLRequest(request, listener);
|
60 |
} else if (request.getStatus() == RetrieveEvent.REQUEST_FINISHED) { |
61 |
if (debug)
|
62 |
System.err.println("done job found ("+request.getFileName()+")"); |
63 |
RetrieveEvent event = new RetrieveEvent();
|
64 |
event.setFileName(request.getFileName()); |
65 |
event.setType(RetrieveEvent.REQUEST_FINISHED); |
66 |
listener.transferEventReceived(event); |
67 |
} else {
|
68 |
if (debug)
|
69 |
System.err.println("working job found ("+request.getFileName()+")"); |
70 |
request.lock(); |
71 |
request.addRetrieveListener(listener); |
72 |
request.unlock(); |
73 |
} |
74 |
|
75 |
} |
76 |
} else {
|
77 |
// Pick an unrepeatable fileName
|
78 |
String host = request.getHost();
|
79 |
String fileName = request.getFileName();
|
80 |
File tempDir = new File(tempDirectoryPath); |
81 |
if (!tempDir.exists())
|
82 |
tempDir.mkdir(); |
83 |
String fileNamePrefix = tempDirectoryPath +
|
84 |
File.separator + host +
|
85 |
"-" ;
|
86 |
if (fileName.startsWith(fileNamePrefix))
|
87 |
fileName = fileName.substring(fileNamePrefix.length(), fileName.length()); |
88 |
|
89 |
|
90 |
|
91 |
|
92 |
// get this server's task queue
|
93 |
RetrieveQueue serverQueue = (RetrieveQueue) getQueue(request.getHost()); |
94 |
|
95 |
|
96 |
fileName = fileNamePrefix + fileName; |
97 |
|
98 |
request.setFileName(fileName); |
99 |
synchronized (this) { |
100 |
addDownloadedURLRequest(request); |
101 |
} |
102 |
// TODO
|
103 |
// jo ac? comprovaria quin protocol, m?tode, host, etc... i crearia un
|
104 |
// objecte que tractara la desc?rrega segons el m?tode que li toca.
|
105 |
// algo en plan Strategy's
|
106 |
//
|
107 |
// per exemple si fem URLRetrieveTask una abstracta i tenim
|
108 |
//
|
109 |
// GET de tota la vida
|
110 |
// serverQueue.put(new HTTPGetRetrieveTask(request, listener));
|
111 |
//
|
112 |
// POST
|
113 |
// serverQueue.put(new HTTPPostRetrieveTask(request, listener));
|
114 |
//
|
115 |
// FTP
|
116 |
// serverQueue.put(new FTPRetrieveTask(request, listener));
|
117 |
//
|
118 |
// ????Xarxa local?????
|
119 |
// serverQueue.put(new SMBRetrieveTask(request, listener));
|
120 |
|
121 |
// Enqueue the request and the listener will be notified when done.
|
122 |
request.addRetrieveListener(listener); |
123 |
URLRetrieveTask task = new URLRetrieveTask(request);
|
124 |
serverQueue.put(task); |
125 |
} |
126 |
} catch (MalformedURLException e) { |
127 |
e.printStackTrace(); |
128 |
} |
129 |
return request;
|
130 |
} |
131 |
|
132 |
private IQueue getQueue(String hostName) { |
133 |
RetrieveQueue queue = null;
|
134 |
if (serversTable.containsKey(hostName))
|
135 |
queue = (RetrieveQueue) serversTable.get(hostName); |
136 |
else {
|
137 |
// crea la cola
|
138 |
queue = new RetrieveQueue(hostName);
|
139 |
// pone la cola del server en marcha.
|
140 |
} |
141 |
return queue;
|
142 |
} |
143 |
|
144 |
|
145 |
private Vector downloadedFiles = new Vector(); |
146 |
private final String tempDirectoryPath = System.getProperty("java.io.tmpdir")+"tmp-andami"; |
147 |
/**
|
148 |
* Remove an URL from the system cache. The file will remain in the file
|
149 |
* system for further eventual uses.
|
150 |
* @param request
|
151 |
*/
|
152 |
public void removeURLRequest(URLRequest request) { |
153 |
if (downloadedFiles != null && downloadedFiles.contains(request)) |
154 |
downloadedFiles.remove(request); |
155 |
} |
156 |
/**
|
157 |
* Adds an URL to the table of downloaded files for further uses. If the URL
|
158 |
* already exists in the table its filePath value is updated to the new one and
|
159 |
* the old file itself is removed from the file system.
|
160 |
*
|
161 |
* @param url
|
162 |
* @param filePath
|
163 |
*/
|
164 |
private void addDownloadedURLRequest(URLRequest request){ |
165 |
if (!downloadedFiles.contains(request)) {
|
166 |
downloadedFiles.add(request); |
167 |
} |
168 |
} |
169 |
|
170 |
} |