llv 0.1.0

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.
data/lib/llv/web.rb ADDED
@@ -0,0 +1,104 @@
1
+ # frozen_string_literal: true
2
+
3
+ require "sinatra/base"
4
+ require "json"
5
+
6
+ module Llv
7
+ class Web < Sinatra::Base
8
+ PUBLIC = File.expand_path("public", __dir__)
9
+
10
+ set :public_folder, PUBLIC
11
+ set :static, true
12
+ set :logging, false
13
+ set :show_exceptions, false
14
+
15
+ class << self
16
+ attr_accessor :store
17
+ end
18
+
19
+ helpers do
20
+ def store
21
+ self.class.store
22
+ end
23
+
24
+ def json_response(obj)
25
+ content_type :json
26
+ JSON.generate(obj, allow_nan: false)
27
+ end
28
+
29
+ def serialise_group(group)
30
+ return nil unless group
31
+
32
+ group.merge(
33
+ lines: group[:lines].map do |line|
34
+ {
35
+ type: line.type,
36
+ payload: line.payload,
37
+ html: Ansi.to_html(line.raw),
38
+ plain: line.plain,
39
+ at: line.at
40
+ }
41
+ end
42
+ )
43
+ end
44
+ end
45
+
46
+ get "/" do
47
+ send_file File.join(PUBLIC, "index.html")
48
+ end
49
+
50
+ get "/groups" do
51
+ limit = (params[:limit] || 200).to_i.clamp(1, 1000)
52
+ kind = params[:kind]&.to_sym
53
+ kind = nil unless %i[http job untagged].include?(kind)
54
+ json_response(groups: store.list(limit: limit, kind: kind))
55
+ end
56
+
57
+ get "/groups/:id" do
58
+ group = store.fetch(params[:id])
59
+ halt 404, json_response(error: "not found") unless group
60
+ json_response(group: serialise_group(group))
61
+ end
62
+
63
+ get "/events" do
64
+ content_type "text/event-stream"
65
+ cache_control :no_cache
66
+ headers["X-Accel-Buffering"] = "no"
67
+
68
+ stream(:keep_open) do |out|
69
+ queue = Queue.new
70
+ handle = store.subscribe do |type, group|
71
+ queue << [type, group]
72
+ end
73
+
74
+ keepalive = Thread.new do
75
+ loop do
76
+ sleep 15
77
+ queue << [:keepalive, nil]
78
+ end
79
+ end
80
+
81
+ begin
82
+ loop do
83
+ type, group = queue.pop
84
+ if type == :keepalive
85
+ out << ": keepalive\n\n"
86
+ else
87
+ data = group.respond_to?(:summary) ? group.summary : { id: group.id }
88
+ out << "event: #{type}\n"
89
+ out << "data: #{JSON.generate(data)}\n\n"
90
+ end
91
+ end
92
+ ensure
93
+ keepalive.kill
94
+ store.unsubscribe(handle)
95
+ end
96
+ end
97
+ end
98
+
99
+ error JSON::GeneratorError do
100
+ status 500
101
+ json_response(error: "encoding error")
102
+ end
103
+ end
104
+ end
data/lib/llv.rb ADDED
@@ -0,0 +1,8 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "llv/version"
4
+ require_relative "llv/ansi"
5
+ require_relative "llv/parser"
6
+ require_relative "llv/group_store"
7
+ require_relative "llv/tailer"
8
+ require_relative "llv/cli"
metadata ADDED
@@ -0,0 +1,153 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: llv
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Jamie Lawrence
8
+ bindir: bin
9
+ cert_chain: []
10
+ date: 1980-01-02 00:00:00.000000000 Z
11
+ dependencies:
12
+ - !ruby/object:Gem::Dependency
13
+ name: sinatra
14
+ requirement: !ruby/object:Gem::Requirement
15
+ requirements:
16
+ - - "~>"
17
+ - !ruby/object:Gem::Version
18
+ version: '4.0'
19
+ type: :runtime
20
+ prerelease: false
21
+ version_requirements: !ruby/object:Gem::Requirement
22
+ requirements:
23
+ - - "~>"
24
+ - !ruby/object:Gem::Version
25
+ version: '4.0'
26
+ - !ruby/object:Gem::Dependency
27
+ name: puma
28
+ requirement: !ruby/object:Gem::Requirement
29
+ requirements:
30
+ - - "~>"
31
+ - !ruby/object:Gem::Version
32
+ version: '6.0'
33
+ type: :runtime
34
+ prerelease: false
35
+ version_requirements: !ruby/object:Gem::Requirement
36
+ requirements:
37
+ - - "~>"
38
+ - !ruby/object:Gem::Version
39
+ version: '6.0'
40
+ - !ruby/object:Gem::Dependency
41
+ name: rackup
42
+ requirement: !ruby/object:Gem::Requirement
43
+ requirements:
44
+ - - "~>"
45
+ - !ruby/object:Gem::Version
46
+ version: '2.1'
47
+ type: :runtime
48
+ prerelease: false
49
+ version_requirements: !ruby/object:Gem::Requirement
50
+ requirements:
51
+ - - "~>"
52
+ - !ruby/object:Gem::Version
53
+ version: '2.1'
54
+ - !ruby/object:Gem::Dependency
55
+ name: listen
56
+ requirement: !ruby/object:Gem::Requirement
57
+ requirements:
58
+ - - "~>"
59
+ - !ruby/object:Gem::Version
60
+ version: '3.9'
61
+ type: :runtime
62
+ prerelease: false
63
+ version_requirements: !ruby/object:Gem::Requirement
64
+ requirements:
65
+ - - "~>"
66
+ - !ruby/object:Gem::Version
67
+ version: '3.9'
68
+ - !ruby/object:Gem::Dependency
69
+ name: launchy
70
+ requirement: !ruby/object:Gem::Requirement
71
+ requirements:
72
+ - - "~>"
73
+ - !ruby/object:Gem::Version
74
+ version: '3.0'
75
+ type: :runtime
76
+ prerelease: false
77
+ version_requirements: !ruby/object:Gem::Requirement
78
+ requirements:
79
+ - - "~>"
80
+ - !ruby/object:Gem::Version
81
+ version: '3.0'
82
+ - !ruby/object:Gem::Dependency
83
+ name: bubbletea
84
+ requirement: !ruby/object:Gem::Requirement
85
+ requirements:
86
+ - - "~>"
87
+ - !ruby/object:Gem::Version
88
+ version: '0.1'
89
+ type: :runtime
90
+ prerelease: false
91
+ version_requirements: !ruby/object:Gem::Requirement
92
+ requirements:
93
+ - - "~>"
94
+ - !ruby/object:Gem::Version
95
+ version: '0.1'
96
+ - !ruby/object:Gem::Dependency
97
+ name: lipgloss
98
+ requirement: !ruby/object:Gem::Requirement
99
+ requirements:
100
+ - - "~>"
101
+ - !ruby/object:Gem::Version
102
+ version: '0.2'
103
+ type: :runtime
104
+ prerelease: false
105
+ version_requirements: !ruby/object:Gem::Requirement
106
+ requirements:
107
+ - - "~>"
108
+ - !ruby/object:Gem::Version
109
+ version: '0.2'
110
+ description: Tails a Rails development.log, groups lines by request_id or ActiveJob
111
+ id, and renders a master/detail view in a browser or terminal.
112
+ email:
113
+ - jamie@ideasasylum.com
114
+ executables:
115
+ - llv
116
+ extensions: []
117
+ extra_rdoc_files: []
118
+ files:
119
+ - README.md
120
+ - bin/llv
121
+ - lib/llv.rb
122
+ - lib/llv/ansi.rb
123
+ - lib/llv/cli.rb
124
+ - lib/llv/group_store.rb
125
+ - lib/llv/parser.rb
126
+ - lib/llv/public/app.js
127
+ - lib/llv/public/index.html
128
+ - lib/llv/public/styles.css
129
+ - lib/llv/tailer.rb
130
+ - lib/llv/tui.rb
131
+ - lib/llv/version.rb
132
+ - lib/llv/web.rb
133
+ licenses:
134
+ - MIT
135
+ metadata: {}
136
+ rdoc_options: []
137
+ require_paths:
138
+ - lib
139
+ required_ruby_version: !ruby/object:Gem::Requirement
140
+ requirements:
141
+ - - ">="
142
+ - !ruby/object:Gem::Version
143
+ version: '3.2'
144
+ required_rubygems_version: !ruby/object:Gem::Requirement
145
+ requirements:
146
+ - - ">="
147
+ - !ruby/object:Gem::Version
148
+ version: '0'
149
+ requirements: []
150
+ rubygems_version: 3.6.9
151
+ specification_version: 4
152
+ summary: Local Rails log viewer that groups lines by request or job.
153
+ test_files: []