Skip to content
GitLab
Explorer
Connexion
Navigation principale
Rechercher ou aller à…
Projet
P
PlayBot
Gestion
Activité
Membres
Labels
Programmation
Tickets
Tableaux des tickets
Jalons
Wiki
Wiki externe
Code
Requêtes de fusion
Dépôt
Branches
Validations
Étiquettes
Graphe du dépôt
Comparer les révisions
Déploiement
Releases
Registre de modèles
Surveillance
Incidents
Analyse
Données d'analyse des chaînes de valeur
Analyse des contributeurs
Données d'analyse du dépôt
Expériences du modèle
Aide
Aide
Support
Documentation de GitLab
Comparer les forfaits GitLab
Forum de la communauté GitLab
Contribuer à GitLab
Donner votre avis
Raccourcis clavier
?
Extraits de code
Groupes
Projets
Afficher davantage de fils d'Ariane
Alexandre MORIGNOT
PlayBot
Validations
37991399
Valider
37991399
rédigé
24 oct. 2012
par
Alexandre Morignot
Validation de
Animation des soirees
24 oct. 2012
Parcourir les fichiers
Options
Téléchargements
Correctifs
Plain Diff
gestion des favoris
parent
8740eec5
Branches
Branches contenant la validation
Étiquettes
Étiquettes contenant la validation
Aucune requête de fusion associée trouvée
Modifications
1
Afficher les modifications d'espaces
En ligne
Côte à côte
Affichage de
1 fichier modifié
PlayBot.pl
+65
-4
65 ajouts, 4 suppressions
PlayBot.pl
avec
65 ajouts
et
4 suppressions
PlayBot.pl
+
65
−
4
Voir le fichier @
37991399
...
...
@@ -28,6 +28,8 @@ my $username = 'nightiies';
my
$channel
=
'
#nightiies
';
my
$admin
=
'
moise
';
my
$baseurl
=
'
http://nightiies.iiens.net/links/
';
my
@nicksToVerify
;
my
@codesToVerify
;
my
$debug
=
0
;
...
...
@@ -56,6 +58,7 @@ POE::Session->create(
irc_001
=>
\
&on_connect
,
irc_public
=>
\
&on_speak
,
irc_msg
=>
\
&on_query
,
irc_notice
=>
\
&on_notice
,
_flux
=>
\
&flux
},
);
...
...
@@ -131,7 +134,7 @@ sub on_connect
sub
on_query
{
my
(
$user
,
$msg
)
=
@_
[
ARG0
,
ARG2
];
$user
=
(
split
(
/!/
,
$user
)
)[
0
]
;
my
(
$nick
)
=
split
(
/!/
,
$user
);
if
(
$msg
=~
m/^!/
&&
$user
eq
$admin
)
{
my
$commande
=
(
$msg
=~
m/^!([^ ]*)/
)[
0
];
...
...
@@ -144,6 +147,56 @@ sub on_query
}
}
}
elsif
(
$msg
=~
/^PB/
)
{
# on vérifie si le nick est register
push
(
@nicksToVerify
,
$nick
);
push
(
@codesToVerify
,
$msg
);
$irc
->
yield
(
privmsg
=>
$nick
=>
'
Vérification en cours…
');
$irc
->
yield
(
privmsg
=>
nickserv
=>
'
info
'
.
$nick
);
}
}
sub
on_notice
{
my
(
$user
,
$msg
)
=
@_
[
ARG0
,
ARG2
];
my
(
$nick
)
=
split
(
/!/
,
$user
);
print
$nick
.
'
:
'
.
$msg
.
"
\n
";
return
unless
(
$nick
=~
/^NickServ$/i
);
my
$nickToVerify
=
shift
@nicksToVerify
;
my
$code
=
shift
@codesToVerify
;
return
unless
(
defined
(
$nickToVerify
));
if
(
$msg
!~
/$nickToVerify/
)
{
push
(
@nicksToVerify
,
$nickToVerify
);
push
(
@codesToVerify
,
$code
);
}
elsif
(
$msg
=~
/isn't registered/
)
{
$irc
->
yield
(
privmsg
=>
$nickToVerify
=>
"
Il faut que ton pseudo soit enregistré auprès de NickServ
");
}
else
{
$log
->
info
("
ahahahah
"
.
$code
);
my
$sth
=
$dbh
->
prepare_cached
('
SELECT user FROM playbot_codes WHERE code = ?
');
$log
->
error
("
Counldn't prepare querie; aborting
")
unless
(
defined
$sth
);
$sth
->
execute
(
$code
);
if
(
$sth
->
rows
)
{
my
$sth
=
$dbh
->
prepare_cached
('
UPDATE playbot_codes SET nick = ? WHERE code = ?
');
$log
->
error
("
Couldn't prepare querie; aborting
")
unless
(
defined
$sth
);
$sth
->
execute
(
$nickToVerify
,
$code
)
or
$log
->
error
("
Couldn't finish transaction:
"
.
$dbh
->
errstr
);
$irc
->
yield
(
privmsg
=>
$nickToVerify
=>
'
Association effectuée
');
$irc
->
yield
(
privmsg
=>
$nickToVerify
=>
'
pour enregistrer un lien dans tes favoris : !fav <id>
');
}
else
{
$irc
->
yield
(
privmsg
=>
$nickToVerify
=>
"
Ce code n'existe pas
");
}
}
}
...
...
@@ -175,6 +228,14 @@ sub on_speak
eval
{
%content
=
zippy
(
$url
)
};
$site
=
'
zippyshare
';
}
elsif
(
$msg
=~
/!fav ([0-9]+)/
)
{
my
$sth
=
$dbh
->
prepare_cached
('
INSERT INTO playbot_fav (id, user) SELECT ?, user FROM playbot_codes WHERE nick = ?
');
$sth
->
execute
(
$
1
,
$nick
)
or
$log
->
error
("
Couldn't finish transaction:
"
.
$dbh
->
errstr
);
$irc
->
yield
(
privmsg
=>
$chan
=>
'
Ok
');
return
;
}
else
{
return
;
}
...
...
@@ -196,10 +257,10 @@ sub on_speak
}
if
(
defined
$content
{'
author
'})
{
$irc
->
yield
(
privmsg
=>
$chan
=>
$content
{'
title
'}
.
'
|
'
.
$content
{'
author
'})
;
$irc
->
yield
(
privmsg
=>
$chan
=>
'
[
'
.
$dbh
->
{
mysql_insertid
}
.
'
]
'
.
$content
{'
title
'}
.
'
|
'
.
$content
{'
author
'})
;
}
else
{
$irc
->
yield
(
privmsg
=>
$chan
=>
$content
{'
title
'});
$irc
->
yield
(
privmsg
=>
$chan
=>
'
[
'
.
$dbh
->
{
mysql_insertid
}
.
'
]
'
.
$content
{'
title
'})
;
}
}
...
...
Ce diff est replié.
Cliquez pour l'agrandir.
Aperçu
0%
Chargement en cours
Veuillez réessayer
ou
joindre un nouveau fichier
.
Annuler
You are about to add
0
people
to the discussion. Proceed with caution.
Terminez d'abord l'édition de ce message.
Enregistrer le commentaire
Annuler
Please
se connecter
to comment