jdk/src/share/classes/sun/net/www/http/HttpCapture.java
author jccollet
Mon, 06 Jul 2009 15:13:48 +0200
changeset 3217 07b65d4b6227
parent 3059 2975ff687a6b
child 3866 34cd368bd2dd
permissions -rw-r--r--
6856856: NPE in HTTP protocol handler logging Summary: Fixed the NPE and Moved the java.util.logging dependency to a single class and used reflection to make it a soft one. Reviewed-by: chegar
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
3059
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
     1
/*
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
     2
 * Copyright 2009 Sun Microsystems, Inc.  All Rights Reserved.
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
     4
 *
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Sun designates this
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
     9
 * by Sun in the LICENSE file that accompanied this code.
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    10
 *
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    15
 * accompanied this code).
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    16
 *
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    20
 *
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    21
 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    22
 * CA 95054 USA or visit www.sun.com if you need additional information or
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    23
 * have any questions.
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    24
 */
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    25
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    26
package sun.net.www.http;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    27
import java.io.*;
3217
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    28
import java.lang.reflect.InvocationTargetException;
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    29
import java.lang.reflect.Method;
3059
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    30
import java.util.ArrayList;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    31
import java.util.logging.Level;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    32
import java.util.logging.Logger;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    33
import sun.net.NetProperties;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    34
import java.util.regex.*;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    35
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    36
/**
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    37
 * Main class of the HTTP traffic capture tool.
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    38
 * Captures are triggered by the sun.net.http.captureRules system property.
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    39
 * If set, it should point to a file containing the capture rules.
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    40
 * Format for the file is simple:
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    41
 * - 1 rule per line
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    42
 * - Lines starting with a # are considered comments and ignored
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    43
 * - a rule is a pair of a regular expression and file pattern, separated by a comma
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    44
 * - The regular expression is applied to URLs, if it matches, the traffic for
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    45
 *   that URL will be captured in the associated file.
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    46
 * - if the file name contains a '%d', then that sequence will be replaced by a
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    47
 *   unique random number for each URL. This allow for multi-threaded captures
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    48
 *   of URLs matching the same pattern.
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    49
 * - Rules are checked in sequence, in the same order as in the file, until a
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    50
 *   match is found or the end of the list is reached.
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    51
 *
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    52
 * Examples of rules:
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    53
 * www\.sun\.com , sun%d.log
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    54
 * yahoo\.com\/.*asf , yahoo.log
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    55
 *
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    56
 * @author jccollet
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    57
 */
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    58
public class HttpCapture {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    59
    private File file = null;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    60
    private boolean incoming = true;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    61
    private BufferedWriter out = null;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    62
    private static boolean initialized = false;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    63
    private static volatile ArrayList<Pattern> patterns = null;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
    64
    private static volatile ArrayList<String> capFiles = null;
3217
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    65
    /* Logging is done in an ugly way so that it does not require the presence
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    66
     * the java.util.logging package. If the Logger class is not available, then
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    67
     * logging is turned off. This is for helping the modularization effort.
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    68
     */
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    69
    private static Object logger = null;
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    70
    private static boolean logging = false;
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    71
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    72
    static {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    73
        Class cl;
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    74
        try {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    75
            cl = Class.forName("java.util.logging.Logger");
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    76
        } catch (ClassNotFoundException ex) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    77
            cl = null;
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    78
        }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    79
        if (cl != null) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    80
            try {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    81
                Method m = cl.getMethod("getLogger", String.class);
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    82
                logger = m.invoke(null, "sun.net.www.protocol.http.HttpURLConnection");
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    83
                logging = true;
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    84
            } catch (NoSuchMethodException noSuchMethodException) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    85
            } catch (SecurityException securityException) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    86
            } catch (IllegalAccessException illegalAccessException) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    87
            } catch (IllegalArgumentException illegalArgumentException) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    88
            } catch (InvocationTargetException invocationTargetException) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    89
            }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    90
        }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    91
    }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    92
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    93
    public static void fine(String s) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    94
        if (logging) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    95
            ((Logger)logger).fine(s);
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    96
        }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    97
    }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    98
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
    99
    public static void finer(String s) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   100
        if (logging) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   101
            ((Logger)logger).finer(s);
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   102
        }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   103
    }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   104
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   105
    public static void finest(String s) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   106
        if (logging) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   107
            ((Logger)logger).finest(s);
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   108
        }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   109
    }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   110
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   111
    public static void severe(String s) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   112
        if (logging) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   113
            ((Logger)logger).finest(s);
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   114
        }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   115
    }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   116
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   117
    public static void info(String s) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   118
        if (logging) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   119
            ((Logger)logger).info(s);
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   120
        }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   121
    }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   122
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   123
    public static void warning(String s) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   124
        if (logging) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   125
            ((Logger)logger).warning(s);
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   126
        }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   127
    }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   128
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   129
    public static boolean isLoggable(String level) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   130
        if (!logging) {
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   131
            return false;
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   132
        }
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   133
        return ((Logger)logger).isLoggable(Level.parse(level));
07b65d4b6227 6856856: NPE in HTTP protocol handler logging
jccollet
parents: 3059
diff changeset
   134
    }
3059
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   135
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   136
    private static synchronized void init() {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   137
        initialized = true;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   138
        String rulesFile = java.security.AccessController.doPrivileged(
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   139
            new java.security.PrivilegedAction<String>() {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   140
                public String run() {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   141
                    return NetProperties.get("sun.net.http.captureRules");
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   142
                }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   143
            });
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   144
        if (rulesFile != null && !rulesFile.isEmpty()) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   145
            BufferedReader in;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   146
            try {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   147
                in = new BufferedReader(new FileReader(rulesFile));
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   148
            } catch (FileNotFoundException ex) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   149
                return;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   150
            }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   151
            try {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   152
                String line = in.readLine();
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   153
                while (line != null) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   154
                    line = line.trim();
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   155
                    if (!line.startsWith("#")) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   156
                        // skip line if it's a comment
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   157
                        String[] s = line.split(",");
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   158
                        if (s.length == 2) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   159
                            if (patterns == null) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   160
                                patterns = new ArrayList<Pattern>();
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   161
                                capFiles = new ArrayList<String>();
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   162
                            }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   163
                            patterns.add(Pattern.compile(s[0].trim()));
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   164
                            capFiles.add(s[1].trim());
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   165
                        }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   166
                    }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   167
                    line = in.readLine();
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   168
                }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   169
            } catch (IOException ioe) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   170
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   171
            } finally {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   172
                try {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   173
                    in.close();
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   174
                } catch (IOException ex) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   175
                }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   176
            }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   177
        }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   178
    }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   179
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   180
    private static synchronized boolean isInitialized() {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   181
        return initialized;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   182
    }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   183
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   184
    private HttpCapture(File f, java.net.URL url) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   185
        file = f;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   186
        try {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   187
            out = new BufferedWriter(new FileWriter(file, true));
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   188
            out.write("URL: " + url + "\n");
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   189
        } catch (IOException ex) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   190
            Logger.getLogger(HttpCapture.class.getName()).log(Level.SEVERE, null, ex);
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   191
        }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   192
    }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   193
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   194
    public synchronized void sent(int c) throws IOException {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   195
        if (incoming) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   196
            out.write("\n------>\n");
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   197
            incoming = false;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   198
            out.flush();
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   199
        }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   200
        out.write(c);
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   201
    }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   202
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   203
    public synchronized void received(int c) throws IOException {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   204
        if (!incoming) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   205
            out.write("\n<------\n");
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   206
            incoming = true;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   207
            out.flush();
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   208
        }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   209
        out.write(c);
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   210
    }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   211
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   212
    public synchronized void flush() throws IOException {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   213
        out.flush();
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   214
    }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   215
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   216
    public static HttpCapture getCapture(java.net.URL url) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   217
        if (!isInitialized()) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   218
            init();
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   219
        }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   220
        if (patterns == null || patterns.isEmpty()) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   221
            return null;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   222
        }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   223
        String s = url.toString();
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   224
        for (int i = 0; i < patterns.size(); i++) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   225
            Pattern p = patterns.get(i);
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   226
            if (p.matcher(s).find()) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   227
                String f = capFiles.get(i);
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   228
                File fi;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   229
                if (f.indexOf("%d") >= 0) {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   230
                    java.util.Random rand = new java.util.Random();
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   231
                    do {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   232
                        String f2 = f.replace("%d", Integer.toString(rand.nextInt()));
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   233
                        fi = new File(f2);
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   234
                    } while (fi.exists());
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   235
                } else {
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   236
                    fi = new File(f);
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   237
                }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   238
                return new HttpCapture(fi, url);
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   239
            }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   240
        }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   241
        return null;
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   242
    }
2975ff687a6b 6811297: Add more logging to HTTP protocol handler
jccollet
parents:
diff changeset
   243
}