Jump to content

chain

Administrators
  • Posts

    6030
  • Joined

  • Last visited

  • Days Won

    17

Everything posted by chain

  1. Description : Ce script vous permet d'afficher des articles de l'encyclopédie Wikipédia. Syntaxe : !wiki [.langue] <recherche> Affiche l'article correspondant à votre recherche. La langue par défaut est le français, mais vous pouvez changer ce réglage ou effectuer des recherches dans d'autres langues. Vous devez spécifier la langue telle qu'elle est présente dans l'adresse de Wikipédia. Voyez http://en.wikipedia.org/wiki/List_of_Wikipedias#List pour plus de détails. !wiki -results [.langue] <recherche> Affiche une liste des articles correspondant à la recherche <recherche>. Dépendances : le package json le package http le package tls Tcl 8.5 Activation : Pour activer le script, il faut taper .chanset #salon +wikipedia en partyline. Changelog Version 1.2 par ealexp (29/07/2017) 599 téléchargements - Correction d'un bug qui empêchait d'afficher correctement certains articles Version 1.1 par ealexp (01/08/2016) 0 téléchargements Ajout du support https - Nécessite le package tcl-tls Version 1.0.1 par ealexp (22/09/2012) 0 téléchargements Petite correction dans les commentaires. Version 1.0 par ealexp (22/09/2012) 0 téléchargements Première version. 20170729173720-wikipedia.tcl
  2. Description Automatic Translator est un traducteur fonctionnant grâce à l'API de Yandex et permettant de traduire des textes en 92 langues différentes. Il fait également office d'interprète en vous permettant de traduire automatiquement et presqu'instantanément tout ce que dit un utilisateur. Fonctionnalités Support multilingue (packs de langue français et anglais fournis). Traduction de 92 langues différentes. Quota de 1 000 000 de caractères par jour ou 10 000 000 par mois avec la version gratuite de l'API de Yandex (info datée du 16/04/2020). L'interprète peut détecter automatiquement la langue d'origine et la traduire dans la langue de votre choix. L'interprète automatique ne tentera pas de traduire les commandes. L'interprète automatique ne traduira que ce qui nécessite de l'être. L'interprète automatique ne tentera pas de traduire les nicks des utilisateurs présents s'ils sont utilisés dans une phrase. La connexion à l'API se fait de manière asynchrone. Anti-flood. Possibilité de configurer des commandes alternatives. Screenshots http://i.imgur.com/80mvOaj.png http://i.imgur.com/PkgMI9k.png http://i.imgur.com/ZmJuHlA.png Syntaxe !traduire [[depuis-]vers] <texte> Traduit le texte spécifié. !translate lang ou !autotranslate lang Affiche la liste détaillée des langues supportées. !autotranslate <nick> [[depuis-]vers] Active l'interprète automatique sur l'utilisateur spécifié. !autotranslate <nick> off Désactive l'interprète automatique sur l'utilisateur spécifié. Langues supportées Afrikaans, Amharique, Arabe, Azéri, Bachkir, Biélorusse, Bulgare, Bengali, Bosnien, Catalan, Cebuano, Tchèque, Gallois, Danois, Allemand, Grec, Anglais, Espéranto, Espagnol, Estonien, Basque, Perse, Finnois, Français, Irlandais, Écossais, Galicien, Gujarati, Hébreu, Hindi, Croate, Haïtien Créole, Hongrois, Arménien, Indonésien, Islandais, Italien, Japonais, Javanais, Géorgien, Kazakh, Khmer, Kannada, Coréen, Kirghize, Latin, Luxembourgeois, Laotien, Lituanien, Letton, Malgache, Mari, Maori, Macédonien, Malayâlam, Mongolien, Marathi, Hill Mari, Malais, Maltais, Népalais, Néerlandais, Norvégien, Punjabi, Papiamento, Polonais, Portuguais, Roumain, Russe, Cinghalais, Slovaque, Slovène, Albanais, Serbe, Sundanais, Suédois, Swahili, Tamil, Telugu, Tadjik, Thaï, Tagalog, Turc, Tatar, Oudmourtie, Ukrainien, Urdu, Ouzbek, Vietnamien, Ourdou, Yiddish, Chinois Installation et activation Vous aurez besoin des packages TLS et JSON. Pour activer Automatic Translator sur un chan, vous devez taper ceci en partyline de l'Eggdrop : .chanset #NomDuChan +AutoTranslator et ceci pour le désactiver : .chanset #NomDuChan -AutoTranslator Attention aux majuscules ! Problèmes connus Les langues utilisant des caractères unicode ne sont pas supportées en entrée sur les Eggdrops v1.6.x. Changelog Version 1.1 par MenzAgitat (16/04/2020) 276 téléchargements Ajout : les langues suivantes sont maintenant supportées : Amharique, Bachkir, Bengali, Cebuano, Espéranto, Écossais, Gujarati, Hindi, Javanais, Khmer, Kannada, Luxembourgeois, Laotien, Mari, Maori, Malayâlam, Marathi, Hill Mari, Népalais, Punjabi, Papiamento, Cinghalais, Sundanais, Tamil, Telugu, Oudmourtie, Urdu, Ourdou et Yiddish. Modification : le fonctionnement du paramètre fix_charset a été inversé, reportez-vous à sa description. Modification : abandon du paramètre tls_workaround, il est possible de faire fonctionner correctement le package tls avec un Windrop. Correction : le script refusait de se charger sur les Eggdrops v1.8+ Correction : l'encodage des caractères était corrompu sur les Eggdrops v1.8+ si le mode monochrome était activé. Correction : le catalogue de messages n'était pas déchargé de la mémoire par la procédure de désinstallation. Correction : une erreur se produisait si l'antiflood était désactivé. Correction : l'accent grave utilisé comme une apostrophe par certains utilisateurs n'était pas reconnu. Correction : une erreur se produisait lors du rechargement du script, après un rehash par exemple. Version 1.03 par MenzAgitat (11/04/2016) 52 téléchargements Correction : le système de préservation des nicks dans l'interprète automatique était susceptible de corrompre un charset unicode lors de la substitution. Version 1.02 par MenzAgitat (10/04/2016) 0 téléchargements Correction : le paramètre autotranslate_cmds avait été mal orthographié dans le fichier .cfg, ce qui provoquait une erreur au démarrage du script. Cela vient du fait que la config utilisée pour les releases est un peu différentes des réglages que j'utilise couramment chez moi. Correction : l'adjonction du préfixe indiquant les langues traduites au début du texte traduit corrompait le charset de certaines langues unicode. Correction : les codes de styles (couleurs, gras, ...) sont maintenant filtrés avant soumission du texte à Yandex. Modification : la version requise pour le package tls est passée de la v1.6 à la v1.5 Modification : la version requise pour le package json est passée de la v1.3.0 à la v1.0 Modification : la description du paramètre fix_charset a été modifiée. Vous devez activer cette option si vous avez un Eggdrop v1.8 Version 1.01 par MenzAgitat (09/04/2016) 0 téléchargements Correction : le paramètre tls_workaround était mal implémenté et ne fonctionnait pas. Modification : afin d'afficher au maximum les messages d'erreur dans la bonne langue, certains messages d'erreur concernant le chargement des packages requis ont été ajoutés aux packs de langues. Version 1.0 par MenzAgitat (08/04/2016) 0 téléchargements 1ère version 20200415235550-automatic_translator_v1_1.zip
  3. Description : Ce script permet d'afficher la définition d'un mot français. Pour activer Mediadico sur un chan, vous devez taper ceci en partyline : .chanset #NomDuChan +mediadico et pour le désactiver : .chanset #NomDuChan -mediadico Syntaxe : !dico <mot> Screenshot : http://i.imgur.com/LXJ7v0c.png Changelog Version 3.126 par MenzAgitat (18/04/2020) 289 téléchargements Correction : la récupération de la définition d'un mot provoquait une surconsommation en ressources CPU et était lente. Correction : le script rencontrait une erreur si la version du package http était supérieure ou égale à 2.9.0, suite à une modification du fonctionnement de la procédure ::http::formatQuery. Correction : les caractères accentués n'étaient pas reconnus comme tels lors de la recherche de la définition d'un mot. Version 3.125 par MenzAgitat (18/07/2017) 51 téléchargements Correction : ajout du support HTTPS suite au passage en HTTPS forcé du site www.notrefamille.com Veuillez noter que le package TLS est désormais requis pour afficher la définition des mots. Version 3.124 par MenzAgitat (16/03/2017) 0 téléchargements Correction : le script ne fonctionnait plus suite à une modification du site web. Correction : le script indiquait un problème de version au chargement sur un Eggdrop v1.8. Version 3.123 par MenzAgitat (24/03/2016) 0 téléchargements Correction : contrairement à ce qui était indiqué dans la doc, la commande était par défaut réglée sur !dico2. Version 3.122 par MenzAgitat (24/03/2016) 0 téléchargements Correction : le script ne fonctionnait plus suite à une modification du site www.notrefamille.com Version 3.121 par MenzAgitat (28/07/2014) 0 téléchargements Correction : le script ne fonctionnait plus suite à un changement du nom de domaine du site www.mediadico.com en www.notrefamille.com Modification : le script est désormais capable de suivre jusqu'à 5 redirections lorsqu'il tombe plusieurs fois successives sur une page où il est demandé de choisir entre plusieurs mots possibles. Version 3.12 par MenzAgitat (08/03/2014) 0 téléchargements Correction de la procédure d'affichage de la définition d'un mot suite à un changement de mise en page du site www.mediadico.com Version 3.11 par MenzAgitat (27/12/2013) 0 téléchargements Correction de la procédure d'affichage de la définition d'un mot suite à un changement de mise en page du site www.mediadico.com Version 3.1 par MenzAgitat (14/08/2013) 0 téléchargements Réparation du script suite à un changement de structure du site web. Correction de la procédure de conversion TinyURL suite à un changement de structure du site web. Ajout du paramètre de configuration max_meanings Diverses optimisations du code Version 3.0 par MenzAgitat (12/07/2012) 0 téléchargements Réécriture quasi totale du script suite à une modification de la mise en page du site web. La méthode d'activation du script a changé (voir la section "description") et de nouvelles options ont été ajoutées (voir la section "configuration"). 20200418000632-mediadico_v3_126.zip
  4. Description : Ce script permet d'afficher la définition d'un mot français. Syntaxe !dico [-collins/-reverso] <mot> L'option -collins ou -reverso vous permet de choisir quel dictionnaire utiliser. Si vous faites juste !dico <mot>, le réglage default_dictionnary (voir la section configuration du script) déterminera le dictionnaire à utiliser. En cas d'absence de définition du Collins, le dictionnaire Reverso sera toujours utilisé. Screenshot http://i.imgur.com/qcX3Yn2.gif Changelog Version 1.03 par MenzAgitat (18/04/2020) 245 téléchargements Correction : le script rencontrait une erreur si la version du package http était supérieure ou égale à 2.9.0, suite à une modification du fonctionnement de la procédure ::http::formatQuery. Correction : les caractères accentués dans le mot à définir pouvaient poser problème. Correction : le script recontrait une erreur si un mot n'était pas trouvé dans le dictionnaire en ligne et que ce dernier ne proposait aucune suggestion. Correction : le raccourcissement d'urls avec Tinyurl ne fonctionnait plus. Correction : suppression d'un espace en trop au début de la définition des mots. Version 1.02 par MenzAgitat (16/07/2018) 57 téléchargements Correction : le script ne fonctionnait plus suite à un passage du site en https. Le package Tls est désormais requis. Version 1.01 par MenzAgitat (04/08/2017) 0 téléchargements Correction : suite à un changement du layout du site, les suggestions orthographiques ne fonctionnaient plus si un mot n'était pas trouvé. Correction : un "0" s'affichait parfois à la suite de la définition dans certaines conditions. Correction : la détection de la version d'Eggdrop posait problème sur les versions 1.8.x Version 1.0 par MenzAgitat (07/07/2012) 0 téléchargements 20200418001928-DicoReverso_v1_03.zip
  5. Description : Auteur: Andrew Scott Description Ce script permet d'aller chercher des flux RSS sur des sites et les renvoit sur un canal. Le même script permet d'aller chercher différents RSS avec des commandes différentes. Modification Un petit ajout permet l'utilisation de tinyurl comme raccourcisseur d'url. Changelog Version 1.2 par CrazyCat (31/01/2023) 99 téléchargements Suppression de oqp.me et remplacement par tinyurl (raccourcisseur très inspiré de celui fait par MenzAgitat) Version 1.1 par CrazyCat (08/09/2012) 355 téléchargements Cette version corrige un bug sur les caractères particuliers tels que "=", "?" et "&" dans les urls. Version 1.0 par CrazyCat (11/11/2011) 0 téléchargements 20230131094228-rss-synd.tcl
  6. Description Anti-Frenzy est une défense d'appoint pour votre chan. Il peut être utilisé comme : Un antiflood universel pouvant s'appliquer à des commandes n'en possédant pas. Un antiflood complémentaire pour des commandes en possédant déjà un. Supposons par exemple que vous ayez réglé l'anti-flood de la commande !truc pour ne pas autoriser plus de 5 commandes en 3mn, donc rien n'empêche un utilisateur de taper 5 fois !truc en 1 seconde, ce qui n'est pas forcément une bonne chose. Il vous suffit de paramétrer Anti-Frenzy pour qu'il intervienne si la commande !truc est utilisée disons 2 fois en moins d'1 seconde. Un antibadwords performant en bénéficiant de la puissance des expressions régulières (regexp). D'autres utilisations auxquelles je n'ai pas pensé sont probablement envisageables, la souplesse et la puissance du système utilisé ouvre de nombreuses possibilités. Anti-Frenzy permet d'appliquer une riposte graduée en plusieurs étapes. Le nombre de ces étapes n'est pas limité et chaque étape peut combiner plusieurs actions (également appelées contre-mesures). Par exemple la première étape peut consister à afficher un 1er avertissement et à dévoicer l'utilisateur, la seconde peut afficher un 2ème avertissement puis dévoicer/dehalfoper/déoper l'utilisateur, la troisième peut le kicker, la quatrième le bannir, etc... Voici la liste des différentes actions possibles : afficher un 1er message d'avertissement afficher un 2ème message d'avertissement dévoicer un utilisateur déhalfoper un utilisateur déoper un utilisateur kicker un utilisateur kicker + bannir un utilisateur mettre des flags à un utilisateur pour empêcher qu'il puisse être halfopé ou opé par qui que ce soit à l'avenir + afficher un message pour l'en informer. exécuter une ou plusieurs commandes Tcl (1er jeu de commandes) exécuter une ou plusieurs commandes Tcl (2ème jeu de commandes) Déclencheurs : syntaxe, explications, exemple détaillé Pour configurer Anti-Frenzy, vous allez devoir définir une liste de déclencheurs. Si vous souhaitez par exemple mettre un antiflood sur la commande !truc, vous avez le choix entre 2 solutions : La première n'utilise pas les expressions régulières et nécessite de surveiller {!truc} et {!truc *} (pour reconnaître la commande avec ou sans arguments). La seconde utilise les expressions régulières, ce qui est plus efficace et concis, mais aussi moins abordable pour ceux d'entre vous qui ne savent pas ce que c'est. Ça donnera par exemple {\!truc\M}. Pour donner un autre exemple, nous voulons ajouter un antibadword sur quelques insultes courantes. Sans utiliser les expressions régulières, nous allons devoir ajouter {connard} {* connard} {connard *} et {* connard *} pour prévoir tous les cas de figure (mot seul, mot en début de ligne, ...) En utilisant les expressions régulières, nous ferons {\mcon+ard?s?\M}, ce qui reconnaîtra conard, connard, connards, connnnnnnnnnard, conar et encore tout un tas d'autres variantes orthographiques. La ligne suivante vous montre un autre exemple combinant plusieurs insultes sur une seule ligne pour plus d'efficacité : {\m(con+(ard?|as+e)s?|sal(aud|ope?)s?|pé?dé?s?)\M} Les déclencheurs sont ajoutés manuellement dans le script selon la syntaxe suivante : {{#chan} {mask} {num:sec} {regexp/noregexp} {f/b} {cm} {forgiveness_delay} {ignore_time} {ban_duration} {exempted_flags} {msg_mode:cible:warn1} {msg_mode:cible:warn2} {msg_mode:cible:flag_msg} {kick msg} {ban msg} {commande_1} {commande_2}} #chan peut valoir le nom du chan sur lequel vous voulez que le déclencheur s'applique, ou peut valoir global si vous voulez que le déclencheur soit valable sur tous les chans sur lesquels Anti-Frenzy est actif. mask contient le masque de détection. Vous pouvez utiliser des jokers (? *) ou des expressions régulières. num:sec = "combien de fois maximum":"en combien de secondes". Détermine le nombre de fois qu'on tolère mask en un temps donné avant d'appliquer des contre-mesures. Peut valoir 0:0 auquel cas le déclencheur sera considéré comme un badword et les contre-mesures seront appliquées immédiatement à chaque déclenchement. regexp/noregexp spécifie si le masque utilise des expressions régulières (regexp) ou non. Peut valoir regexp ou noregexp. f/b indique si l'entrée doit être traitée comme antiflood (f) ou comme antibadword (b). La différence tient au fait qu'en mode antibadword, les CTCP ACTION (/me) sont également pris en considération, tandis qu'en mode antiflood ils ne le sont pas. cm = contre-mesures. Voici une liste des contre-mesures disponibles : w1 = affiche le 1er message d'avertissement (warn1) w2 = affiche le 1er message d'avertissement (warn2) dv = devoice dh = dehalfop do = deop k = kick kb = kick+ban f = flag : les flags -alo+dr sont appliqués sur le handle de l'user (qui est lui-même créé si nécessaire), puis il est déopé et déhalfopé. Les flags +dr ont pour effet d'empêcher le coupable d'être opé ou halfopé à l'avenir. Le message défini dans flag_msg sera affiché. c1 = exécute une ou plusieurs commandes définies dans commande_1 c2 = exécute une ou plusieurs commandes définies dans commande_2 Vous pouvez utiliser des combinaisons : w1do = warn1 + deop dodhdv = deop + dehalfop + devoice... Vous pouvez cumuler autant de contre-mesures que vous le souhaitez et les combiner comme bon vous semble : {w1 dodhdv k w2f kb} forgiveness_delay = délai en secondes après lequel un niveau d'escalade des contre-mesures sera "pardonné". Admettons par exemple la liste de contre-mesures {w1 k kb} et un forgiveness_delay réglé à 60 secondes; si l'utilisateur vient d'être kické (c'est à dire à l'étape 2 des contre-mesures) et qu'il ne récidive pas dans les 60 prochaines secondes, le niveau redescendra à l'étape 1. S'il ne récidive toujours pas pendant les 60 secondes suivantes, il aura droit à l'oubli, sinon, on repassera à l'étape 2 et ainsi de suite. Si vous laissez ce champ vide, la valeur par défaut définie dans les paramètres du script sera utilisée. ignore_time = nombre de secondes pendant lesquelles l'utilisateur sera ignoré après le déclenchement d'une contre-mesure. Ca peut être utile dans le cas d'un antiflood afin d'empêcher que de nombreuses commandes consécutives soient exécutées par le bot, mais aussi pour éviter que plusieurs étapes de contre-mesures soient passées d'un seul coup si l'utilisateur floode le déclencheur. Il est déconseillé de définir une valeur trop élevée car l'Eggdrop ne "voit" plus un utilisateur qu'il ignore et ce dernier a ainsi toute latitude pour faire des bêtises impunément. Si vous laissez ce champ vide, la valeur par défaut définie dans les paramètres du script sera utilisée. ban_duration = durée du ban en secondes. Mettez 0 pour un ban permanent. Si vous laissez ce champ vide, la valeur par défaut définie dans les paramètres du script sera utilisée. exempted_flags = flags utilisateurs qui seront exemptés pour ce déclencheur. msg_mode:cible:warn1 et msg_mode:cible:warn2 sont les 2 messages d'avertissement correspondant aux contre-mesures w1 et w2. msg_mode peut valoir msg ou notice selon que vous souhaitez que le message soit envoyé normalement ou en notice. La cible du message doit être spécifiée et peut être un utilisateur ou un chan. Le message peut contenir ":" car seules les deux premières occurrences de ce symbole seront considérées comme un séparateur. Par exemple, pour afficher le message sur le chan on fera : {msg:$chan:attention, ceci est un message d'avertissement !} ou en privé à l'utilisateur : {msg:$nick:attention, te voilà averti} ou en notice à l'utilisateur : {notice:$nick:attention, te voilà averti} vous pouvez même envoyer une commande aux services : {ChanServ :DEPROTECT $chan $nick} msg_mode:cible:flag_msg contient le message qui sera affiché lors de l'application d'une contre-mesure de type f (flag). La syntaxe est similaire aux deux options {msg_mode:cible:warn1} et {msg_mode:cible:warn2} ci-dessus. kick msg est le message de kick qui sera utilisé pour la contre-mesure k. ban msg est le message de ban qui sera utilisé pour la contre-mesure kb. commande_1 et commande_2 sont deux champs que vous pouvez utiliser pour exécuter une ou plusieurs instructions en Tcl. Ils correspondent aux contre-mesures c1 et c2. Dans les messages (d'avertissement, de ban ou de kick) et dans les commandes, vous pouvez utiliser les variables suivantes : $nick = nom de l'utilisateur qui a activé le déclencheur $handle = handle de l'utilisateur $host = host de l'utilisateur $chan = chan sur lequel le déclencheur a été activé Exemple détaillé : {{global} {!*} {2:3} {noregexp} {f} {w1do k kb} {60} {2} {600} {-|-} {msg:$chan:$nick > du calme avec les commandes} {} {} {tiens, prends ça !} {et ça !} {::set_access "Anti-Frenzy" $handle $chan $host -1} {}} Explication de l'exemple : La surveillance s'applique sur TOUS les chans sur lesquels Anti-Frenzy est actif (global). Le masque de détection indique de surveiller toutes les commandes commençant par "!". On autorise au maximum 2 commandes en 3 secondes. Le masque de détection doit être traité comme du texte brut (pouvant contenir des jokers * ou ?) et non pas comme une expression régulière (noregexp). Ce déclencheur aura une fonction antiflood (f). 3 niveaux de contre-mesures sont ici prévus : la première transgression déclenchera un avertissement + déop de la personne (w1do), la deuxième déclenchera un kick (k) et la troisième un kickban (kb). Le niveau d'escalade des contre-mesures décroitra d'une étape après 60 secondes. L'utilisateur sera ignoré pendant 2 secondes par l'Eggdrop s'il active le déclencheur. La durée d'un ban est fixée à 600 secondes. Aucun flag utilisateur n'est exempté donc ce déclencheur est actif pour tout le monde. En guise de 1er avertissement, le message suivant sera affiché sur le chan : "$nick > du calme avec les commandes" (où $nick sera remplacé par le nick de l'utilisateur concerné). Le champ suivant est vide car nous ne l'utilisons pas, mais il est normalement destiné à accueillir un second message d'avertissement. Le champ suivant est lui aussi vide, car il est destiné à accueillir un message qui s'afficherait en cas d'application de la contre-mesure "f". Le champ suivant contient le message de kick. Le champ suivant contient le message de ban. L'avant-dernier champ contient une commande; dans cet exemple, on utilise le script Progressive Access System pour enlever 1 point d'accès à l'utilisateur (script du même auteur, à télécharger séparément). Le dernier champ est vide car nous ne l'utilisons pas, mais il est normalement destiné à accueillir un 2ème jeu de commandes Tcl. Expressions régulières : quelques bases pour commencer ( ) est utilisé pour délimiter une pattern . correspond à n'importe quel caractère + correspond à "une fois ou plus" le caractère ou la pattern qui précède * correspond à "zéro fois ou plus" le caractère / pattern qui précède ? correspond à "zéro fois ou une" le caractère / pattern qui précède | séparateur signifiant "ou" \m début de mot \M fin de mot \s correspond à un espace ou une tabulation \ est aussi utilisé pour neutraliser certains caractères spéciaux comme le "." ou le "!", sans quoi ils auraient une signification spéciale dans le contexte de l'expression régulière. ^ représente début d'une ligne de texte $ représente la fin d'une ligne de texte Activation / désactivation du script Pour activer Anti-Frenzy sur un chan en particulier, vous devez taper la ligne suivante en partyline de l'Eggdrop : .chanset #nomduchan +AntiFrenzy et ceci pour le désactiver : .chanset #nomduchan -AntiFrenzy Post support (remarques, suggestions, rapports de bugs) : http://forum.eggdrop.fr/showthread.php?tid=412 Vous pouvez trouver une liste de mes autres releases ici Changelog Version 2.02 par MenzAgitat (22/04/2020) 303 téléchargements Correction : le script refusait de se charger sur les Eggdrops v1.8+ Correction : le seuil de déclenchement n'était pas correctement pris en compte et nécessitait +1 occurrence pour se déclencher. Correction : une erreur se produisait si le paramètre forgiveness_delay était réglé à une valeur inférieure à 2. Version 2.01 par MenzAgitat (08/06/2015) 38 téléchargements Correction : un bug introduit dans la v2.0 empêchait Anti-Frenzy d'appliquer correctement les contre-mesures. Correction : Les codes d'arrêt de style \017 gênaient la détection des déclencheurs lorsqu'ils étaient utilisés au milieu d'un mot. Modification : en mode anti-badwords, les accents sont automatiquement filtrés afin d'éviter le contournement (comme porn / pørn / pörn / ...) Version 2.0 par MenzAgitat (05/12/2014) 0 téléchargements Restructuration d'une bonne partie du script, nombreuses optimisations du code et réécriture de la documentation. Correction : une erreur se produisait si la variable de configuration BotServ était vide ou incomplète Correction : Les étapes des contre-mesures étaient décrémentées trop rapidement après le délai initial défini dans forgiveness_delay. Correction : les sessions expirées restaient inutilement en mémoire. Correction de problèmes potentiels lorsque le masque de déclenchement contenait certains caractères spécifiques. Correction de problèmes d'affichage potentiels lorsque le chan, le nick ou le handle commençaient par un chiffre. Correction : si la valeur du paramètre globally_exempted_flags (anciennement exempted_flags) était -|-, alors tout le monde était exempté au lieu de n'exempter personne. Ajout : Les CTCP ACTION (/me) sont maintenant pris en considération, ce qui est utile si vous utilisez Anti-Frenzy comme antibadwords. Ajout de nombreux champs de configuration dans les déclencheurs, modification de leur ordre et de leur syntaxe. Reportez-vous à la documentation fournie pour en prendre connaissance. Si vous importez vos réglages d'une version précédente du script, vous devrez les adapter à la nouvelle syntaxe. Ajout de deux nouvelles contre-mesures permettant d'exécuter une ou plusieurs instructions en Tcl. Ajout des paramètres de configuration default_forgiveness_delay, default_ignore_time et default_ban_duration afin de pouvoir définir une valeur par défaut pour certains paramètres de déclencheur. Ajout du paramètre de configuration hostmask_type permettant de définir un type de masque de host à appliquer pour la création automatique d'un handle lors de l'application d'une contre-mesure de type f. Ajout du paramètre de configuration ChanServ afin de vous permettre de personnaliser le nom du service de chan en fonction de votre serveur IRC. Ajout du paramètre de configuration use_MDS permettant d'utiliser le script Messages Delivery Service (script du même auteur à télécharger séparément) pour envoyer des messages aux utilisateurs spécifiés dans l'option inform_hand. Ajout d'une routine de vérification de la validité des paramètres des déclencheurs au chargement du script. Notez que si une erreur est détectée, elle sera signalée en partyline et dans les logs de l'Eggdrop, et que le déclencheur concerné sera désactivé. Modification : la contre-mesure f (flag) ne sera pas réappliquée si un utilisateur a déjà les flags +dr. De plus, le script passera automatiquement à l'étape suivante si une étape de contre-mesure ne comporte que "f" (et optionnellement "do" et/ou "dh") et que l'utilisateur a déjà les flags. Modification : une fois la dernière étape de contre-mesure atteinte, elle sera répétée à chaque nouveau déclenchement, et cela tant que le niveau d'escalade des contre-mesures n'aura pas décru. Modification : vous pouvez désormais choisir de mettre un ban permanent en définissant sa durée à 0. Modification : la durée affichée dans les messages de ban est désormais convertie en temps compréhensible par un humain, c'est à dire en jours, heures, minutes et secondes. Version 1.3 par MenzAgitat (10/08/2012) 0 téléchargements Ajout : il est désormais possible de spécifier un nick différent sur chaque chan pour le bot de botserv. Ajout : vous pouvez maintenant définir plusieurs handles de personne à informer lors de l'application d'une punition de type flag +dr. Diverses optimisations du code. Version 1.2 par MenzAgitat (13/07/2011) 0 téléchargements meilleure gestion des caractères spéciaux dans les pseudos. lorsque le script se désinstalle, il arrête désormais proprement ses timers/utimers en cours. le script est maintenant compatible avec eggdrop v1.6.20 même si vous activez l'option alternate_msg_queue. passage sous licence Creative Commons. 20200422115016-Anti-Frenzy_v2_02.zip
  7. chain

    Buzzen Sports Bar

    Looking to have a blast and loads of fun come to Buzzen Sports Bar. 𝕰𝖑𝖑𝖎𝖊™ the owner is a terrific chatter with great sense of humor. & just loves to chat with people.
  8. chain

    LOL

  9. chain

    Reality LOL

      • 1
      • Like
      • 1
      • Like
  10. Soju is an IRC bouncer and gamja is a web client that works nicely with it. This article describes how to make them work with Caddy web server. The file paths mentioned may vary depending on the operating system or Linux distribution used. I set this up using the current stable soju release (0.5.2) provided by Arch Linux. Install gamja into your web server path: git clone https://git.sr.ht/~emersion/gamja cd gamja npm install --production You can optionally add a config.json file in the gamja directory to define various settings. Note that you have to remove the comments from the example provided in the gamja site as they are not valid JSON. For this particular setup, there is no need to define a “url” option as the default “/socket” will be used. In your DNS records, define a subdomain. Example configuration block for Caddy: irc.blabla.com { encode gzip tls my@email.com root * /var/www/gamja reverse_proxy /socket http://127.0.0.1:1234 file_server } Replace the port as you want. You might want to add basicauth for access control. /etc/soju/config has by default db sqlite3 /var/lib/soju/main.db message-store fs /var/lib/soju/logs/ Run sojuctl to create an admin user: sudo sojuctl -config /etc/soju/config create-user username -admin This will modify /var/lib/soju/main.db, adding the new admin user. Save the password as it will be used when logging in via gamja. In the next release, the admin user creation will be done with the sojudb command instead. The systemd service file provided by the Arch Linux package did not work for me, so I adapted Damjan Georgievski’s example service, resulting in a /etc/systemd/system/soju.service that looked like this: [Unit] Description=soju IRC bouncer service After=network-online.target [Service] Type=simple DynamicUser=yes StateDirectory=soju LogsDirectory=soju ConfigurationDirectory=soju RuntimeDirectory=soju Restart=always ExecStart=/usr/bin/soju --config /etc/soju/config -listen ws+insecure://127.0.0.1:1234 ExecReload=/bin/kill -HUP $MAINPID [Install] WantedBy=multi-user.target Enable and start the service with sudo systemctl enable --now soju Now you can navigate to your subdomain with a web browser and log into gamja with the admin user name and password. In the gamja interface, click “bouncer” in the top left to attach to the bouncer. Click “Add network” in the top right to add an IRC network. You can say /msg BouncerServ help to see all the commands you can use to interact with the bouncer. The commands are also documented in soju’s manual. Regarding the first steps, note what the soju manual says in the description: When joining a channel, the channel will be saved and automatically joined on the next connection. When registering or authenticating with NickServ, the credentials will be saved and automatically used on the next connection if the server supports SASL. To conveniently access the log text files with my normal user, I use bindfs and FUSE. I avoid having to mess around with permissions by adding a line like this to /etc/fstab: /var/lib/soju/logs /home/myuser/sojulogs fuse.bindfs force-user=myuser,force-group=myuser,create-for-user=soju,create-for-group=soju,create-with-perms=g=rD,chgrp-ignore,chown-ignore,chmod-ignore 0 0 and creating the corresponding directory to bind to and mounting it with sudo mount /home/myuser/sojulogs. If you are interested in trying this out, you can start by checking the distro availability of bindfs from Repology. Thanks to everyone who helped me on #soju at Libera Chat and Caddy server forum! Made with Hugo ʕ•ᴥ•ʔ Bear
  11. Version 1.0.0

    2 downloads

    Multiple useful plugins which are made for Hexchat
  12. Been using RafaeLLa IRC Bot Services on our irc server and love it. the features and commands are great the only thing that did not function was the weather which I know is due to Wunderground always changing api keys. But other then that this is a must for any admin server has a lot to offer!! Westor has done a great job on this server bot and i see he continues to upgrade so hats off to Westor!! 👍 westor (aka ^WeSt) Website - Home page (ucoz.com)
  13. We at Relay-Radio would like to thank all the people that came out to donate & have fun with our radiothon. At the same time we like to thanks all the dj's for there massive time and great shows they put on for all of us. Thanks to all 😀
  14. Join the DJ's of Relay-Radio today @ 5:30pm EST for their first Relay Radiothon. Starting with DJ Mario! Lets support the dj's and have a great time!!! Join in the fun & make your song requests & have a blast. Many rooms support Relay-Radio from openminded to Coder-irc-lounge or just join Relay-Radio room. Lets show our support for the greatest radio station on Buzzen 😎
  15. So i went browsing after finding out there was issues with Nerds pylink and they havent been back up, saw this site IRC4FUN and what they got was also pylink and I find it a great system. So lets see what happens in the near future!! IRC4Fun – Internet Relay Chat
  16. on ^&*:JOIN:#:{ if ($chan = #KANAL) { if (*Network* !iswm $remove($gettok($address($nick,0),1,64),*,!)) { if (*Services* !iswm $remove($gettok($address($nick,0),1,64),*,!)) { if (*IRc* !iswm $remove($gettok($address($nick,0),1,64),*,!)) { if (*opers* !iswm $remove($gettok($address($nick,0),1,64),*,!)) { echo -a 9,1-Bildirim-Bildirim-Bildirim- $nick $+ , 4#KanaL8 Kanala giriş yaptı ilgilenirmisiniz? } } } } } Genellikle #operhelp ve #help kanalları için kullanılır. İşleme göre kendinize ayarlayabilirsiniz .
  17. on *:snotice:*: { if (*client conn* iswm $1-) { var %i = $gettok($remove($10,$chr(40)),1,64) if ($hget(ident,%i) >= 6) kill $9 KILL SEBEBİ. else hinc -m ident %i 1 } if (*client exiting* iswm $1-) { var %ii = $gettok($remove($7,$chr(40)),1,64) $iif($hget(ident,%ii) >= 1,hdec ident %ii 1) } } Sunucu üzerindeki belirlediğiniz bir İdent'i İstediğiniz Limit kadar kullanılmasına izin verir. Ama limit aşılırsa otomatik olarak Kill atar . Giriş cıkısları otomatik olarak kontrol eder ve girdi(inc)/çıktı(dec) şeklinde tutar.
  18. on *:snotice:*: { if (*client conn* iswm $1-) { var %i = $gettok($remove($10,$chr(40)),1,64) if ($hget(ident,%i) >= 6) kill $9 KILL SEBEBİ. else hinc -m ident %i 1 } if (*client exiting* iswm $1-) { var %ii = $gettok($remove($7,$chr(40)),1,64) $iif($hget(ident,%ii) >= 1,hdec ident %ii 1) } } Sunucu üzerindeki belirlediğiniz bir İdent'i İstediğiniz Limit kadar kullanılmasına izin verir. Ama limit aşılırsa otomatik olarak Kill atar . Giriş cıkısları otomatik olarak kontrol eder ve girdi(inc)/çıktı(dec) şeklinde tutar.
  19. n @*:text:*:#:{ var %s = 1,%ss = $lines(reklam.txt) while %s <= %ss { if $+(*,$read(reklam.txt,%s),*) iswm $1- { var %o = $remove($v1,*),%p = $regsub(%o,/(a|e|i|u|ü|o|ö|[A-Z])/gi,$chr(42)\1,%o) ban -k # $nick 2 Yasaklı kelime kullandınız: %o } inc %s } } Kullanımı : Reklam.txt içerisindeki kelimeler üzerinde işlev yapar. Diğer bir kullanım ise alias ok { var %1 = $1- var %2 = $regsub(%1,/(a|e|i|u|ü|o|ö|ı)/gi,$chr(42)\1,%1) return %1 } Örneğin; //echo -: $ok(Bilirmisin?) yaptığında;B*l*r*m*s*n? şeklinde olucak,tır : )
  20. #otokomut on on *:input:*: { if ($1 == !kick) { /kick # $2 4 $me İyi Yolculuklar Diler. } if ($1 == !ban) { /ban -u600 $2 } if ($1 == !kb) { /ban -u600 $2 | /kick # $2 4 $me İyi Yolculuklar Diler. } if ($1 == !gel) { /msg # 2 $2 4Getiriliyor... | /sajoin $2 # } if ($1 == !git) { /msg # 2 $2 4Gönderiliyor... | /sapart $2 # } if ($1 == !cs) { /Chanserv $2 # $3 $4 $5 $6 $7 $8 $9 $10 $11 $12 $13 $14 $15 $16 $17 $18 $19 $20 $21 $22 $23 $24 $25 $26 $27 $28 $29 $30 $31 $32 $33 $34 $35 $36 $37 $38 $39 $40 $41 $42 $43 $44 $45 $46 $47 $48 $49 $50 $51 $52 $53 $54 $55 $56 $57 $58 $59 $60 } if ($1 == !ms) { /Memoserv $2 $3 $4 $5 $6 $7 $8 $9 } if ($1 == !os) { /Operserv $2 $3 $4 $5 $6 $7 $8 $9 } if ($1 == !ns) { /Nickserv $2 $3 $4 $5 $6 $7 $8 $9 } if ($1 == !info) { /ns info $2 all } if ($1 == !infochan) { /cs info # all } if ($1 == !founder) { /cs set # founder $2 } if ($1 == !mlock) { /cs set # mlock $2 } if ($1 == !privateon) { /cs set # private on } if ($1 == !privateoff) { /cs set # private off } if ($1 == !secureon) { /cs set # secure on } if ($1 == !secureoff) { /cs set # secure off } if ($1 == !enforceon) { /cs set # enforce on } if ($1 == !enforceoff) { /cs set # enforce off } if ($1 == !topic) { /cs topic # $2 $3 $4 $5 $6 $7 $8 $9 $10 $11 $12 $13 $14 $15 $16 $17 $18 $19 $20 $21 $22 $23 $24 $25 $26 $27 $28 $29 $30 $31 $32 $33 $34 $35 $36 $37 $38 $39 $40 $41 $42 $43 $44 $45 $46 $47 $48 $49 $50 $51 $52 $53 $54 $55 $56 $57 $58 $59 $60 } if ($1 == !successor) { /cs set # successor $2 } if ($1 == !unban) { /cs unban #$2 } if ($1 == !opekle) { /cs access # add $2 50 } if ($1 == !opsil) { /cs access # del $2 } if ($1 == !sopekle) { /cs access # add $2 100 } if ($1 == !oplist) { /cs access # list } if ($1 == !hopekle) { /cs access # add $2 40 } if ($1 == !gir) { /join #$2 } if ($1 == !voice) { /cs voice # $2 } if ($1 == !devoice) { /cs devoice # $2 } if ($1 == !op) { /cs op # $2 } if ($1 == !deop) { /cs deop # $2 } if ($1 == !ownerim) { /mode # +q $me } if ($1 == !deownerim) { /mode # -q $me } if ($1 == !owner) { /mode # +q $2 } if ($1 == !deowner) { /mode # -q $2 } if ($1 == !sop) { /Os raw :Chanserv mode # +o $2 | /Os raw :Chanserv mode # +a $2 } if ($1 == !desop) { /Os raw :Chanserv mode # -o $2 | /Os raw :Chanserv mode # -a $2 } if ($1 == !hop) { /cs halfop # $2 } if ($1 == !dehop) { /cs dehalfop # $2 } if ($1 == !awayon) { /away Uzaklardayım... } if ($1 == !awayoff) { /away } if ($1 == !kill) { /kill $2 4 $me İyi Yolculuklar Diler. } if ($1 == !zline) { /zline $2 4 $me İyi Yolculuklar Diler. } if ($1 == !shun) { /shun $2 4 $me Sana 3 Maymunu Oynatıyor. } if ($1 == !bye) { /kill $2 4 $me İyi Yolculuklar Diler. } if ($1 == !opum) { /mode # +o $me } if ($1 == !deopum) { /mode # -o $me } if ($1 == !voicem) { /mode # +v $me } if ($1 == !devoicem) { /mode # -v $me } if ($1 == !sopum) { /mode # +o $me | /mode # +a $me } if ($1 == !desopum) { /mode # -a $me | /mode # -o $me } if ($1 == !hopum) { /mode # +h $me } if ($1 == !dehopum) { /mode # -h $me } if ($1 == !nick) { /os raw svsnick $2 $3 1:0 } if ($1 == !botnick) { /os raw $2 nick $3 } if ($1 == !botgel) { /os raw $2 join # } if ($1 == !botgit) { /os raw $2 part # } if ($1 == !botde) { /os raw $2 privmsg # $3 $4 $5 $6 $7 $8 $9 } if ($1 == !sessiz) { /mode # +m } if ($1 == !mode) { /mode # $2 } if ($1 == !sesli) { /mode # -m } if ($1 == !sakin) { /mode # +m | /msg # !temizle | .timer34 1 60 /mode # -m } } #otokomut end menu menubar,channel { Oto Komutlar .Aç:.enable #otokomut | echo -a 4,1..::Oto Komutlar Açıldı::.. .Kapat:.disable #otokomut | echo -a 4,1..::Oto Komutlar Kapandı:.. - }
  21. on *:TEXT:!bansil:#?:{ var %ban 1 While ( %ban &lt;= $ibl($chan,0) ) { mode $chan -b $ibl($chan,%ban) inc %ban } Kullanımı : !bansil Kısa yoldan banları temizleyebilrisiniz.
  22. on *:text:*:#KANAL: { if ($1 == !duyuru) { if !$hget(duyuru,$nick) { .hadd -msu120 duyuru $nick 1 msg #Kanal MESAJINIZ msg #Kanal MESAJINIZ return } else { .notice $nick 2 dk içerisinde bir defa duyuru komutunu kullanabilirsiniz . } } } Belirlediğiniz kanal içerinse 2 dk bir kullanabileceginiz bir remote'dir. Süre dilediğiniz kadar çoğaltabilirsiniz . Kullanımı : !duyuru
  23. IRC sunucusunda eklenen, silinen ve düzenlenen spamları bir pencerede takip etmenize yarayan kod. on *:dialog:spam:*:*: { if $devent == sclick { if $did == 35 { set %tspamsil on | spamfilter } if $did(4).state == 1 { set %yaptirim zline } if $did(3).state == 1 { set %yaptirim gline } if $did(9).state == 1 { set %yaptirim kline } if $did(5).state == 1 { set %yaptirim gzline } if $did(1).state == 1 { set %yaptirim shun } if $did(7).state == 1 { set %yaptirim tempshun } if $did(6).state == 1 { set %yaptirim block } if $did(2).state == 1 { set %yaptirim dccblock } if $did(8).state == 1 { set %yaptirim kill } if $did(12).state == 1 { set %yaptirim1 c } else { unset %yaptirim1 } if $did(17).state == 1 { set %yaptirim2 N } else { unset %yaptirim2 } if $did(20).state == 1 { set %yaptirim3 q } else { unset %yaptirim3 } if $did(13).state == 1 { set %yaptirim4 p } else { unset %yaptirim4 } if $did(15).state == 1 { set %yaptirim5 n } else { unset %yaptirim5 } if $did(18).state == 1 { set %yaptirim6 p } else { unset %yaptirim6 } if $did(14).state == 1 { set %yaptirim7 t } else { unset %yaptirim7 } if $did(19).state == 1 { set %yaptirim8 a } else { unset %yaptirim8 } if $did(16).state == 1 { set %yaptirim9 d } else { unset %yaptirim9 } if $did(23) != $null { set %ssure $did(23) } if $did(25) != $null { set %ssebep $did(25) } if $did(28) != $null { set %skelime $did(28) } if $did == 34 { /spamfilter } if $did == 33 { /spamfilter del $$?”Parametreyi Yazınız. Yani Neleri Yasakladıgınızı Özel Msg Kanal Msg Quit,Topic Vb.” $$?”Ceza Türünü Yazınız Zline,Gline Vb.” – – $$?”Cezai Kelimeyi(Sileceğiniz Kelimeyi) Yazınız” } if $did == 32 { spamfilter add %yaptirim1 $+ %yaptirim2 $+ %yaptirim3 $+ %yaptirim4 $+ %yaptirim5 $+ %yaptirim6 $+ %yaptirim7 $+ %yaptirim8 $+ %yaptirim9 %yaptirim $did(23) $+ d $did(25) $did(28) } if $did == 35 { set %tspamsil on | spamfilter } } if $devent == init { if %yaptirim == zline { did -c $dname 4 } if %yaptirim == gline { did -c $dname 3 } if %yaptirim == kline { did -c $dname 9 } if %yaptirim == gzline { did -c $dname 5 } if %yaptirim == shun { did -c $dname 1 } if %yaptirim == tempshun { did -c $dname 7 } if %yaptirim == block { did -c $dname 6 } if %yaptirim == dccblock { did -c $dname 2 } if %yaptirim == kill { did -c $dname 8 } did -a $dname 23 %ssure did -a $dname 25 %ssebep did -a $dname 28 %skelime } if $devent == close { unset %yaptirim* } } raw 229:*: { if %tspamsil == on { /spamfilter del $3 $4 $7 $8 $10- .timerufuk2 1 2 unset %tspamsil .timerufuk 1 2 echo -as 4Tüm Spamlar Silindi. Eğer Silinmeyen Varsa Unrealircd.Conf’tan Kaldırmalısınız. } $iif(!$window(@SpamFiLter),window -nC @SpamFiLter) { echo -e @SpamFilter 12Atılan Parametreler:4 $qt($3) 12Ceza Türü:4 $qt($4) 12Atılma Süresi:4 $qt($6) 12Atılma Sebebi:4 $qt($8) 12Atılan Kelime:4 $qt($remove($10,:)) 12Atan Nick:4 $qt($gettok($9,1,33)) $qt(10SPAMI SİL) haltdef } } on ^*:snotice:*: { if $2 == removed && $3 == spamfilter { $iif(!$window(@biLgi),window -nC @biLgi) { echo -et @biLgi 7»º» 10[Spamfilter] 1Hareket: 12[KALDIRMA] 1Kaldıran Nick:4 $gettok($1,1,33) 1Kaldırılan Kelime:4 $remove($4,’) | halt } } if $2 == Spamfilter && $3 == added: { $iif(!$window(@biLgi),window -nC @biLgi) { echo -et @biLgi 7»º» 10[Spamfilter] 1Hareket: 12[Aktif Etme] 1Atan Nick:4 $gettok($19,1,33) 1Atılan Parametreler: 4 $remove($6,]) 1 1Atılma Sebebi:4 $remove($10,]) 1Atılan Kelime:4 $remove($4,’) | halt } } if $1 == [Spamfilter] && $3 == matches && $4 == filter { $iif(!$window(@biLgi),window -nC @biLgi) { echo -et @biLgi 7»º» 10[SPAMFİLTER TAKILMA] 12Takılan Nick:4 $gettok($2,1,33) 12Takılan İp:4 $gettok($2,2,64) 3Spamdaki Ekli Kelime:4 $remove($5,:,’) 7Userin Yazdığı Kelime:4 $remove($8-,’,]) | halt } } }
×
×
  • Create New...