| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616 |
- # $Id: QuoteEngine.tcl,v 1.20 2004/03/30 21:52:12 James Exp $
- ###############################################################################
- # QuoteEngine for eggdrop bots
- # Copyright (C) James Michael Seward 2003
- #
- # This program is covered by the GPL, please refer the to LICENCE file in the
- # distribution.
- ###############################################################################
- # load the extension
- package require mysqltcl
- # Make sure you edit the sample settings file and save it as "QuoteEngine-settings.tcl"
- # in the eggdrop scripts directory!
- source "scripts/QuoteEngine-settings.tcl"
- # bind commands CHANGE as needed to set who can use
- # use ".chanset #channel [+/-]quoteengine" to enable/disable individual
- # channels
- bind pub "m|fov" !addquote quote_add
- bind pub "m|fov" !randquote quote_rand
- bind pub "m|fov" !fetchquote quote_fetch
- bind pub "m|fov" !getquote quote_fetch
- bind pub "m|fov" !findquote quote_search
- bind pub "m|fov" !searchquote quote_search
- bind pub "m|fov" !urlquote quote_url
- bind pub "-|-" !quoteurl quote_url
- bind pub "m|ov" !delquote quote_delete
- bind pub "m|ov" !deletequote quote_delete
- bind pub "m|ov" !quotestats quote_stats
- bind pub "-|-" !quoteversion quote_version
- bind pub "-|-" !quotehelp quote_help
- bind pubm "-|ov" * quote_auto
- ################################################################################
- #No need to edit beyond this point
- ################################################################################
- set quote_version "1.3"
- set quote_auto_last(blah) 0
- #add setting to channel
- setudef flag quoteengine
- # connect to database
- proc quote_connect { } {
- global db_handle quote_db
-
- set db_handle [mysqlconnect -host $quote_db(host) -user $quote_db(user) -password $quote_db(password) -db $quote_db(database)]
- if {$db_handle != ""} {
- return 1
- } else {
- return 0
- }
- }
- ################################################################################
- # quote_ping
- # Check we're still connected to mysql
- ################################################################################
- proc quote_ping { } {
- global db_handle
- if [::mysql::ping $db_handle] {
- return 1
- } else {
- return [quote_connect]
- }
- }
- ################################################################################
- # quote_add
- # !addquote <text>
- # Adds a quote to the database
- ################################################################################
- proc quote_add { nick host handle channel text } {
- global db_handle quote_noflags
- if {![channel get $channel quoteengine]} {
- return 0
- }
- if [matchattr $handle $quote_noflags] { return 0 }
- if {($handle == "") || ($handle == "*")} {
- set handle $nick
- }
- if {![quote_ping]} {
- putquick "PRIVMSG $channel :Sorry, lost database connection :("
- return 0
- }
- set text [string trim $text]
- if {$text == ""} {
- putserv "PRIVMSG $nick :You forgot the quote text :("
- return 0
- }
- set sql "INSERT INTO quotes VALUES(null, "
- append sql "'$handle', "
- append sql "'$nick!$host', "
- set text [mysqlescape $text]
- append sql "'$text', "
- append sql "'$channel', "
- append sql "'[clock seconds]')"
- putloglev d * "QuoteEngine: executing $sql"
- set result [mysqlexec $db_handle $sql]
- if {$result != 1} {
- putlog "An error occurred with the sql :("
- } else {
- set id [mysqlinsertid $db_handle]
- puthelp "PRIVMSG $channel :Quote \002$id\002 added"
- if [regexp {[^]> ]\|[[<0-9(]} $text] {
- puthelp "PRIVMSG $nick :It's possible you didn't split the lines quite right on the quote you just added. For best results, split lines in quotes using '|' with a space each side. To delete the quote you just added and fix it, do '!delquote $id' in the channel."
- }
- }
- }
- ################################################################################
- # quote_rand
- # !randquote [--all|--channel #channel]
- # Gets a random quote from the database for the current channel
- # --all: Choose from entire database
- # --channel: Choose from given channel
- # -c: Shortcut for --channel
- ################################################################################
- proc quote_rand { nick host handle channel text } {
- global db_handle quote_noflags quote_shrinkspaces
- if {![channel get $channel quoteengine]} {
- return 0
- }
- if [matchattr $handle $quote_noflags] { return 0 }
- if {![quote_ping]} {
- putquick "PRIVMSG $channel :Sorry, lost database connection :("
- return 0
- }
- set where_clause "WHERE channel='$channel'"
- if [regexp -- "--?all" $text] {
- set where_clause ""
- }
- if [regexp -- "--?c(hannel)?( |=)(.+)" $text matches skip1 skip2 newchan] {
- set where_clause "WHERE channel='[mysqlescape $newchan]'"
- }
- set sql "SELECT * FROM quotes $where_clause ORDER BY RAND() LIMIT 1"
- putloglev d * "QuoteEngine: executing $sql"
- set result [mysqlquery $db_handle $sql]
- if {[set row [mysqlnext $result]] != ""} {
- set id [lindex $row 0]
- set quote [lindex $row 3]
- set by [lindex $row 1]
- set when [clock format [lindex $row 5] -format "%Y/%m/%d %H:%M"]
- catch {
- if {$quote_shrinkspaces == 1} {
- regsub -all " +" $quote " " quote
- }
- set quote [stripcodes bcruag $quote]
- }
- puthelp "PRIVMSG $channel :\[\002$id\002\] $quote"
- } else {
- puthelp "PRIVMSG $channel :Couldn't find a quote :("
- }
- mysqlendquery $result
- }
- ################################################################################
- # quote_fetch
- # !getquote <id>
- # Fetches the given quote from the database
- ################################################################################
- proc quote_fetch { nick host handle channel text } {
- global db_handle quote_noflags quote_shrinkspaces
- if {![channel get $channel quoteengine]} {
- return 0
- }
- if [matchattr $handle $quote_noflags] { return 0 }
- set verbose ""
- if {![regexp {(-v )?([0-9]+)} $text matches verbose quote_id]} {
- puthelp "PRIVMSG $channel: Use: !getquote \[-v\] <id>"
- return 0
- }
- if {![quote_ping]} {
- putquick "PRIVMSG $channel :Sorry, lost database connection :("
- return 0
- }
-
- set text [mysqlescape $quote_id]
- set sql "SELECT * FROM quotes WHERE id='$text'"
- putloglev d * "QuoteEngine: executing $sql"
- set result [mysqlquery $db_handle $sql]
- if {[set row [mysqlnext $result]] != ""} {
- set id [lindex $row 0]
- set quote [lindex $row 3]
- catch {
- if {$quote_shrinkspaces == 1} {
- regsub -all " +" $quote " " quote
- }
- set quote [stripcodes bcruag $quote]
- }
- set by [lindex $row 1]
- set when [clock format [lindex $row 5] -format "%Y/%m/%d %H:%M"]
- set chan [lindex $row 4]
- if {$chan != $channel} {
- puthelp "PRIVMSG $channel :\[\002$id\002\] $quote"
- if {$verbose != ""} {
- puthelp "PRIVMSG $channel :\[\002$id\002\] From $chan, by added $by at $when."
- }
- } else {
- puthelp "PRIVMSG $channel :\[\002$id\002\] $quote"
- if {$verbose != ""} {
- puthelp "PRIVMSG $channel :\[\002$id\002\] Added by $by at $when."
- }
- }
- } else {
- puthelp "PRIVMSG $channel :Couldn't find quote $text"
- }
- mysqlendquery $result
- }
- ################################################################################
- # quote_search
- # !findquote [--all] [--channel #channel] [--count <int>] <text>
- # Find all quotes with "text" in them. (in random order)
- # The first 5 (by default) are listed in the channel. The rest are /msg'd to
- # you up to the maximum (default 5).
- # --all: Search all channels, not just current one
- # --channel: Search given channel
- # --count <int>: Find this many total quotes
- # -c: Shortcut for --channel
- # -n: Shortcut for --count
- # Note this is a SQL search, so use % as the wildcard (instead of *)
- # The script automatically puts %s around your text when searching.
- ################################################################################
- proc quote_search { nick host handle channel text } {
- global db_handle quote_webpage quote_noflags quote_chanmax
- if {![channel get $channel quoteengine]} {
- return 0
- }
- if [matchattr $handle $quote_noflags] { return 0 }
- if {$text == ""} {
- puthelp "PRIVMSG $channel :Use: !findquote <text>"
- return 0
- }
- if {![quote_ping]} {
- putquick "PRIVMSG $channel :Sorry, lost database connection :("
- return 0
- }
- set where_clause "AND channel='[mysqlescape $channel]'"
- if [regexp -- "--?all " $text matches skip1] {
- set where_clause ""
- regsub -- $matches $text "" text
- }
- if [regexp -- {--?c(hannel)?( |=)([^ ]+)} $text matches skip1 skip2 newchan] {
- set where_clause "AND channel='[mysqlescape $newchan]'"
- regsub -- $matches $text "" text
- }
- set limit 5
- if [regexp -- {--?count( |=)([^ ]+)} $text matches skip1 count] {
- set limit [mysqlescape $count]
- regsub -- $matches $text "" text
- }
- if [regexp -- {-n( )?([^ ]+)} $text matches skip1 count] {
- set limit [mysqlescape $count]
- regsub -- $matches $text "" text
- }
- set sql "SELECT * FROM quotes WHERE quote LIKE '%[mysqlescape $text]%' $where_clause ORDER BY RAND()"
- putloglev d * "QuoteEngine: executing $sql"
- if {[mysqlsel $db_handle $sql] > 0} {
- set count 0
- mysqlmap $db_handle {id qnick qhost quote qchannel qts} {
- if {$count == $limit} {
- break
- }
- if {$count == $quote_chanmax} {
- puthelp "PRIVMSG $nick :Rest of matches for your search '$text' follow in private:"
- }
- if {$count < $quote_chanmax} {
- puthelp "PRIVMSG $channel :\[\002$id\002\] $quote"
- } else {
- puthelp "PRIVMSG $nick :\[\002$id\002\] $quote"
- }
- incr count
- }
- set remaining [mysqlresult $db_handle rows?]
- if {$remaining > 0} {
- if {$count < $quote_chanmax} {
- set command "PRIVMSG $channel :"
- } else {
- set command "PRIVMSG $nick :"
- }
- regsub "#" $channel "" chan
- if {$quote_webpage != ""} {
- puthelp "${command}(Plus $remaining more matches: $quote_webpage?filter=${text}&channel=${chan}&search=search)"
- } else {
- puthelp "${command}Plus $remaining other matches"
- }
- } else {
- if {$count < $quote_chanmax} {
- set command "PRIVMSG $channel :"
- } else {
- set command "PRIVMSG $nick :"
- }
- if {$count == 1} {
- puthelp "${command}(All of 1 match)"
- } else {
- puthelp "${command}(All of $count matches)"
- }
- }
- } else {
- puthelp "PRIVMSG $channel :No matches"
- }
- }
- ################################################################################
- # quote_url
- # !quoteurl
- # Gives the web of the web interface
- ################################################################################
- proc quote_url { nick host handle channel text } {
- global quote_webpage quote_noflags
- if {![channel get $channel quoteengine]} {
- return 0
- }
- if [matchattr $handle $quote_noflags] { return 0 }
- if {$quote_webpage != ""} {
- # changed for better url by dubkat
- puthelp "PRIVMSG $channel :${quote_webpage}?channel=[string range $channel 1 end]"
- } else {
- puthelp "PRIVMSG $channel :Not available."
- }
- }
- ################################################################################
- # quote_stats
- # !quotestats
- # Give some simple statistics about the db, channel, and user
- ################################################################################
- proc quote_stats { nick host handle channel text } {
- global db_handle quote_noflags
- if {![channel get $channel quoteengine]} {
- return 0
- }
- if [matchattr $handle $quote_noflags] { return 0 }
- if {![quote_ping]} {
- putquick "PRIVMSG $channel :Sorry, lost database connection :("
- return 0
- }
- set sql "SELECT COUNT(*) AS total FROM quotes WHERE channel='$channel'"
- putloglev d * "QuoteEngine: executing $sql"
- set result [mysqlquery $db_handle $sql]
- set total 0
- set chan 0
- if {[set row [mysqlnext $result]] != ""} {
- set total [lindex $row 0]
- }
- mysqlendquery $result
- set sql "SELECT COUNT(*) AS total FROM quotes"
- putloglev d * "QuoteEngine: executing $sql"
- set result [mysqlquery $db_handle $sql]
- if {[set row [mysqlnext $result]] != ""} {
- set chan [lindex $row 0]
- }
- mysqlendquery $result
- set sql "SELECT COUNT(*) AS total FROM quotes WHERE nick='$handle' AND channel='$channel'"
- putloglev d * "QuoteEngine: executing $sql"
- set result [mysqlquery $db_handle $sql]
- if {[set row [mysqlnext $result]] != ""} {
- set by_handle [lindex $row 0]
- }
- mysqlendquery $result
- puthelp "PRIVMSG $channel :Quotes for $channel: \002$total\002 (total: $chan). You have added \002$by_handle\002 quotes in this channel."
- }
- ################################################################################
- # quote_delete
- # !delquote <id>
- # Removes a quote from the database. You can only delete the quote if you
- # are a bot/channel master, or if you're the person who added it.
- ################################################################################
- proc quote_delete { nick host handle channel text } {
- global db_handle quote_noflags
- if {![channel get $channel quoteengine]} {
- return 0
- }
- if [matchattr $handle $quote_noflags] { return 0 }
- if {![quote_ping]} {
- putquick "PRIVMSG $channel :Sorry, lost database connection :("
- return 0
- }
- set text [mysqlescape $text]
- if {![matchattr $handle m|m $channel]} {
- set sql "SELECT nick FROM quotes WHERE id='$text'"
- putloglev d * "QuoteEngine: executing $sql"
- set result [mysqlquery $db_handle $sql]
- set owner [lindex [mysqlnext $result] 0]
- mysqlendquery $result
- if {$owner != $handle} {
- puthelp "NOTICE $nick :You cannot delete that quote."
- return 0
- }
- }
- set sql "DELETE FROM quotes WHERE id='$text'"
- putloglev d * "QuoteEngine: executing $sql"
- set result [mysqlexec $db_handle $sql]
- if {$result != 1} {
- puthelp "PRIVMSG $channel :An error occurred deleting the quote :("
- return 0
- } else {
- puthelp "PRIVMSG $channel :Deleted quote $text"
- }
- }
- ################################################################################
- # quote_version
- # !quoteversion
- # Gives the version of the script
- ################################################################################
- proc quote_version { nick host handle channel text } {
- global quote_version quote_noflags
- if [matchattr $handle $quote_noflags] { return 0 }
- puthelp "PRIVMSG $channel :This is the QuoteEngine version $quote_version by JamesOff (http://www.jamesoff.net/go/quoteengine)"
- return 0
- }
- ################################################################################
- # quote_help
- # !quotehelp
- # Handle help requests
- ################################################################################
- proc quote_help { nick host handle channel text } {
- global quote_noflags
- if [matchattr $handle $quote_noflags] { return 0 }
- puthelp "PRIVMSG $nick :Commands for the QuoteEngine script:"
- puthelp "PRIVMSG $nick : !addquote <quote text> - adds a quote to the database"
- puthelp "PRIVMSG $nick : !delquote <id> - deletes a quote. You must be either a bot/channel master or the person who added the quote to delete it."
- puthelp "PRIVMSG $nick : !randquote \[--all\] \[--channel=#channel\] \[-c #channel\] - fetches a random quote from the current channel. --all chooses from all channels, not just the one the command is executed from. --channel and -c choose only from the given channel."
- puthelp "PRIVMSG $nick : !getquote \[-v\]<id> - fetches the quote with number <id>. Gives info of who added it if -v is specified."
- puthelp "PRIVMSG $nick : !findquote \[--all\] \[--channel=#channel\] \[-c #channel\] \[--count <int>\] \[-n <int>\] <text> - finds up to <int> (default 5) quotes containing 'text'. Optional parameters same as !randquote. -n is a shortcut for --count."
- puthelp "PRIVMSG $nick : !quoteurl - get the URL for the web interface to the quotes"
- puthelp "PRIVMSG $nick : !quotestats - get some information"
- puthelp "PRIVMSG $nick : !quoteversion - get the version of the script"
- puthelp "PRIVMSG $nick : Some commands have synonyms: !deletequote, !fetchquote, !urlquote, and !searchquote."
- puthelp "PRIVMSG $nick : (End of help)"
- return 0
- }
- proc quote_auto { nick host handle channel text } {
- global quote_automatic quote_shrinkspaces
- if {$quote_automatic == 0} {
- return
- }
- if {![channel get $channel quoteengine]} {
- return
- }
- global quote_auto_last db_handle quote_automatic_minimum
- if [info exists quote_auto_last($channel)] {
- set diff [expr [clock seconds] - $quote_auto_last($channel)]
- putloglev 1 * "diff for $channel is $diff"
- } else {
- set diff [expr $quote_automatic_minimum + 1]
- putloglev d * "initialising diff for $channel"
- set quote_auto_last($channel) 0
- }
- if {$diff < $quote_automatic_minimum} {
- return
- }
- set words [split $text]
- set newwords [list]
- foreach word $words {
- if [regexp -nocase {^[a-z0-9']{4,}$} $word] {
- if {[lsearch [list "yeah" "about" "hello" "their" "there" "that's" "can't" "morning" "won't"] $word] > -1} {
- continue
- }
- if [onchan $word] {
- continue
- }
- lappend newwords [mysqlescape $word]
- }
- }
- if {[llength $newwords] == 0} {
- return
- }
- putloglev d * "quoteengine: candidate words for random quote in $channel: $newwords"
- if {![quote_ping]} {
- return
- }
- set thisword [pickRandom $newwords]
- putloglev d * "quoteengine: using $thisword"
- if {[rand 100] < 95} {
- putloglev d * "quoteengine: not random enough, ignoring"
- return
- }
-
- set where_clause "WHERE channel='[mysqlescape $channel]' AND quote LIKE '%$thisword%' ORDER BY RAND() LIMIT 1"
- putloglev d * "quoteengine: $where_clause"
- set sql "SELECT * FROM quotes $where_clause"
- set result [mysqlquery $db_handle $sql]
- if {[set row [mysqlnext $result]] != ""} {
- set id [lindex $row 0]
- set quote [lindex $row 3]
- catch {
- if {$quote_shrinkspaces == 1} {
- regsub -all " +" $quote " " quote
- }
- set quote [stripcodes bcruag $quote]
- }
- putloglev d * "RANDOM QUOTE: $quote ($id)"
- puthelp "PRIVMSG $channel :\[\002$id\002\] $quote"
- set quote_auto_last($channel) [clock seconds]
- }
- mysqlendquery $result
- }
- # Define the pickRandom method which is used if bMotion isn't loaded
- if {[llength [info procs pickRandom]] == 0} {
- proc pickRandom { list } {
- return [lindex $list [rand [llength $list]]]
- }
- }
- quote_connect
- putlog "QuoteEngine $quote_version loaded"
|