forked from lug/matterbridge
		
	Add SkipTLSVerify option for mattermost, allows selfsigned certificates
This commit is contained in:
		| @@ -59,7 +59,8 @@ port=9999 | |||||||
| showjoinpart=true #show irc users joining and parting | showjoinpart=true #show irc users joining and parting | ||||||
| #the token you get from the outgoing webhook in mattermost. If empty no token check will be done. | #the token you get from the outgoing webhook in mattermost. If empty no token check will be done. | ||||||
| token=yourtokenfrommattermost | token=yourtokenfrommattermost | ||||||
|  | #disable certificate checking (selfsigned certificates) | ||||||
|  | #SkipTLSVerify=true | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### mattermost | ### mattermost | ||||||
|   | |||||||
							
								
								
									
										11
									
								
								config.go
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								config.go
									
									
									
									
									
								
							| @@ -16,11 +16,12 @@ type Config struct { | |||||||
| 		Channel       string | 		Channel       string | ||||||
| 	} | 	} | ||||||
| 	Mattermost struct { | 	Mattermost struct { | ||||||
| 		URL          string | 		URL           string | ||||||
| 		Port         int | 		Port          int | ||||||
| 		ShowJoinPart bool | 		ShowJoinPart  bool | ||||||
| 		Token        string | 		Token         string | ||||||
| 		IconURL      string | 		IconURL       string | ||||||
|  | 		SkipTLSVerify bool | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -12,3 +12,4 @@ port=9999 | |||||||
| showjoinpart=true | showjoinpart=true | ||||||
| #token=yourtokenfrommattermost | #token=yourtokenfrommattermost | ||||||
| IconURL="http://youricon.png" | IconURL="http://youricon.png" | ||||||
|  | #SkipTLSVerify=true | ||||||
|   | |||||||
| @@ -20,7 +20,8 @@ func NewBridge(name string, config *Config) *Bridge { | |||||||
| 	b := &Bridge{} | 	b := &Bridge{} | ||||||
| 	b.Config = config | 	b.Config = config | ||||||
| 	b.m = matterhook.New(b.Config.Mattermost.URL, | 	b.m = matterhook.New(b.Config.Mattermost.URL, | ||||||
| 		matterhook.Config{Port: b.Config.Mattermost.Port, Token: b.Config.Mattermost.Token}) | 		matterhook.Config{Port: b.Config.Mattermost.Port, Token: b.Config.Mattermost.Token, | ||||||
|  | 			InsecureSkipVerify: b.Config.Mattermost.SkipTLSVerify}) | ||||||
| 	b.i = b.createIRC(name) | 	b.i = b.createIRC(name) | ||||||
| 	go b.handleMatter() | 	go b.handleMatter() | ||||||
| 	return b | 	return b | ||||||
| @@ -68,7 +69,11 @@ func (b *Bridge) Send(nick string, message string) error { | |||||||
| 	matterMessage := matterhook.OMessage{IconURL: b.Config.Mattermost.IconURL} | 	matterMessage := matterhook.OMessage{IconURL: b.Config.Mattermost.IconURL} | ||||||
| 	matterMessage.UserName = nick | 	matterMessage.UserName = nick | ||||||
| 	matterMessage.Text = message | 	matterMessage.Text = message | ||||||
| 	b.m.Send(matterMessage) | 	err := b.m.Send(matterMessage) | ||||||
|  | 	if err != nil { | ||||||
|  | 		log.Println(err) | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3,6 +3,7 @@ package matterhook | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"bytes" | 	"bytes" | ||||||
|  | 	"crypto/tls" | ||||||
| 	"encoding/json" | 	"encoding/json" | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"github.com/gorilla/schema" | 	"github.com/gorilla/schema" | ||||||
| @@ -39,16 +40,18 @@ type IMessage struct { | |||||||
|  |  | ||||||
| // Client for Mattermost. | // Client for Mattermost. | ||||||
| type Client struct { | type Client struct { | ||||||
| 	url string | 	url        string | ||||||
| 	In  chan IMessage | 	In         chan IMessage | ||||||
| 	Out chan OMessage | 	Out        chan OMessage | ||||||
|  | 	httpclient *http.Client | ||||||
| 	Config | 	Config | ||||||
| } | } | ||||||
|  |  | ||||||
| // Config for client. | // Config for client. | ||||||
| type Config struct { | type Config struct { | ||||||
| 	Port  int    // Port to listen on. | 	Port               int    // Port to listen on. | ||||||
| 	Token string // Only allow this token from Mattermost. (Allow everything when empty) | 	Token              string // Only allow this token from Mattermost. (Allow everything when empty) | ||||||
|  | 	InsecureSkipVerify bool   // disable certificate checking | ||||||
| } | } | ||||||
|  |  | ||||||
| // New Mattermost client. | // New Mattermost client. | ||||||
| @@ -57,6 +60,11 @@ func New(url string, config Config) *Client { | |||||||
| 	if c.Port == 0 { | 	if c.Port == 0 { | ||||||
| 		c.Port = 9999 | 		c.Port = 9999 | ||||||
| 	} | 	} | ||||||
|  | 	tr := &http.Transport{ | ||||||
|  | 		TLSClientConfig: &tls.Config{InsecureSkipVerify: config.InsecureSkipVerify}, | ||||||
|  | 	} | ||||||
|  | 	c.httpclient = &http.Client{Transport: tr} | ||||||
|  |  | ||||||
| 	go c.StartServer() | 	go c.StartServer() | ||||||
| 	return c | 	return c | ||||||
| } | } | ||||||
| @@ -124,7 +132,7 @@ func (c *Client) Send(msg OMessage) error { | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	resp, err := http.Post(c.url, "application/json", bytes.NewReader(buf)) | 	resp, err := c.httpclient.Post(c.url, "application/json", bytes.NewReader(buf)) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Wim
					Wim