[19/12/2018] - ~5mins - #golang #code
Je piétine.
J'ai un peu lu à droite à gauche, je sais toujours pas trop comment m'en sortir de ces histoires de "variables globales".
Du coup j'ai continué un peu à raffiner le support d'IRC :
C'est pas bien il paraît mais j'ai pas trop réussi à savoir si dans mon cas c'était justifié ou non, mais comme ça marche pour le moment ça me va bien.
J'ai été étonné de voir que dans la lib strings il n'y avait pas moyen de récupérer une sous-chaîne en coupant une chaîne en entrée jusqu'à un caractère particulier du coup me la suis rajoutée.
Rien de bien méchant mais ça permet de se simplifier la tâche plus tard.
J'ai remarqué une petite erreur dans la logique de la fonction parseIrc où je bouclais sur plus qu'il ne fallait.
Je pense qu'il serait malin de remplacer l'empilement de if par un switch, mais là j'ai un poil la flemme pour le moment.
Bon ça peut sembler assez peu mais … au final je suis assez satisfait des maigres avancées, j'ai l'impression (mais c'est peut-être complètement faux) que mon code est un peu plus robuste grâce aux variables globales.
{{}}
package main
import (
"bufio"
"fmt"
"net"
"os"
"io"
"strings"
"time"
)
var server string = "localhost"
var port string = "6667"
var channel string = "#lms"
var nick string = "bab"
var commander string = ":Lord!Lord@geeknode.fuckyeah"
var onchan bool
var rouge string = "\033[1;31m"
var vert string = "\033[1;32m"
var jaune string = "\033[1;33m"
var cyan string = "\033[1;36m"
var normal string = "\033[0m"
var me string
var ircconn net.Conn
var debug bool
func main() {
if len(os.Args) > 1 {
server = os.Args[1]
}
ircconn = initIrc(server, port, nick, channel)
go incoming()
ircconnbuf := bufio.NewReader(ircconn)
go io.Copy(ircconn, os.Stdin)
for {
msg, err := ircconnbuf.ReadString('\n')
if err != nil {
fmt.Println(err)
break
}
fmt.Print(jaune+"<< "+msg+normal)
parseIrc(msg)
}
defer ircconn.Close()
}
// ------------------
// Côté IRC
// ------------------
func initIrc(server string, port string, nick string, channel string) net.Conn{
conn, err := net.Dial("tcp",server+":"+port)
fmt.Println(rouge+server+":"+port+normal)
if err != nil {
fmt.Println(err)
os.Exit(1)
}
fmt.Println(rouge+">> NICK "+nick+normal)
io.WriteString(conn,"NICK "+nick+"\n")
fmt.Println(rouge+">> USER "+nick+" 0.0.0.0 "+nick+" :"+nick+" bot"+normal)
io.WriteString(conn,"USER "+nick+" 0.0.0.0 "+nick+" :"+nick+" bot\n")
fmt.Println(rouge+">> JOIN "+channel+normal)
io.WriteString(conn,"JOIN "+channel+"\n")
return conn
}
func parseIrc(msg string){
var elements []string = strings.Fields(msg)
for i, element := range elements {
fmt.Print(cyan+"[",i,"|"+normal+element+cyan+"] "+normal )
}
fmt.Println("")
if elements[1] == "421" {
fmt.Println("!! Commande non reconnue par le serveur !!")
}
if elements[1] == "433" {
nick = nick+"_"
io.WriteString(ircconn,"NICK "+nick+"\n")
}
if elements[0] == "PING" {
fmt.Print(rouge+">> PONG "+strings.TrimPrefix(msg, "PING :")+normal)
io.WriteString(ircconn,"PONG "+strings.TrimPrefix(msg, "PING :")+"\n")
}
if elements[1] == "JOIN" {
if ":"+nick == stringCut(elements[0],"!"){
me = strings.TrimPrefix(elements[0],":")
fmt.Println(me+" a rejoin le salon "+strings.Trim(elements[2],":"))
onchan = true
sendIrc("c'est moi que vla!")
}
}
if elements[1] == "PART" {
fmt.Println("On est parti de "+strings.Trim(elements[2],":"))
onchan = false
}
if elements[1] == "KICK" && elements[3] == nick {
fmt.Println("Ptain on s'est fait kicker de "+elements[2]+" par "+elements[4]+" !")
io.WriteString(ircconn,"JOIN "+channel+"\n")
}
if elements[1] == ":Closing" && elements[2] == "Link:" {
// Déconnecté
ircconn = initIrc(server, port, nick, channel)
}
}
func sendIrc(msg string){
msg = strings.TrimSpace(msg)
fmt.Print(rouge+">> PRIVMSG "+channel+" :"+msg+"\n"+normal)
io.WriteString(ircconn,"PRIVMSG "+channel+" :"+msg+"\n")
}
// ------------------
// Serveur en écoute
// ------------------
func incoming(){
in, err :=net.Listen("tcp",":4321")
defer in.Close()
if err != nil {
fmt.Println(err)
os.Exit(1)
}
for {
inconn, err :=in.Accept()
if err != nil {
fmt.Println(err)
continue
}
go handleIncoming(inconn)
}
}
func handleIncoming(in net.Conn){
fmt.Println(vert+"Incoming from ",in.RemoteAddr(),normal)
inbuf := bufio.NewReader(in)
for {
inmsg, err := inbuf.ReadString('\n')
if err != nil || !onchan || inmsg == "\n" {
break
}
fmt.Print(vert+"<<]] "+inmsg+normal)
sendIrc(inmsg)
time.Sleep(500 * time.Millisecond)
}
}
// ------------
// Génériques
// ------------
func stringCut(incoming string, pattern string) string{
var results = strings.Split(incoming, pattern)
if len(results) < 1 {
return incoming
} else {
return results[0]
}
}
{{}}
Ha au fait j'ai installé un vrai serveur IRC pour tester en condition un peu plus réelle sans pour autant pourrir un vrai réseau IRC…
Du coup mon ptit script bash d'hier n'a pas servi.
[19/12/2018] - #golang #code
=> [>> Suivant >>] ⏭ Une semaine pour coder par soi même : Jour 4 | [<< Précédent <<] ⏮ L'affaire du Siècle This content has been proxied by September (ba2dc).Proxy Information
text/gemini