1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package org.apache.logging.log4j.core.appender.db.jpa.converter;
18
19 import java.io.IOException;
20 import java.util.List;
21
22 import javax.persistence.AttributeConverter;
23 import javax.persistence.Converter;
24 import javax.persistence.PersistenceException;
25
26 import org.apache.logging.log4j.ThreadContext;
27 import org.apache.logging.log4j.spi.DefaultThreadContextStack;
28 import org.apache.logging.log4j.util.Strings;
29
30 import com.fasterxml.jackson.core.type.TypeReference;
31
32
33
34
35
36
37
38
39
40
41 @Converter(autoApply = false)
42 public class ContextStackJsonAttributeConverter implements AttributeConverter<ThreadContext.ContextStack, String> {
43 @Override
44 public String convertToDatabaseColumn(final ThreadContext.ContextStack contextStack) {
45 if (contextStack == null) {
46 return null;
47 }
48
49 try {
50 return ContextMapJsonAttributeConverter.OBJECT_MAPPER.writeValueAsString(contextStack.asList());
51 } catch (final IOException e) {
52 throw new PersistenceException("Failed to convert stack list to JSON string.", e);
53 }
54 }
55
56 @Override
57 public ThreadContext.ContextStack convertToEntityAttribute(final String s) {
58 if (Strings.isEmpty(s)) {
59 return null;
60 }
61
62 List<String> list;
63 try {
64 list = ContextMapJsonAttributeConverter.OBJECT_MAPPER.readValue(s, new TypeReference<List<String>>() { });
65 } catch (final IOException e) {
66 throw new PersistenceException("Failed to convert JSON string to list for stack.", e);
67 }
68
69 final DefaultThreadContextStack result = new DefaultThreadContextStack(true);
70 result.addAll(list);
71 return result;
72 }
73 }