Sha256: 80d80c984b88c4f177ebf48ab0b9b8f0beefc1250c969cb8fa87ed9d72e68553

Contents?: true

Size: 1.69 KB

Versions: 2

Compression:

Stored size: 1.69 KB

Contents

---
layout: page
title: "Advanced Features"
category: doc
---

Direct Client Access
--------------------

If you want to do something not provided directly by Chatterbot, you
have access to an instance of Twitter::Client provided by the
**client** method. In theory, you can do something like this in your
bot to unfollow users who DM you:

    client.direct_messages_received(:since_id => since_id).each do |m|
        client.unfollow(m.user.name)
    end

Storing Config in the Database
------------------------------
Sometimes it is preferable to store the authorization credentials for
your bot in a database.

Chatterbot can manage configurations that are stored in the database,
but to do this you will need to specify how to connect to the
database. You can do this by specifying the connection string
either in one of the global config files by setting

```
:db_uri:mysql://username:password@host/database
```

Or you can specify the connection on the command-line by using the
--db="db_uri" configuration option. Any calls to the database are
handled by the Sequel gem, and MySQL and Sqlite should work. The DB
URI should be in the form of

    mysql://username:password@host/database

see http://sequel.rubyforge.org/rdoc/files/doc/opening_databases_rdoc.html
for details.


Logging Tweets to the Database
------------------------------

Chatterbot can log tweet activity to a database if desired. This can
be handy for archival purposes, or for tracking what's going on with
your bot.

If you've configured your bot for database access, you can store a
tweet to the database by calling the `log` method like this:

```
search "chatterbot" do |tweet|
    log tweet
end
```

See `Chatterbot::Logging` for details on this.


Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
chatterbot-2.2.0 docs/advanced.md
chatterbot-2.1.0 docs/advanced.md