Skip to content

Commit

Permalink
Add request logging instrumentation
Browse files Browse the repository at this point in the history
  • Loading branch information
testower committed Jun 10, 2024
1 parent 22b568b commit 706f122
Show file tree
Hide file tree
Showing 2 changed files with 131 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
/*
*
*
* * Licensed under the EUPL, Version 1.2 or – as soon they will be approved by
* * the European Commission - subsequent versions of the EUPL (the "Licence");
* * You may not use this work except in compliance with the Licence.
* * You may obtain a copy of the Licence at:
* *
* * https://joinup.ec.europa.eu/software/page/eupl
* *
* * Unless required by applicable law or agreed to in writing, software
* * distributed under the Licence is distributed on an "AS IS" basis,
* * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* * See the Licence for the specific language governing permissions and
* * limitations under the Licence.
*
*/

package org.entur.lamassu.config.graphql;

import graphql.execution.instrumentation.Instrumentation;
import java.util.ArrayList;
import java.util.List;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class InstrumentationConfiguration {

/**
* Return all instrumentations as a bean.
*/
@Bean
List<Instrumentation> instrumentations() {
// Note: Due to a bug in GraphQLWebAutoConfiguration, the returned list has to be modifiable (it will be sorted)
return new ArrayList<>(List.of(new RequestLoggingInstrumentation()));
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,93 @@
/*
*
*
* * Licensed under the EUPL, Version 1.2 or – as soon they will be approved by
* * the European Commission - subsequent versions of the EUPL (the "Licence");
* * You may not use this work except in compliance with the Licence.
* * You may obtain a copy of the Licence at:
* *
* * https://joinup.ec.europa.eu/software/page/eupl
* *
* * Unless required by applicable law or agreed to in writing, software
* * distributed under the Licence is distributed on an "AS IS" basis,
* * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* * See the Licence for the specific language governing permissions and
* * limitations under the Licence.
*
*/

package org.entur.lamassu.config.graphql;

import graphql.ExecutionResult;
import graphql.execution.instrumentation.InstrumentationContext;
import graphql.execution.instrumentation.SimpleInstrumentationContext;
import graphql.execution.instrumentation.SimplePerformantInstrumentation;
import graphql.execution.instrumentation.parameters.InstrumentationExecutionParameters;
import jakarta.servlet.http.HttpServletRequest;
import org.jetbrains.annotations.NotNull;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

@Component
public class RequestLoggingInstrumentation extends SimplePerformantInstrumentation {

public static final Logger logger = LoggerFactory.getLogger(
RequestLoggingInstrumentation.class
);

@Autowired
private HttpServletRequest httpServletRequest;

@Value("org.entur.lamassu.graphql.instrumentation.extract-header-name")
private String extractHeaderName;

@Override
public @NotNull InstrumentationContext<ExecutionResult> beginExecution(
InstrumentationExecutionParameters parameters
) {
long startMillis = System.currentTimeMillis();
var executionId = parameters.getExecutionInput().getExecutionId();

final String extractHeaderValue = httpServletRequest.getHeader(extractHeaderName);

logger.debug(
"[{}] {}: {}, Query: {}",
executionId,
extractHeaderName,
extractHeaderValue,
parameters.getQuery()
);
if (parameters.getVariables() != null && !parameters.getVariables().isEmpty()) {
logger.info(
"[{}] {}: {}, variables: {}",
executionId,
extractHeaderName,
extractHeaderValue,
parameters.getVariables()
);
}

return SimpleInstrumentationContext.whenCompleted(
(
(executionResult, throwable) -> {
long endMillis = System.currentTimeMillis();
long duration = endMillis - startMillis;
if (throwable == null) {
logger.debug(
"[{}] {}: {}, completed in {}ms",
executionId,
extractHeaderName,
extractHeaderValue,
duration
);
} else {
logger.warn("Failed in: {} ", duration, throwable);
}
}
)
);
}
}

0 comments on commit 706f122

Please sign in to comment.