sparoid 1.0.7 → 1.0.12
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.
- checksums.yaml +4 -4
- data/.rubocop.yml +1 -1
- data/CHANGELOG.md +21 -0
- data/README.md +1 -1
- data/exe/sparoid +6 -2
- data/lib/sparoid.rb +42 -2
- data/lib/sparoid/cli.rb +8 -5
- data/lib/sparoid/version.rb +1 -1
- data/sparoid.gemspec +1 -1
- metadata +4 -4
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 12dad3dbab45bb38650465dab2b26f356c051569b06d20ba1bcfd6af11eb9701
|
4
|
+
data.tar.gz: 0b17fe457b36978f1b682153cb14578192cb657a846fadcbb3abb2cf82e07bb6
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 1c31f7b1fa30e2d064b0e92e79b2b567bdfa4021995d7f52c25b6b4373d08062ed091aab8187aeb42051c11e0c7c1b994d158878e64311eed28e68d1e3fe4008
|
7
|
+
data.tar.gz: cacd2adf45ed9fa8e31b063809e01cf0371c6d13670e24b5bdb17f7c2623c2f9592c7e38b6df18a5f529db9628d4197baf323a9d58124b8eb6ea75762c3a6d78
|
data/.rubocop.yml
CHANGED
data/CHANGELOG.md
CHANGED
@@ -1,3 +1,24 @@
|
|
1
|
+
## [1.0.12] - 2021-06-14
|
2
|
+
|
3
|
+
- Use file locking to prevent multiple processes/threads to write to the public ip cache file
|
4
|
+
|
5
|
+
## [1.0.11] - 2021-06-14
|
6
|
+
|
7
|
+
- Log hostname when reporting unhandled exceptions
|
8
|
+
|
9
|
+
## [1.0.10] - 2021-06-09
|
10
|
+
|
11
|
+
- Cache public IP in /tmp/.sparoid_public_ip for 1 min
|
12
|
+
|
13
|
+
## [1.0.9] - 2021-05-23
|
14
|
+
|
15
|
+
- Exit gracefully on abort (ctrl-c) instead of dumping huge stacktrace
|
16
|
+
- Sleep 20ms aftering sending UDP package to allow for remote host to open its firewall
|
17
|
+
|
18
|
+
## [1.0.8] - 2021-04-27
|
19
|
+
|
20
|
+
- Get ENV variables if config file is missing
|
21
|
+
|
1
22
|
## [1.0.7] - 2021-04-27
|
2
23
|
|
3
24
|
- Get key and hmac key from ENV variables
|
data/README.md
CHANGED
data/exe/sparoid
CHANGED
data/lib/sparoid.rb
CHANGED
@@ -11,9 +11,14 @@ module Sparoid
|
|
11
11
|
|
12
12
|
# Send an authorization packet
|
13
13
|
def auth(key, hmac_key, host, port)
|
14
|
-
msg = message(
|
14
|
+
msg = message(cached_public_ip)
|
15
15
|
data = prefix_hmac(hmac_key, encrypt(key, msg))
|
16
16
|
sendmsg(host, port, data)
|
17
|
+
|
18
|
+
# wait some time for the server to actually open the port
|
19
|
+
# if we don't wait the next SYN package will be dropped
|
20
|
+
# and it have to be redelivered, adding 1 second delay
|
21
|
+
sleep 0.02
|
17
22
|
end
|
18
23
|
|
19
24
|
# Generate new aes and hmac keys, print to stdout
|
@@ -67,7 +72,42 @@ module Sparoid
|
|
67
72
|
version = 1
|
68
73
|
ts = (Time.now.utc.to_f * 1000).floor
|
69
74
|
nounce = OpenSSL::Random.random_bytes(16)
|
70
|
-
[version, ts, nounce, ip.address].pack("
|
75
|
+
[version, ts, nounce, ip.address].pack("N q> a16 a4")
|
76
|
+
end
|
77
|
+
|
78
|
+
def cached_public_ip
|
79
|
+
if up_to_date_cache?
|
80
|
+
read_cache
|
81
|
+
else
|
82
|
+
write_cache
|
83
|
+
end
|
84
|
+
rescue StandardError => e
|
85
|
+
warn "Sparoid: #{e.inspect}"
|
86
|
+
public_ip
|
87
|
+
end
|
88
|
+
|
89
|
+
def up_to_date_cache?
|
90
|
+
mtime = File.mtime("/tmp/.sparoid_public_ip")
|
91
|
+
(Time.now - mtime) <= 60 # cache is valid for 1 min
|
92
|
+
rescue Errno::ENOENT
|
93
|
+
false
|
94
|
+
end
|
95
|
+
|
96
|
+
def read_cache
|
97
|
+
File.open("/tmp/.sparoid_public_ip", "r") do |f|
|
98
|
+
f.flock(File::LOCK_SH)
|
99
|
+
Resolv::IPv4.create f.read
|
100
|
+
end
|
101
|
+
end
|
102
|
+
|
103
|
+
def write_cache
|
104
|
+
File.open("/tmp/.sparoid_public_ip", File::WRONLY | File::CREAT, 0o0644) do |f|
|
105
|
+
f.flock(File::LOCK_EX)
|
106
|
+
ip = public_ip
|
107
|
+
f.truncate(0)
|
108
|
+
f.write ip.to_s
|
109
|
+
ip
|
110
|
+
end
|
71
111
|
end
|
72
112
|
|
73
113
|
def public_ip
|
data/lib/sparoid/cli.rb
CHANGED
@@ -13,7 +13,7 @@ module Sparoid
|
|
13
13
|
rescue Errno::ENOENT
|
14
14
|
abort "Sparoid: Config not found"
|
15
15
|
rescue StandardError => e
|
16
|
-
abort "Sparoid: #{e.message}"
|
16
|
+
abort "Sparoid: #{e.message} (#{host})"
|
17
17
|
end
|
18
18
|
|
19
19
|
desc "connect HOST PORT [SPA-PORT]", "Send a SPA, TCP connect, and then pass the FD back to the parent"
|
@@ -26,7 +26,7 @@ module Sparoid
|
|
26
26
|
end
|
27
27
|
Sparoid.fdpass(host, port)
|
28
28
|
rescue StandardError => e
|
29
|
-
abort "Sparoid: #{e.message}"
|
29
|
+
abort "Sparoid: #{e.message} (#{host})"
|
30
30
|
end
|
31
31
|
|
32
32
|
desc "keygen", "Generate an encryption key and a HMAC key"
|
@@ -41,14 +41,17 @@ module Sparoid
|
|
41
41
|
private
|
42
42
|
|
43
43
|
def send_auth(host, port, config)
|
44
|
-
key =
|
45
|
-
hmac_key = ENV["SPAROID_HMAC_KEY"]
|
46
|
-
key, hmac_key = get_keys(parse_ini(config)) if config
|
44
|
+
key, hmac_key = get_keys(parse_ini(config))
|
47
45
|
Sparoid.auth(key, hmac_key, host, port.to_i)
|
48
46
|
end
|
49
47
|
|
50
48
|
def parse_ini(path)
|
51
49
|
File.readlines(File.expand_path(path)).map! { |line| line.split("=", 2).map!(&:strip) }.to_h
|
50
|
+
rescue Errno::ENOENT
|
51
|
+
{
|
52
|
+
"key" => ENV["SPAROID_KEY"],
|
53
|
+
"hmac-key" => ENV["SPAROID_HMAC_KEY"]
|
54
|
+
}
|
52
55
|
end
|
53
56
|
|
54
57
|
def get_keys(config)
|
data/lib/sparoid/version.rb
CHANGED
data/sparoid.gemspec
CHANGED
@@ -11,7 +11,7 @@ Gem::Specification.new do |spec|
|
|
11
11
|
spec.summary = "Single Packet Authorisation client"
|
12
12
|
spec.homepage = "https://github.com/84codes/sparoid.rb"
|
13
13
|
spec.license = "MIT"
|
14
|
-
spec.required_ruby_version = Gem::Requirement.new(">= 2.
|
14
|
+
spec.required_ruby_version = Gem::Requirement.new(">= 2.5.0")
|
15
15
|
|
16
16
|
spec.metadata["homepage_uri"] = spec.homepage
|
17
17
|
spec.metadata["source_code_uri"] = spec.homepage
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: sparoid
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.0.
|
4
|
+
version: 1.0.12
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Carl Hörberg
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2021-
|
11
|
+
date: 2021-06-24 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: thor
|
@@ -62,14 +62,14 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
62
62
|
requirements:
|
63
63
|
- - ">="
|
64
64
|
- !ruby/object:Gem::Version
|
65
|
-
version: 2.
|
65
|
+
version: 2.5.0
|
66
66
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
67
67
|
requirements:
|
68
68
|
- - ">="
|
69
69
|
- !ruby/object:Gem::Version
|
70
70
|
version: '0'
|
71
71
|
requirements: []
|
72
|
-
rubygems_version: 3.2.
|
72
|
+
rubygems_version: 3.2.15
|
73
73
|
signing_key:
|
74
74
|
specification_version: 4
|
75
75
|
summary: Single Packet Authorisation client
|