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 package info.magnolia.module.exchangesimple;
35
36 import info.magnolia.cms.exchange.ActivationManagerFactory;
37 import info.magnolia.cms.exchange.ExchangeException;
38 import info.magnolia.cms.exchange.Subscriber;
39 import info.magnolia.module.exchangesimple.monitor.ActivationMonitor;
40 import info.magnolia.objectfactory.Components;
41
42 import java.io.File;
43 import java.io.FileInputStream;
44 import java.io.OutputStream;
45 import java.net.HttpURLConnection;
46 import java.util.Collection;
47
48 import org.apache.commons.io.IOUtils;
49 import org.apache.commons.lang.StringUtils;
50 import org.slf4j.Logger;
51 import org.slf4j.LoggerFactory;
52
53
54
55
56
57
58 public class Transporter {
59
60 private static Logger log = LoggerFactory.getLogger(Transporter.class);
61
62
63
64
65 public static final String BOUNDARY = "mgnlExchange-cfc93688d385";
66
67
68
69
70
71
72
73
74 public static void transport(HttpURLConnection connection, ActivationContent activationContent)
75 throws ExchangeException {
76 File tempFile = null;
77 FileInputStream is = null;
78 OutputStream os = null;
79
80 try {
81 tempFile = activationContent.getTempFile();
82
83
84
85 connection.setDoOutput(true);
86 connection.setDoInput(true);
87 connection.setUseCaches(false);
88 connection.setRequestProperty("Content-type", "multipart/form-data; boundary=" + BOUNDARY);
89 connection.setRequestProperty("Cache-Control", "no-cache");
90
91 is = new FileInputStream(tempFile);
92 if (tempFile.length() > Integer.MAX_VALUE) {
93 connection.setChunkedStreamingMode(4096);
94 }
95 else {
96 connection.setFixedLengthStreamingMode((int) tempFile.length());
97 }
98
99 long start = System.currentTimeMillis();
100 os = connection.getOutputStream();
101 long end = System.currentTimeMillis();
102
103 String subscriberName = null;
104 Collection<Subscriber> subscribers = ActivationManagerFactory.getActivationManager().getSubscribers();
105 for (Subscriber subscriber : subscribers) {
106 if (subscriber.getURL().equals(StringUtils.substringBefore(connection.getURL().toString(), "/" + BaseSyndicatorImpl.DEFAULT_HANDLER))) {
107 subscriberName = subscriber.getName();
108 }
109 }
110 ActivationMonitor activationMonitor = Components.getComponent(ActivationMonitor.class);
111 activationMonitor.setSubscriberResponseTime(subscriberName, end - start);
112
113 IOUtils.copy(is, os);
114 } catch (Exception e) {
115 String msg = "Simple exchange transport failed: " + e.getMessage();
116 log.error(msg, e);
117 throw new ExchangeException(msg, e);
118 } finally {
119 IOUtils.closeQuietly(is);
120 IOUtils.closeQuietly(os);
121 }
122 }
123 }