mirror of
https://github.com/cmur2/openvpn-status-web.git
synced 2025-09-28 21:52:05 +02:00
Compare commits
41 Commits
Author | SHA1 | Date | |
---|---|---|---|
65a65081ae | |||
194137adc8 | |||
ee06f65e81 | |||
![]() |
075922e484 | ||
![]() |
9ece1e125b | ||
![]() |
ba50185f44 | ||
![]() |
d57e8b7d2e | ||
![]() |
2d77c0efee | ||
![]() |
4f6725825a | ||
![]() |
8af23da209 | ||
![]() |
78d4c3c8cb | ||
![]() |
39f570ec48 | ||
![]() |
1eb6202a8f | ||
![]() |
a329966bc5 | ||
![]() |
575516bd27 | ||
![]() |
af253c61f0 | ||
![]() |
a804f842df | ||
![]() |
648b4d94b6 | ||
![]() |
117f70e2e3 | ||
![]() |
1e0444a71d | ||
![]() |
20c6c9176a | ||
![]() |
a0ad379b00 | ||
![]() |
d8f4931657 | ||
![]() |
6676f47c97 | ||
![]() |
811b928403 | ||
![]() |
f4a48b8ce0 | ||
![]() |
f985ec1c12 | ||
![]() |
3d10b7d128 | ||
![]() |
27876c7f12 | ||
![]() |
9d584ceb71 | ||
![]() |
1996f1d9b9 | ||
![]() |
f342b07495 | ||
557a328336 | |||
057d243db8 | |||
![]() |
e3a06fdf6c | ||
![]() |
bfe39adaf8 | ||
![]() |
9159a53cce | ||
![]() |
51825eb2da | ||
![]() |
280e2b9ae1 | ||
![]() |
6d56db855f | ||
![]() |
0b782b7dd3 |
3
.github/workflows/ci.yml
vendored
3
.github/workflows/ci.yml
vendored
@@ -16,11 +16,10 @@ jobs:
|
|||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
ruby-version:
|
ruby-version:
|
||||||
- '2.5'
|
|
||||||
- '2.6'
|
|
||||||
- '2.7'
|
- '2.7'
|
||||||
- '3.0'
|
- '3.0'
|
||||||
- '3.1'
|
- '3.1'
|
||||||
|
- '3.2'
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
- name: Set up Ruby ${{ matrix.ruby-version }}
|
- name: Set up Ruby ${{ matrix.ruby-version }}
|
||||||
|
@@ -3,7 +3,7 @@ require:
|
|||||||
- rubocop-rspec
|
- rubocop-rspec
|
||||||
|
|
||||||
AllCops:
|
AllCops:
|
||||||
TargetRubyVersion: '2.5'
|
TargetRubyVersion: '2.7'
|
||||||
NewCops: enable
|
NewCops: enable
|
||||||
|
|
||||||
Gemspec/RequireMFA:
|
Gemspec/RequireMFA:
|
||||||
|
@@ -1,8 +1,8 @@
|
|||||||
FROM alpine:3.13
|
FROM alpine:3.16
|
||||||
|
|
||||||
EXPOSE 8080
|
EXPOSE 8080
|
||||||
|
|
||||||
ENV VERSION=3.2.1
|
ENV VERSION=3.4.0
|
||||||
|
|
||||||
RUN apk --no-cache add openssl ca-certificates && \
|
RUN apk --no-cache add openssl ca-certificates && \
|
||||||
apk --no-cache add ruby ruby-etc ruby-webrick && \
|
apk --no-cache add ruby ruby-etc ruby-webrick && \
|
||||||
|
@@ -7,9 +7,10 @@ require 'logger'
|
|||||||
require 'ipaddr'
|
require 'ipaddr'
|
||||||
require 'yaml'
|
require 'yaml'
|
||||||
require 'rack'
|
require 'rack'
|
||||||
|
require 'rackup'
|
||||||
require 'erb'
|
require 'erb'
|
||||||
require 'metriks'
|
require 'metriks'
|
||||||
require 'better_errors' if ENV['RACK_ENV'] == 'development'
|
require 'better_errors' if ENV.fetch('RACK_ENV', nil) == 'development'
|
||||||
|
|
||||||
require 'openvpn-status-web/status'
|
require 'openvpn-status-web/status'
|
||||||
require 'openvpn-status-web/parser/v1'
|
require 'openvpn-status-web/parser/v1'
|
||||||
@@ -128,21 +129,21 @@ module OpenVPNStatusWeb
|
|||||||
|
|
||||||
# configure rack
|
# configure rack
|
||||||
app = Daemon.new(config['vpns'])
|
app = Daemon.new(config['vpns'])
|
||||||
if ENV['RACK_ENV'] == 'development'
|
if ENV.fetch('RACK_ENV', nil) == 'development'
|
||||||
app = BetterErrors::Middleware.new(app)
|
app = BetterErrors::Middleware.new(app)
|
||||||
BetterErrors.application_root = File.expand_path(__dir__)
|
BetterErrors.application_root = File.expand_path(__dir__)
|
||||||
end
|
end
|
||||||
|
|
||||||
Signal.trap('INT') do
|
Signal.trap('INT') do
|
||||||
OpenVPNStatusWeb.logger.info 'Quitting...'
|
OpenVPNStatusWeb.logger.info 'Quitting...'
|
||||||
Rack::Handler::WEBrick.shutdown
|
Rackup::Handler::WEBrick.shutdown
|
||||||
end
|
end
|
||||||
Signal.trap('TERM') do
|
Signal.trap('TERM') do
|
||||||
OpenVPNStatusWeb.logger.info 'Quitting...'
|
OpenVPNStatusWeb.logger.info 'Quitting...'
|
||||||
Rack::Handler::WEBrick.shutdown
|
Rackup::Handler::WEBrick.shutdown
|
||||||
end
|
end
|
||||||
|
|
||||||
Rack::Handler::WEBrick.run app, Host: config['host'], Port: config['port']
|
Rackup::Handler::WEBrick.run app, Host: config['host'], Port: config['port']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@@ -13,10 +13,10 @@ module OpenVPNStatusWeb
|
|||||||
|
|
||||||
text.lines.each do |line|
|
text.lines.each do |line|
|
||||||
parts = line.strip.split(sep)
|
parts = line.strip.split(sep)
|
||||||
status.client_list_headers = parts[2..-1] if parts[0] == 'HEADER' && parts[1] == 'CLIENT_LIST'
|
status.client_list_headers = parts[2..] if parts[0] == 'HEADER' && parts[1] == 'CLIENT_LIST'
|
||||||
status.client_list << parse_client(parts[1..-1], status.client_list_headers) if parts[0] == 'CLIENT_LIST'
|
status.client_list << parse_client(parts[1..], status.client_list_headers) if parts[0] == 'CLIENT_LIST'
|
||||||
status.routing_table_headers = parts[2..-1] if parts[0] == 'HEADER' && parts[1] == 'ROUTING_TABLE'
|
status.routing_table_headers = parts[2..] if parts[0] == 'HEADER' && parts[1] == 'ROUTING_TABLE'
|
||||||
status.routing_table << parse_route(parts[1..-1], status.routing_table_headers) if parts[0] == 'ROUTING_TABLE'
|
status.routing_table << parse_route(parts[1..], status.routing_table_headers) if parts[0] == 'ROUTING_TABLE'
|
||||||
status.global_stats << parse_global(parts[1..2]) if parts[0] == 'GLOBAL_STATS'
|
status.global_stats << parse_global(parts[1..2]) if parts[0] == 'GLOBAL_STATS'
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@@ -27,9 +27,9 @@ module OpenVPNStatusWeb
|
|||||||
|
|
||||||
status = Status.new
|
status = Status.new
|
||||||
status.client_list_headers = ['Common Name', 'Real Address', 'Data Received', 'Data Sent', 'Connected Since']
|
status.client_list_headers = ['Common Name', 'Real Address', 'Data Received', 'Data Sent', 'Connected Since']
|
||||||
status.client_list = client_list[2..-1].map { |client| parse_client(client) }
|
status.client_list = client_list[2..].map { |client| parse_client(client) }
|
||||||
status.routing_table_headers = ['Virtual Address', 'Common Name', 'Real Address', 'Last Ref']
|
status.routing_table_headers = ['Virtual Address', 'Common Name', 'Real Address', 'Last Ref']
|
||||||
status.routing_table = routing_table[1..-1].map { |route| parse_route(route) }
|
status.routing_table = routing_table[1..].map { |route| parse_route(route) }
|
||||||
status.global_stats = global_stats.map { |global| parse_global(global) }
|
status.global_stats = global_stats.map { |global| parse_global(global) }
|
||||||
status
|
status
|
||||||
end
|
end
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
# frozen_string_literal: true
|
# frozen_string_literal: true
|
||||||
|
|
||||||
module OpenVPNStatusWeb
|
module OpenVPNStatusWeb
|
||||||
VERSION = '3.2.1'
|
VERSION = '3.4.0'
|
||||||
end
|
end
|
||||||
|
@@ -24,10 +24,11 @@ Gem::Specification.new do |s|
|
|||||||
s.executables = ['openvpn-status-web']
|
s.executables = ['openvpn-status-web']
|
||||||
s.extra_rdoc_files = Dir['README.md', 'LICENSE']
|
s.extra_rdoc_files = Dir['README.md', 'LICENSE']
|
||||||
|
|
||||||
s.required_ruby_version = '>= 2.5'
|
s.required_ruby_version = '>= 2.7'
|
||||||
|
|
||||||
s.add_runtime_dependency 'metriks'
|
s.add_runtime_dependency 'metriks'
|
||||||
s.add_runtime_dependency 'rack', '~> 2.0'
|
s.add_runtime_dependency 'rack', '~> 3.0'
|
||||||
|
s.add_runtime_dependency 'rackup', '~> 2'
|
||||||
s.add_runtime_dependency 'webrick', '>= 1.6.1'
|
s.add_runtime_dependency 'webrick', '>= 1.6.1'
|
||||||
|
|
||||||
s.add_development_dependency 'better_errors'
|
s.add_development_dependency 'better_errors'
|
||||||
@@ -37,8 +38,8 @@ Gem::Specification.new do |s|
|
|||||||
s.add_development_dependency 'rack-test'
|
s.add_development_dependency 'rack-test'
|
||||||
s.add_development_dependency 'rake'
|
s.add_development_dependency 'rake'
|
||||||
s.add_development_dependency 'rspec'
|
s.add_development_dependency 'rspec'
|
||||||
s.add_development_dependency 'rubocop', '~> 1.24.0'
|
s.add_development_dependency 'rubocop', '~> 1.43.0'
|
||||||
s.add_development_dependency 'rubocop-rake', '~> 0.6.0'
|
s.add_development_dependency 'rubocop-rake', '~> 0.6.0'
|
||||||
s.add_development_dependency 'rubocop-rspec', '~> 2.7.0'
|
s.add_development_dependency 'rubocop-rspec', '~> 2.18.0'
|
||||||
s.add_development_dependency 'solargraph', '~> 0.44.0'
|
s.add_development_dependency 'solargraph', '~> 0.48.0'
|
||||||
end
|
end
|
||||||
|
Reference in New Issue
Block a user