fozzie 0.0.20 → 0.0.21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,97 +0,0 @@
1
- <!DOCTYPE html>
2
- <html>
3
- <head>
4
- <meta http-equiv="content-type" content="text/html;charset=utf-8">
5
- <title>middleware.rb</title>
6
- <link rel="stylesheet" href="http://jashkenas.github.com/docco/resources/docco.css">
7
- </head>
8
- <body>
9
- <div id='container'>
10
- <div id="background"></div>
11
- <div id="jump_to">
12
- Jump To &hellip;
13
- <div id="jump_wrapper">
14
- <div id="jump_page">
15
- <a class="source" href="../../core_ext/hash.html">hash.rb</a>
16
- <a class="source" href="../../fozzie.html">fozzie.rb</a>
17
- <a class="source" href="../configuration.html">configuration.rb</a>
18
- <a class="source" href="../interface.html">interface.rb</a>
19
- <a class="source" href="middleware.html">middleware.rb</a>
20
- <a class="source" href="../rails/middleware.html">middleware.rb</a>
21
- <a class="source" href="../socket.html">socket.rb</a>
22
- <a class="source" href="../version.html">version.rb</a>
23
- </div>
24
- </div>
25
- </div>
26
- <table cellspacing=0 cellpadding=0>
27
- <thead>
28
- <tr>
29
- <th class=docs><h1>middleware.rb</h1></th>
30
- <th class=code></th>
31
- </tr>
32
- </thead>
33
- <tbody>
34
- <tr id='section-1'>
35
- <td class=docs>
36
- <div class="pilwrap">
37
- <a class="pilcrow" href="#section-1">&#182;</a>
38
- </div>
39
-
40
- </td>
41
- <td class=code>
42
- <div class='highlight'><pre><span class="k">module</span> <span class="nn">Fozzie</span>
43
- <span class="k">module</span> <span class="nn">Rack</span></pre></div>
44
- </td>
45
- </tr>
46
- <tr id='section-2'>
47
- <td class=docs>
48
- <div class="pilwrap">
49
- <a class="pilcrow" href="#section-2">&#182;</a>
50
- </div>
51
- <p>Time and record each request through a given Rack app
52
- This middlewware times server processing for a resource, not view render.</p>
53
-
54
- </td>
55
- <td class=code>
56
- <div class='highlight'><pre> <span class="k">class</span> <span class="nc">Middleware</span>
57
-
58
- <span class="kp">attr_reader</span> <span class="ss">:app</span>
59
-
60
- <span class="k">def</span> <span class="nf">initialize</span><span class="p">(</span><span class="n">app</span><span class="p">)</span>
61
- <span class="vi">@app</span> <span class="o">=</span> <span class="n">app</span>
62
- <span class="k">end</span>
63
-
64
- <span class="k">def</span> <span class="nf">call</span><span class="p">(</span><span class="n">env</span><span class="p">)</span>
65
- <span class="n">k</span> <span class="o">=</span> <span class="n">generate_key</span><span class="p">(</span><span class="n">env</span><span class="p">)</span>
66
- <span class="k">if</span> <span class="n">k</span><span class="o">.</span><span class="n">nil?</span>
67
- <span class="nb">self</span><span class="o">.</span><span class="n">call_without_timer</span><span class="p">(</span><span class="n">env</span><span class="p">)</span>
68
- <span class="k">else</span>
69
- <span class="nb">self</span><span class="o">.</span><span class="n">call_with_timer</span><span class="p">(</span><span class="n">k</span><span class="p">,</span> <span class="n">env</span><span class="p">)</span>
70
- <span class="k">end</span>
71
- <span class="k">end</span>
72
-
73
- <span class="k">def</span> <span class="nf">call_without_timer</span><span class="p">(</span><span class="n">env</span><span class="p">)</span>
74
- <span class="vi">@app</span><span class="o">.</span><span class="n">call</span><span class="p">(</span><span class="n">env</span><span class="p">)</span>
75
- <span class="k">end</span>
76
-
77
- <span class="k">def</span> <span class="nf">call_with_timer</span><span class="p">(</span><span class="n">key</span><span class="p">,</span> <span class="n">env</span><span class="p">)</span>
78
- <span class="n">S</span><span class="o">.</span><span class="n">time_to_do</span> <span class="n">key</span> <span class="k">do</span>
79
- <span class="vi">@app</span><span class="o">.</span><span class="n">call</span><span class="p">(</span><span class="n">env</span><span class="p">)</span>
80
- <span class="k">end</span>
81
- <span class="k">end</span>
82
-
83
- <span class="k">def</span> <span class="nf">generate_key</span><span class="p">(</span><span class="n">env</span><span class="p">)</span>
84
- <span class="n">s</span> <span class="o">=</span> <span class="n">env</span><span class="o">[</span><span class="s1">&#39;PATH_INFO&#39;</span><span class="o">]</span>
85
- <span class="k">return</span> <span class="kp">nil</span> <span class="k">if</span> <span class="n">s</span><span class="o">.</span><span class="n">nil?</span>
86
- <span class="n">s</span> <span class="o">=</span> <span class="p">(</span><span class="n">s</span> <span class="o">==</span> <span class="s1">&#39;/&#39;</span> <span class="p">?</span> <span class="s1">&#39;index&#39;</span> <span class="p">:</span> <span class="n">s</span><span class="o">.</span><span class="n">gsub</span><span class="p">(</span><span class="sr">/.(\/)./</span><span class="p">)</span> <span class="p">{</span><span class="o">|</span><span class="n">m</span><span class="o">|</span> <span class="n">m</span><span class="o">.</span><span class="n">gsub</span><span class="p">(</span><span class="s1">&#39;/&#39;</span><span class="p">,</span> <span class="s1">&#39;.&#39;</span><span class="p">)</span> <span class="p">}</span><span class="o">.</span><span class="n">gsub</span><span class="p">(</span><span class="sr">/\//</span><span class="p">,</span> <span class="s1">&#39;&#39;</span><span class="p">)</span><span class="o">.</span><span class="n">strip</span><span class="p">)</span>
87
- <span class="p">(</span><span class="n">s</span><span class="o">.</span><span class="n">nil?</span> <span class="o">||</span> <span class="n">s</span><span class="o">.</span><span class="n">empty?</span> <span class="p">?</span> <span class="kp">nil</span> <span class="p">:</span> <span class="s2">&quot;</span><span class="si">#{</span><span class="n">s</span><span class="si">}</span><span class="s2">.render&quot;</span><span class="p">)</span>
88
- <span class="k">end</span>
89
-
90
- <span class="k">end</span>
91
- <span class="k">end</span>
92
- <span class="k">end</span></pre></div>
93
- </td>
94
- </tr>
95
- </table>
96
- </div>
97
- </body>
@@ -1,97 +0,0 @@
1
- <!DOCTYPE html>
2
- <html>
3
- <head>
4
- <meta http-equiv="content-type" content="text/html;charset=utf-8">
5
- <title>middleware.rb</title>
6
- <link rel="stylesheet" href="http://jashkenas.github.com/docco/resources/docco.css">
7
- </head>
8
- <body>
9
- <div id='container'>
10
- <div id="background"></div>
11
- <div id="jump_to">
12
- Jump To &hellip;
13
- <div id="jump_wrapper">
14
- <div id="jump_page">
15
- <a class="source" href="../../core_ext/hash.html">hash.rb</a>
16
- <a class="source" href="../../fozzie.html">fozzie.rb</a>
17
- <a class="source" href="../configuration.html">configuration.rb</a>
18
- <a class="source" href="../interface.html">interface.rb</a>
19
- <a class="source" href="../rack/middleware.html">middleware.rb</a>
20
- <a class="source" href="middleware.html">middleware.rb</a>
21
- <a class="source" href="../socket.html">socket.rb</a>
22
- <a class="source" href="../version.html">version.rb</a>
23
- </div>
24
- </div>
25
- </div>
26
- <table cellspacing=0 cellpadding=0>
27
- <thead>
28
- <tr>
29
- <th class=docs><h1>middleware.rb</h1></th>
30
- <th class=code></th>
31
- </tr>
32
- </thead>
33
- <tbody>
34
- <tr id='section-1'>
35
- <td class=docs>
36
- <div class="pilwrap">
37
- <a class="pilcrow" href="#section-1">&#182;</a>
38
- </div>
39
-
40
- </td>
41
- <td class=code>
42
- <div class='highlight'><pre><span class="nb">require</span> <span class="s1">&#39;fozzie/rack/middleware&#39;</span>
43
-
44
- <span class="k">module</span> <span class="nn">Fozzie</span>
45
- <span class="k">module</span> <span class="nn">Rails</span></pre></div>
46
- </td>
47
- </tr>
48
- <tr id='section-2'>
49
- <td class=docs>
50
- <div class="pilwrap">
51
- <a class="pilcrow" href="#section-2">&#182;</a>
52
- </div>
53
- <p>Time and record each request through a given Rails app
54
- This middlewware times server processing for a resource, not view render.</p>
55
- </td>
56
- <td class=code>
57
- <div class='highlight'><pre> <span class="k">class</span> <span class="nc">Middleware</span> <span class="o">&lt;</span> <span class="no">Fozzie</span><span class="o">::</span><span class="no">Rack</span><span class="o">::</span><span class="no">Middleware</span></pre></div>
58
- </td>
59
- </tr>
60
- <tr id='section-3'>
61
- <td class=docs>
62
- <div class="pilwrap">
63
- <a class="pilcrow" href="#section-3">&#182;</a>
64
- </div>
65
- <p>Generates the statistics key for the current path</p>
66
-
67
- </td>
68
- <td class=code>
69
- <div class='highlight'><pre> <span class="k">def</span> <span class="nf">generate_key</span><span class="p">(</span><span class="n">env</span><span class="p">)</span>
70
- <span class="n">path_str</span> <span class="o">=</span> <span class="n">env</span><span class="o">[</span><span class="s1">&#39;PATH_INFO&#39;</span><span class="o">]</span>
71
- <span class="k">return</span> <span class="kp">nil</span> <span class="k">unless</span> <span class="n">path_str</span>
72
-
73
- <span class="k">begin</span>
74
- <span class="n">routing</span> <span class="o">=</span> <span class="p">(</span><span class="n">rails_version</span> <span class="o">==</span> <span class="mi">3</span> <span class="o">?</span> <span class="o">::</span><span class="no">Rails</span><span class="o">.</span><span class="n">application</span><span class="o">.</span><span class="n">routes</span> <span class="p">:</span> <span class="o">::</span><span class="no">ActionController</span><span class="o">::</span><span class="no">Routing</span><span class="o">::</span><span class="no">Routes</span><span class="p">)</span>
75
- <span class="n">path</span> <span class="o">=</span> <span class="n">routing</span><span class="o">.</span><span class="n">recognize_path</span><span class="p">(</span><span class="n">path_str</span><span class="p">)</span>
76
- <span class="n">stat</span> <span class="o">=</span> <span class="o">[</span><span class="n">path</span><span class="o">[</span><span class="ss">:controller</span><span class="o">]</span><span class="p">,</span> <span class="n">path</span><span class="o">[</span><span class="ss">:action</span><span class="o">]</span><span class="p">,</span> <span class="s2">&quot;render&quot;</span><span class="o">].</span><span class="n">join</span><span class="p">(</span><span class="s1">&#39;.&#39;</span><span class="p">)</span>
77
- <span class="n">stat</span>
78
- <span class="k">rescue</span> <span class="no">ActionController</span><span class="o">::</span><span class="no">RoutingError</span> <span class="o">=&gt;</span> <span class="n">exc</span>
79
- <span class="n">S</span><span class="o">.</span><span class="n">increment</span> <span class="s2">&quot;routing.error&quot;</span>
80
- <span class="kp">nil</span>
81
- <span class="k">rescue</span> <span class="o">=&gt;</span> <span class="n">exc</span>
82
- <span class="kp">nil</span>
83
- <span class="k">end</span>
84
- <span class="k">end</span>
85
-
86
- <span class="k">def</span> <span class="nf">rails_version</span>
87
- <span class="o">::</span><span class="no">Rails</span><span class="o">.</span><span class="n">version</span><span class="o">.</span><span class="n">to_i</span>
88
- <span class="k">end</span>
89
-
90
- <span class="k">end</span>
91
- <span class="k">end</span>
92
- <span class="k">end</span></pre></div>
93
- </td>
94
- </tr>
95
- </table>
96
- </div>
97
- </body>
@@ -1,129 +0,0 @@
1
- <!DOCTYPE html>
2
- <html>
3
- <head>
4
- <meta http-equiv="content-type" content="text/html;charset=utf-8">
5
- <title>socket.rb</title>
6
- <link rel="stylesheet" href="http://jashkenas.github.com/docco/resources/docco.css">
7
- </head>
8
- <body>
9
- <div id='container'>
10
- <div id="background"></div>
11
- <div id="jump_to">
12
- Jump To &hellip;
13
- <div id="jump_wrapper">
14
- <div id="jump_page">
15
- <a class="source" href="../core_ext/hash.html">hash.rb</a>
16
- <a class="source" href="../fozzie.html">fozzie.rb</a>
17
- <a class="source" href="configuration.html">configuration.rb</a>
18
- <a class="source" href="interface.html">interface.rb</a>
19
- <a class="source" href="rack/middleware.html">middleware.rb</a>
20
- <a class="source" href="rails/middleware.html">middleware.rb</a>
21
- <a class="source" href="socket.html">socket.rb</a>
22
- <a class="source" href="version.html">version.rb</a>
23
- </div>
24
- </div>
25
- </div>
26
- <table cellspacing=0 cellpadding=0>
27
- <thead>
28
- <tr>
29
- <th class=docs><h1>socket.rb</h1></th>
30
- <th class=code></th>
31
- </tr>
32
- </thead>
33
- <tbody>
34
- <tr id='section-1'>
35
- <td class=docs>
36
- <div class="pilwrap">
37
- <a class="pilcrow" href="#section-1">&#182;</a>
38
- </div>
39
-
40
- </td>
41
- <td class=code>
42
- <div class='highlight'><pre><span class="nb">require</span> <span class="s1">&#39;socket&#39;</span>
43
-
44
- <span class="k">module</span> <span class="nn">Fozzie</span>
45
- <span class="k">module</span> <span class="nn">Socket</span>
46
-
47
- <span class="no">RESERVED_CHARS_REGEX</span> <span class="o">=</span> <span class="sr">/[\:\|\@]/</span>
48
-
49
- <span class="kp">private</span></pre></div>
50
- </td>
51
- </tr>
52
- <tr id='section-2'>
53
- <td class=docs>
54
- <div class="pilwrap">
55
- <a class="pilcrow" href="#section-2">&#182;</a>
56
- </div>
57
- <p>Send the statistic to the server</p>
58
-
59
- <p>Creates the Statsd key from the given values, and sends to socket (depending on sample rate)</p>
60
- </td>
61
- <td class=code>
62
- <div class='highlight'><pre> <span class="k">def</span> <span class="nf">send</span><span class="p">(</span><span class="n">stat</span><span class="p">,</span> <span class="n">delta</span><span class="p">,</span> <span class="n">type</span><span class="p">,</span> <span class="n">sample_rate</span><span class="p">)</span>
63
- <span class="n">stat</span> <span class="o">=</span> <span class="o">[</span><span class="n">stat</span><span class="o">].</span><span class="n">flatten</span><span class="o">.</span><span class="n">compact</span><span class="o">.</span><span class="n">collect</span><span class="p">(</span><span class="o">&amp;</span><span class="ss">:to_s</span><span class="p">)</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="s1">&#39;.&#39;</span><span class="p">)</span><span class="o">.</span><span class="n">downcase</span>
64
- <span class="n">stat</span> <span class="o">=</span> <span class="n">stat</span><span class="o">.</span><span class="n">gsub</span><span class="p">(</span><span class="s1">&#39;::&#39;</span><span class="p">,</span> <span class="s1">&#39;.&#39;</span><span class="p">)</span><span class="o">.</span><span class="n">gsub</span><span class="p">(</span><span class="no">RESERVED_CHARS_REGEX</span><span class="p">,</span> <span class="s1">&#39;_&#39;</span><span class="p">)</span>
65
-
66
- <span class="n">k</span> <span class="o">=</span> <span class="o">[</span><span class="no">Fozzie</span><span class="o">.</span><span class="n">c</span><span class="o">.</span><span class="n">data_prefix</span><span class="p">,</span> <span class="n">stat</span><span class="o">].</span><span class="n">compact</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="s1">&#39;.&#39;</span><span class="p">)</span>
67
- <span class="n">k</span> <span class="o">&lt;&lt;</span> <span class="s2">&quot;:&quot;</span>
68
- <span class="n">k</span> <span class="o">&lt;&lt;</span> <span class="o">[</span><span class="n">delta</span><span class="p">,</span> <span class="n">type</span><span class="o">].</span><span class="n">join</span><span class="p">(</span><span class="s1">&#39;|&#39;</span><span class="p">)</span>
69
- <span class="n">k</span> <span class="o">&lt;&lt;</span> <span class="s1">&#39;@%s&#39;</span> <span class="o">%</span> <span class="n">sample_rate</span><span class="o">.</span><span class="n">to_s</span> <span class="k">if</span> <span class="n">sample_rate</span> <span class="o">&lt;</span> <span class="mi">1</span>
70
-
71
- <span class="n">sampled</span><span class="p">(</span><span class="n">sample_rate</span><span class="p">)</span> <span class="p">{</span> <span class="n">send_to_socket</span><span class="p">(</span><span class="n">k</span><span class="o">.</span><span class="n">strip</span><span class="p">)</span> <span class="p">}</span>
72
- <span class="k">end</span></pre></div>
73
- </td>
74
- </tr>
75
- <tr id='section-3'>
76
- <td class=docs>
77
- <div class="pilwrap">
78
- <a class="pilcrow" href="#section-3">&#182;</a>
79
- </div>
80
- <p>If the statistic is sampled, generate a condition to check if it&rsquo;s good to send</p>
81
- </td>
82
- <td class=code>
83
- <div class='highlight'><pre> <span class="k">def</span> <span class="nf">sampled</span><span class="p">(</span><span class="n">sample_rate</span><span class="p">)</span>
84
- <span class="k">yield</span> <span class="k">unless</span> <span class="n">sample_rate</span> <span class="o">&lt;</span> <span class="mi">1</span> <span class="ow">and</span> <span class="nb">rand</span> <span class="o">&gt;</span> <span class="n">sample_rate</span>
85
- <span class="k">end</span></pre></div>
86
- </td>
87
- </tr>
88
- <tr id='section-4'>
89
- <td class=docs>
90
- <div class="pilwrap">
91
- <a class="pilcrow" href="#section-4">&#182;</a>
92
- </div>
93
- <p>Send data to the server via the socket</p>
94
- </td>
95
- <td class=code>
96
- <div class='highlight'><pre> <span class="k">def</span> <span class="nf">send_to_socket</span><span class="p">(</span><span class="n">message</span><span class="p">)</span>
97
- <span class="k">begin</span>
98
- <span class="no">Fozzie</span><span class="o">.</span><span class="n">logger</span><span class="o">.</span><span class="n">debug</span> <span class="p">{</span><span class="s2">&quot;Statsd: </span><span class="si">#{</span><span class="n">message</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">}</span> <span class="k">if</span> <span class="no">Fozzie</span><span class="o">.</span><span class="n">logger</span>
99
- <span class="no">Timeout</span><span class="o">.</span><span class="n">timeout</span><span class="p">(</span><span class="no">Fozzie</span><span class="o">.</span><span class="n">c</span><span class="o">.</span><span class="n">timeout</span><span class="p">)</span> <span class="p">{</span>
100
- <span class="n">socket</span><span class="o">.</span><span class="n">send</span><span class="p">(</span><span class="n">message</span><span class="p">,</span> <span class="mi">0</span><span class="p">,</span> <span class="no">Fozzie</span><span class="o">.</span><span class="n">c</span><span class="o">.</span><span class="n">host</span><span class="p">,</span> <span class="no">Fozzie</span><span class="o">.</span><span class="n">c</span><span class="o">.</span><span class="n">port</span><span class="p">)</span>
101
- <span class="kp">true</span>
102
- <span class="p">}</span>
103
- <span class="k">rescue</span> <span class="o">=&gt;</span> <span class="n">exc</span>
104
- <span class="no">Fozzie</span><span class="o">.</span><span class="n">logger</span><span class="o">.</span><span class="n">debug</span> <span class="p">{</span><span class="s2">&quot;Statsd Failure: </span><span class="si">#{</span><span class="n">exc</span><span class="o">.</span><span class="n">message</span><span class="si">}</span><span class="se">\n</span><span class="si">#{</span><span class="n">exc</span><span class="o">.</span><span class="n">backtrace</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">}</span> <span class="k">if</span> <span class="no">Fozzie</span><span class="o">.</span><span class="n">logger</span>
105
- <span class="kp">false</span>
106
- <span class="k">end</span>
107
- <span class="k">end</span></pre></div>
108
- </td>
109
- </tr>
110
- <tr id='section-5'>
111
- <td class=docs>
112
- <div class="pilwrap">
113
- <a class="pilcrow" href="#section-5">&#182;</a>
114
- </div>
115
- <p>The Socket we want to use to send data</p>
116
-
117
- </td>
118
- <td class=code>
119
- <div class='highlight'><pre> <span class="k">def</span> <span class="nf">socket</span>
120
- <span class="vi">@socket</span> <span class="o">||=</span> <span class="o">::</span><span class="no">UDPSocket</span><span class="o">.</span><span class="n">new</span>
121
- <span class="k">end</span>
122
-
123
- <span class="k">end</span>
124
- <span class="k">end</span></pre></div>
125
- </td>
126
- </tr>
127
- </table>
128
- </div>
129
- </body>
@@ -1,36 +0,0 @@
1
- <!DOCTYPE html>
2
- <html>
3
- <head>
4
- <meta http-equiv="content-type" content="text/html;charset=utf-8">
5
- <title>version.rb</title>
6
- <link rel="stylesheet" href="http://jashkenas.github.com/docco/resources/docco.css">
7
- </head>
8
- <body>
9
- <div id='container'>
10
- <div id="background"></div>
11
- <div id="jump_to">
12
- Jump To &hellip;
13
- <div id="jump_wrapper">
14
- <div id="jump_page">
15
- <a class="source" href="../core_ext/hash.html">hash.rb</a>
16
- <a class="source" href="../fozzie.html">fozzie.rb</a>
17
- <a class="source" href="configuration.html">configuration.rb</a>
18
- <a class="source" href="interface.html">interface.rb</a>
19
- <a class="source" href="rack/middleware.html">middleware.rb</a>
20
- <a class="source" href="rails/middleware.html">middleware.rb</a>
21
- <a class="source" href="socket.html">socket.rb</a>
22
- <a class="source" href="version.html">version.rb</a>
23
- </div>
24
- </div>
25
- </div>
26
- <table cellspacing=0 cellpadding=0>
27
- <thead>
28
- <tr>
29
- <th class=docs><h1>version.rb</h1></th>
30
- <th class=code></th>
31
- </tr>
32
- </thead>
33
- <tbody>
34
- </table>
35
- </div>
36
- </body>