nl.basjes.parse.httpdlog.dissectors.ResponseSetCookieDissector Maven / Gradle / Ivy
/*
* Apache HTTPD logparsing made easy
* Copyright (C) 2011-2016 Niels Basjes
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package nl.basjes.parse.httpdlog.dissectors;
import nl.basjes.parse.core.Casts;
import nl.basjes.parse.core.Dissector;
import nl.basjes.parse.core.Parsable;
import nl.basjes.parse.core.ParsedField;
import nl.basjes.parse.core.exceptions.DissectionFailure;
import java.net.HttpCookie;
import java.util.ArrayList;
import java.util.EnumSet;
import java.util.List;
public class ResponseSetCookieDissector extends Dissector {
// --------------------------------------------
private static final String INPUT_TYPE = "HTTP.SETCOOKIE";
@Override
public String getInputType() {
return INPUT_TYPE;
}
// --------------------------------------------
/** This should output all possible types */
@Override
public List getPossibleOutput() {
List result = new ArrayList<>();
result.add("STRING:value");
result.add("STRING:expires");
result.add("STRING:path");
result.add("STRING:domain");
return result;
}
// --------------------------------------------
@Override
public boolean initializeFromSettingsParameter(String settings) {
return true; // Everything went right.
}
// --------------------------------------------
@Override
protected void initializeNewInstance(Dissector newInstance) {
// Nothing to do
}
@Override
public EnumSet prepareForDissect(final String inputname, final String outputname) {
// We do not do anything extra here
return Casts.STRING_ONLY;
}
// --------------------------------------------
@Override
public void prepareForRun() {
// We do not do anything extra here
}
// --------------------------------------------
@Override
public void dissect(final Parsable> parsable, final String inputname) throws DissectionFailure {
final ParsedField field = parsable.getParsableField(INPUT_TYPE, inputname);
final String fieldValue = field.getValue().getString();
if (fieldValue == null || fieldValue.isEmpty()){
return; // Nothing to do here
}
Long nowSeconds = System.currentTimeMillis()/1000;
List cookies = HttpCookie.parse(fieldValue);
for (HttpCookie cookie : cookies) {
parsable.addDissection(inputname, getDissectionType(inputname, "value"), "value", cookie.getValue());
parsable.addDissection(inputname, getDissectionType(inputname, "expires"), "expires",
Long.toString(nowSeconds + cookie.getMaxAge()));
parsable.addDissection(inputname, getDissectionType(inputname, "path"), "path", cookie.getPath());
parsable.addDissection(inputname, getDissectionType(inputname, "domain"), "domain", cookie.getDomain());
parsable.addDissection(inputname, getDissectionType(inputname, "comment"), "comment", cookie.getComment());
}
}
// --------------------------------------------
/**
* This determines the type of the value that was just found.
* This method is intended to be overruled by a subclass
*/
@SuppressWarnings("UnusedParameters")
public String getDissectionType(final String basename, final String name) {
return "STRING"; // Possible outputs are of the same type.
}
// --------------------------------------------
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy