Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Formatters #2

Merged
merged 1 commit into from
Mar 20, 2017
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
110 changes: 104 additions & 6 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,12 +1,16 @@
Logentries
=========

A short role to add configuration of logentries
[![Build Status](https://travis-ci.org/inovia-team/ansible-logentries.svg?branch=master)](https://travis-ci.org/inovia-team/ansible-logentries)

---

A role to add configuration of logentries and allow to format log

Requirements
------------

An account logentries
An account [logentries](https://logentries.com/)

Role Variables
--------------
Expand All @@ -31,6 +35,38 @@ Role Variables
logentries_files_on_server: "logfile2",
logentries_destination_on_logentries: "log_name_on_logentries"
}
logentries_formatters:
format:
- {
method_name: "format_syslog_log",
regexp: "regex",
output_line: "'%s %s %s %s %s'%(self.token, self.identity, self.hostname, self.log_name, line)"
}
formatters:
- {
logentries_project: "syslog",
method_name: "format_syslog_log",
}

`method_name` in section `logentries_formatters.formatters` *MUST* be the same as
`method_name` in `logentries_formatters.format` it's the link between the logs and how to
format it. Same for `logentries_project` which *MUST* be the same as
`logentries_project` in section `logentries_logs`

The format of output line should be formatted with mandatory parts,
`output_line` must have at least

"%s %s %s %s"%(self.token, self.identity, self.hostname, self.log_name)

The result of parsing line with regexp is stored in variable `pl`

(?P<firstpart>^[^{]*)(?P<secondpart>{.*})(?P<lastpart>.*)

All parts of this regexp will be stored as an array and will be accessible:

pl['firstpart']
pl['secondpart']
pl['lastpart']

Example Playbook
----------------
Expand All @@ -57,16 +93,37 @@ Add variables in inventory
logentries_files_on_server: "/var/log/webserver/error.log",
logentries_destination_on_logentries: "myhostname/webserver/error.log"
}
logentries_formatters:
format:
- {
method_name: "format_webserver_log",
regexp: "regexp",
output_line: "'%s %s %s %s %s'%(self.identity, self.hostname, self.log_name, self.token, line)"
}
- {
method_name: "format_syslog_log",
regexp: "(?P<firstpart>^[^{]*)(?P<secondpart>{.*})(?P<lastpart>.*)",
output_line: "'%s{\"identity\":\"%s\", \"hostname\":\"%s\", \"appname\":\"%s\", \"data\": %s, \"metadata\":\"%s\", \"lastpart\":\"%s\"}'%(self.token, self.identity, self.hostname, self.log_name, pl['secondpart'], pl['firstpart'], pl['lastpart'])"
}
formatters:
- {
logentries_project: "syslog",
method_name: "format_syslog_log",
}
- {
logentries_project: "project-webserver-error.log",
method_name: "format_webserver_log",
}

This configuration will generate 2 files in /etc/le/conf.d:
This configuration will generate 2 files in `/etc/le/conf.d`:

syslog.conf file will contains:
`syslog.conf` file will contains:

[stage-syslog]
path = /var/log/syslog
destination = project-dev/monolith-syslog

project.conf file will contains:
`project.conf` file will contains:

[stage-project-default-log]
path = /var/www/project/stage/log/filename.log
Expand All @@ -76,12 +133,53 @@ project.conf file will contains:
path = /var/log/webserver/error.log
destination = myhostname/webserver/error.log

If you add formatting part this will add 2 others files `__init__.py` and
`formatters.py` in folder `/etc/le/le_formatters`

In `formatters.py` you will have a list of methods:

import re

class Form(object):
"""Formats lines based of pattern given."""

def __init__(self, identity, hostname, log_name, token):
self.identity = identity
self.hostname = hostname
self.log_name = log_name
self.token = token

def format_syslog_log(self, line):
line = line.rstrip()
m = re.match(r"(?P<firstpart>^[^{]*)(?P<secondpart>{.*})(?P<lastpart>.*)", line)
if m:
pl = m.groupdict()
return '%s{"identity":"%s", "hostname":"%s", "appname":"%s", "data": %s, "metadata":"%s", "lastpart":"%s"}'%(self.token, self.identity, self.hostname, self.log_name, pl['secondpart'], pl['firstpart'], pl['lastpart'])
else:
return line

def format_webserver_log(self, line):
line = line.rstrip()
m = re.match(r"regexp", line)
if m:
pl = m.groupdict()
return '%s %s %s %s %s'%(self.identity, self.hostname, self.log_name, self.token, line)
else:
return line

formatters = {
'development-syslog': lambda hostname, log_name, token: Form('development-syslog', hostname, log_name, token).format_syslog_log,
'development-mobilities-default': lambda hostname, log_name, token: Form('development-mobilities-default', hostname, log_name, token).format_webserver_log,
}


Use role in playbook
--------------------

- name: logentries
hosts: all
roles:
- logentries
- ansible-logentries
tags:
- logentries

Expand Down
4 changes: 4 additions & 0 deletions defaults/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,3 +3,7 @@
logentries_logs: []
logentries_account_key: ""
logentries_stage: ""

# formatters
logentries_formatters: ""

34 changes: 34 additions & 0 deletions tasks/formatting.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
---
- name: create folder containing formatters
file:
path: /etc/le/le_formatters/
state: directory
mode: "u=rwx,g=rx,o=rx"
owner: root
become: yes
tags:
- logentries
- formatters

- name: initiate module
file:
path: /etc/le/le_formatters/__init__.py
state: touch
mode: "u=rwx,g=rx,o=rx"
owner: root
become: yes
tags:
- logentries
- formatters

- name: deploy formatting class
template:
src: le_formatters/formatters.py.j2
dest: /etc/le/le_formatters/formatters.py
validate: python %s
notify:
- Restart logentries
tags:
- logentries
- formatters

7 changes: 7 additions & 0 deletions tasks/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -54,3 +54,10 @@
tags:
- logentries

- name: deploy formatting
include: formatting.yml
when: logentries_formatters
tags:
- logentries
- formatters

29 changes: 29 additions & 0 deletions templates/le_formatters/formatters.py.j2
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
import re

class Form(object):
"""Formats lines based of pattern given."""

def __init__(self, identity, hostname, log_name, token):
self.identity = identity
self.hostname = hostname
self.log_name = log_name
self.token = token

{% for format in logentries_formatters.format %}
def {{ format.method_name }}(self, line):
line = line.rstrip()
m = re.match(r"{{ format.regexp }}", line)
if m:
pl = m.groupdict()
return {{ format.output_line }}
else:
return line

{% endfor %}

formatters = {
{% for format in logentries_formatters.formatters %}
'{{ logentries_stage }}-{{ format.logentries_project }}': lambda hostname, log_name, token: Form('{{ logentries_stage }}-{{ format.logentries_project }}', hostname, log_name, token).{{ format.method_name }},
{% endfor %}
}

2 changes: 1 addition & 1 deletion tests/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,4 +2,4 @@
- hosts: localhost
remote_user: root
roles:
- logentries
- ansible-logentries