Compare commits
	
		
			3 Commits
		
	
	
		
			v1.0.0-rc3
			...
			master
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 0e73dac143 | |||
| 8ac556ad8b | |||
| 6e9947809c | 
| @ -26,7 +26,7 @@ import ( | ||||
| ) | ||||
|  | ||||
| const ( | ||||
| 	version = "1.0.0-rc3" | ||||
| 	version = "1.0.2" | ||||
| ) | ||||
|  | ||||
| var ( | ||||
| @ -227,7 +227,12 @@ func handleConnection(connClt net.Conn, conLdap *ldap.Conn) { | ||||
| 		// First query netCache built with ipNetworkNumber | ||||
| 		res, err := isIPContainedInNetCache(ip) | ||||
| 		if err != nil { | ||||
| 			if strings.EqualFold(err.Error(), fmt.Sprintf("Invalid IP: %s", ip)) { | ||||
| 				// We don't want those msg to pollute logs | ||||
| 				logstream.Info(err.Error()) | ||||
| 			} else { | ||||
| 				logstream.Error(err.Error()) | ||||
| 			} | ||||
| 			sendResponse(connClt, err.Error(), 500) | ||||
| 			continue | ||||
| 		} | ||||
| @ -276,10 +281,14 @@ func searchLdap(searchReq *ldap.SearchRequest, attempt int) (*ldap.SearchResult, | ||||
| 	result, err := conLdap.Search(searchReq) | ||||
| 	mutex.Unlock() | ||||
| 	// Let's just manage connection errors here | ||||
| 	if err != nil && strings.HasSuffix(err.Error(), "ldap: connection closed") { | ||||
| 	if (err != nil && (strings.HasSuffix(err.Error(), "ldap: connection closed")|| strings.HasSuffix(err.Error(), "ldap: conn is nil, expected net.Conn"))) { | ||||
| 		logstream.Error("LDAP connection closed, retrying") | ||||
| 		mutex.Lock() | ||||
| 		// 16/01/2023: panic: runtime error: invalid memory address or nil pointer dereference | ||||
| 		// probably bc connection is already closed | ||||
| 		if conLdap != nil { | ||||
| 			conLdap.Close() | ||||
| 		} | ||||
| 		conLdap, err = connectLdap() | ||||
| 		mutex.Unlock() | ||||
| 		if err != nil { | ||||
| @ -297,12 +306,12 @@ func connectLdap() (*ldap.Conn, error) { | ||||
| 	conLdap, err = ldap.DialURL(*ldapURL) | ||||
| 	if err != nil { | ||||
| 		logstream.Errorf("Error dialing LDAP on %s: %v\n", *ldapURL, err) | ||||
| 		return conLdap, err | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	err = conLdap.Bind(*ldapUser, *ldapPass) | ||||
| 	if err != nil { | ||||
| 		logstream.Errorf("Error binding LDAP: %s", err) | ||||
| 		return conLdap, err | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return conLdap, err | ||||
| } | ||||
| @ -366,7 +375,7 @@ func main() { | ||||
| 		return | ||||
| 	} | ||||
|  | ||||
| 	fmt.Printf("MyNetTCPTable v.%s\n", version) | ||||
| 	fmt.Printf("%s: MyNetTCPTable v.%s starting\n", time.Now().Format(time.RFC3339), version) | ||||
|  | ||||
| 	logstream = logrus.New() | ||||
| 	level, err := logrus.ParseLevel(*logLevel) | ||||
|  | ||||
		Reference in New Issue
	
	Block a user