Skip to content

Commit

Permalink
- clients: fix incorrect info for clients from /etc/hosts
Browse files Browse the repository at this point in the history
Close #1786

Squashed commit of the following:

commit fc66225
Author: Simon Zolin <s.zolin@adguard.com>
Date:   Thu Jun 11 10:57:26 2020 +0300

    - clients: fix incorrect info for clients from /etc/hosts
  • Loading branch information
szolin committed Jun 11, 2020
1 parent cf087fb commit 1356ac2
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 17 deletions.
16 changes: 7 additions & 9 deletions home/clients.go
Original file line number Diff line number Diff line change
Expand Up @@ -612,15 +612,13 @@ func (clients *clientsContainer) addFromHostsFile() {
_ = clients.rmHosts(ClientSourceHostsFile)

n := 0
for ip, names := range hosts {
for _, name := range names {
ok, err := clients.addHost(ip, name.String(), ClientSourceHostsFile)
if err != nil {
log.Debug("Clients: %s", err)
}
if ok {
n++
}
for ip, name := range hosts {
ok, err := clients.addHost(ip, name, ClientSourceHostsFile)
if err != nil {
log.Debug("Clients: %s", err)
}
if ok {
n++
}
}

Expand Down
8 changes: 4 additions & 4 deletions util/auto_hosts.go
Original file line number Diff line number Diff line change
Expand Up @@ -371,11 +371,11 @@ func (a *AutoHosts) ProcessReverse(addr string, qtype uint16) string {
return host
}

// List - get the hosts table. Thread-safe.
func (a *AutoHosts) List() map[string][]net.IP {
table := make(map[string][]net.IP)
// List - get "IP -> hostname" table. Thread-safe.
func (a *AutoHosts) List() map[string]string {
table := make(map[string]string)
a.lock.Lock()
for k, v := range a.table {
for k, v := range a.tableReverse {
table[k] = v
}
a.lock.Unlock()
Expand Down
7 changes: 3 additions & 4 deletions util/auto_hosts_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -49,10 +49,9 @@ func TestAutoHostsResolution(t *testing.T) {

// Test hosts file
table := ah.List()
ips, _ = table["host"]
assert.NotNil(t, ips)
assert.Equal(t, 1, len(ips))
assert.Equal(t, "127.0.0.1", ips[0].String())
name, ok := table["127.0.0.1"]
assert.True(t, ok)
assert.Equal(t, "host", name)

// Test PTR
a, _ := dns.ReverseAddr("127.0.0.1")
Expand Down

0 comments on commit 1356ac2

Please sign in to comment.