logstashのconf(抜粋)
filter {
json {
source => "message"
}
split {
field => "Records"
target => "r"
remove_field => "Records"
}
}
inputレコード
{\"Records\": [ { \"eventVersion\": \"1.08\", \"userIdentity\": { \"type\": \"AssumeRole\", \"principalId\": \"AROAXXXXX\", \"arn\": \"arn:aws:sts:xxx\" }, \"eventTime\": \"2021-10-11T23:54:08Z\" }, { \"eventVersion\": \"1.08\", \"userIdentity\": { \"type\": \"AssumeRole\", \"principalId\": \"AROAXXXXX\", \"arn\": \"arn:aws:sts:xxx\" }, \"eventTime\": \"2021-10-11T23:54:09Z\" }, { \"eventVersion\": \"1.08\", \"userIdentity\": { \"type\": \"AssumeRole\", \"principalId\": \"AROAXXXXX\", \"arn\": \"arn:aws:sts:xxx\" }, \"eventTime\": \"2021-10-11T23:54:08Z\" }]}"
登録結果(抜粋)
"_source": {
"r": {
"eventVersion": "1.08",
"eventTime": "2021-10-11T23:54:08Z",
"userIdentity": {
"principalId": "AROAXXXXX",
"arn": "arn:aws:sts:xxx",
"type": "AssumeRole"
}
}
この時、例えばフィールド名「r.eventVersion」「r.eventTime」となっているところを、「eventVersion」「eventTime」というように、ルートの「r」を削除した形でフィールド名をしていしたいです。ただし、inputファイルのフィールドのエントリーは場合により異なるため、mutateフィルターで「r.eventVersion」を「eventVersion」にリネームするといったことはせず、ルートの「r」をフィールド名から削除するという指定のやり方で行いたいです。
良い方法があればご教示頂けないでしょうか