Renegade Public Forums
C&C: Renegade --> Dying since 2003™, resurrected in 2024!
Home » Tiberian Technologies / Blackhand Studios » Other Products » BRenBot Plugins
icon5.gif  BRenBot Plugins [message #458858] Wed, 02 November 2011 08:54 Go to next message
Creed3020 is currently offline  Creed3020
Messages: 1438
Registered: February 2003
Location: Toronto, Canada
Karma: 0
General (1 Star)
Quick question:

Are plugins which worked for BR 1.52 e.g. these, also compatible with BR 1.53?

I ask because I resurrected a old server I had installed and updated BR but BR is throwing a shit ton of errors related to plugins.

Thanks!

[Updated on: Wed, 02 November 2011 08:55]

Report message to a moderator

Re: BRenBot Plugins [message #458863 is a reply to message #458858] Wed, 02 November 2011 10:49 Go to previous messageGo to next message
danpaul88 is currently offline  danpaul88
Messages: 5795
Registered: June 2004
Location: England
Karma: 0
General (5 Stars)
Some may be compatible, some may not be. Let me know which ones you are having problems with, I might have updated copies for 1.53. If not I might be able to fix them.

http://steamsignature.com/card/1/76561197975867233.png
Re: BRenBot Plugins [message #458896 is a reply to message #458863] Thu, 03 November 2011 16:56 Go to previous messageGo to next message
Creed3020 is currently offline  Creed3020
Messages: 1438
Registered: February 2003
Location: Toronto, Canada
Karma: 0
General (1 Star)
danpaul88 wrote on Wed, 02 November 2011 13:49

Some may be compatible, some may not be. Let me know which ones you are having problems with, I might have updated copies for 1.53. If not I might be able to fix them.


Awesome. I will add them in one at a time to determine where the problem lies exactly. I am currently using 1.53 without TT 4.0 and the new SSGM.

One other question. BR 1.53 that came with TT 4.0 does not include all the files that a normal installation typically does. I assume that the provided files are to be used to overwrite old ones?

Re: BRenBot Plugins [message #458914 is a reply to message #458858] Fri, 04 November 2011 00:17 Go to previous messageGo to next message
danpaul88 is currently offline  danpaul88
Messages: 5795
Registered: June 2004
Location: England
Karma: 0
General (5 Stars)
Which files in particular were you wondering about? I know renguard.cfg is redundant since 1.53 doesn't support it but I can't remember off the top of my head any other files that were removed

http://steamsignature.com/card/1/76561197975867233.png
Re: BRenBot Plugins [message #458924 is a reply to message #458858] Fri, 04 November 2011 09:09 Go to previous messageGo to next message
Creed3020 is currently offline  Creed3020
Messages: 1438
Registered: February 2003
Location: Toronto, Canada
Karma: 0
General (1 Star)
BR 1.53 includes the following:
autoannounce.cfg
brenbot.cfg
brenbot.exe
commands.xml
mapsettings.xml
messages.cfg
moderators.cfg
presets.cfg
README - BRenBot 1.53.txt
recs.txt

BR 1.52 includes the following:
autoannounce.cfg
brenbot.cfg
brenbot.exe
brLoader.cfg <<<Missing from 1.53
brloader.exe <<<Missing from 1.53

commands.xml
docs [Folder] <<<Missing from 1.53
mapsettings.xml
messages.cfg
moderators.cfg
plugins [Folder] <<<Missing from 1.53
presets.cfg
recs.txt
renguard.cfg <<<No longer needed with 4.0
restart.exe <<<Missing from 1.53
sqlitebrowser.exe <<<Missing from 1.53

ssc_ignore.txt <<<No longer needed with 4.0
uninstall.exe <<<Missing from 1.53

The files I highlighted in red are the ones I am curious about.
Re: BRenBot Plugins [message #458929 is a reply to message #458858] Fri, 04 November 2011 10:17 Go to previous messageGo to next message
danpaul88 is currently offline  danpaul88
Messages: 5795
Registered: June 2004
Location: England
Karma: 0
General (5 Stars)
The missing ones are because whoever packaged up the TT server files didn't bother to ask me for a proper BR build and just grabbed the bare minimum required.

None of the highlighted items are required and I am not even sure if I will continue to use brloader for updates anymore, depends how often I need to release stuff I suppose. The docs folder would just contain the readme files and plugins you can create as necessary to add plugins.

sqlitebrowser was an extra provided to allow you to read and modify the BR database. The version included with 1.52 will not work with 1.53 since the database now uses sqlite3 instead of sqlite2, but you can get an updated version of the app online if you want it.


http://steamsignature.com/card/1/76561197975867233.png
Re: BRenBot Plugins [message #458939 is a reply to message #458929] Fri, 04 November 2011 15:35 Go to previous messageGo to next message
Creed3020 is currently offline  Creed3020
Messages: 1438
Registered: February 2003
Location: Toronto, Canada
Karma: 0
General (1 Star)
danpaul88 wrote on Fri, 04 November 2011 13:17

The missing ones are because whoever packaged up the TT server files didn't bother to ask me for a proper BR build and just grabbed the bare minimum required.

None of the highlighted items are required and I am not even sure if I will continue to use brloader for updates anymore, depends how often I need to release stuff I suppose. The docs folder would just contain the readme files and plugins you can create as necessary to add plugins.

sqlitebrowser was an extra provided to allow you to read and modify the BR database. The version included with 1.52 will not work with 1.53 since the database now uses sqlite3 instead of sqlite2, but you can get an updated version of the app online if you want it.


I figured there were reasons for the limited number of files. I never really used brloader so I wouldn't miss it. It would be nice to see the TT delivery including some basic plugins and an updated sqllite browser. They are useful server admin tools and are a value-add for BR.

One thing that would need to include is restart.exe otherwise the !reboot NOW command does not work.

Thanks for the tips about the BR db, I didn't know the version changed. I will definitely be grabbing a new version of that browser then. Have you ever considered allowing admins to use an external RDBMS for the BR database? e.g. MS SQL Server Express, etc.
Re: BRenBot Plugins [message #458957 is a reply to message #458858] Sat, 05 November 2011 04:04 Go to previous messageGo to next message
danpaul88 is currently offline  danpaul88
Messages: 5795
Registered: June 2004
Location: England
Karma: 0
General (5 Stars)
The DB implementation in BRenBot is all centralised into a couple of functions so it probably wouldn't be that hard to modify it to work with MySQL, MS SQL Server, Oracle, PostgreSQL, <insert db of choice here>.

In fact, other than changing the connection string, its as simple as swapping out the database driver DBD::SQLite for DBD::MySQL or DBD::Oracle etc





Oh, and FYI;
http://sourceforge.net/projects/sqlitebrowser/
Should work with the latest BR database


http://steamsignature.com/card/1/76561197975867233.png

[Updated on: Sat, 05 November 2011 04:05]

Report message to a moderator

Re: BRenBot Plugins [message #458969 is a reply to message #458957] Sat, 05 November 2011 10:23 Go to previous messageGo to next message
Creed3020 is currently offline  Creed3020
Messages: 1438
Registered: February 2003
Location: Toronto, Canada
Karma: 0
General (1 Star)
danpaul88 wrote on Sat, 05 November 2011 07:04

The DB implementation in BRenBot is all centralised into a couple of functions so it probably wouldn't be that hard to modify it to work with MySQL, MS SQL Server, Oracle, PostgreSQL, <insert db of choice here>.

In fact, other than changing the connection string, its as simple as swapping out the database driver DBD::SQLite for DBD::MySQL or DBD::Oracle etc

Oh, and FYI;
http://sourceforge.net/projects/sqlitebrowser/
Should work with the latest BR database


That is good to know. Maybe I will create a copy of BR and mess around with this idea. Where would I be changing this DB driver string content?

I found the SF page yesterday from Google but a user's comment on that one led me to this page: http://sourceforge.net/projects/sqlitedbrowser/, which claims to be newer.

Now back to the reason I started this thread. The messages I am currently seeing in the BR console related to plugins are:
[18:46:41] Loading plugin biatch... Use of tied on a handle without * is deprecated at XML/Parser/Expat.pm line 447.
Success! Attempting to start plugin
[18:46:41] Loading plugin BRenBot... Use of tied on a handle without * is deprecated at XML/Parser/Expat.pm line 447.
Success! Attempting to start plugin
[18:46:41] Loading plugin custom_commands... Use of tied on a handle without * is deprecated at XML/Parser/Expat.pm line 447.
Success! Attempting to start plugin


What do you make of that same message?
Re: BRenBot Plugins [message #458971 is a reply to message #458858] Sat, 05 November 2011 10:35 Go to previous message
danpaul88 is currently offline  danpaul88
Messages: 5795
Registered: June 2004
Location: England
Karma: 0
General (5 Stars)
That's not unusual, its just because the version of the XML parser used in BRenBot uses a deprecated feature in Perl, nothing I can do about it until they release an updated version of the parser which doesn't use the deprecated feature. It shouldn't prevent anything from working.



As for changing the database... its probably just a case of swapping out

$dbh = DBI->connect("dbi:SQLite:dbname=brenbot.dat","","");

for

$dbh = DBI->connect("dbi:<db_of_choice>:dbname=<db_path>","<username>","<password >");


Documentation;
Quote:

connect

$dbh = DBI->connect($data_source, $username, $password)
or die $DBI::errstr;
$dbh = DBI->connect($data_source, $username, $password, \%attr)
or die $DBI::errstr;

Establishes a database connection, or session, to the requested $data_source. Returns a database handle object if the connection succeeds. Use $dbh->disconnect to terminate the connection.

If the connect fails (see below), it returns undef and sets both $DBI::err and $DBI::errstr. (It does not explicitly set $!.) You should generally test the return status of connect and print $DBI::errstr if it has failed.

Multiple simultaneous connections to multiple databases through multiple drivers can be made via the DBI. Simply make one connect call for each database and keep a copy of each returned database handle.

The $data_source value must begin with "dbi:driver_name:". The driver_name specifies the driver that will be used to make the connection. (Letter case is significant.)

As a convenience, if the $data_source parameter is undefined or empty, the DBI will substitute the value of the environment variable DBI_DSN. If just the driver_name part is empty (i.e., the $data_source prefix is "dbi::"), the environment variable DBI_DRIVER is used. If neither variable is set, then connect dies.

Examples of $data_source values are:

dbi:DriverName:database_name
dbi:DriverName:database_name@hostname:port
dbi:DriverName:database=database_name;host=hostname;port=port

There is no standard for the text following the driver name. Each driver is free to use whatever syntax it wants. The only requirement the DBI makes is that all the information is supplied in a single string. You must consult the documentation for the drivers you are using for a description of the syntax they require.

It is recommended that drivers support the ODBC style, shown in the last example above. It is also recommended that that they support the three common names 'host', 'port', and 'database' (plus 'db' as an alias for database). This simplifies automatic construction of basic DSNs: "dbi:$driver:database=$db;host=$host;port=$port". Drivers should aim to 'do something reasonable' when given a DSN in this form, but if any part is meaningless for that driver (such as 'port' for Informix) it should generate an error if that part is not empty.

If the environment variable DBI_AUTOPROXY is defined (and the driver in $data_source is not "Proxy") then the connect request will automatically be changed to:

$ENV{DBI_AUTOPROXY};dsn=$data_source

DBI_AUTOPROXY is typically set as "dbi:Proxy:hostname=...;port=...". If $ENV{DBI_AUTOPROXY} doesn't begin with 'dbi:' then "dbi:Proxy:" will be prepended to it first. See the DBD::Proxy documentation for more details.

If $username or $password are undefined (rather than just empty), then the DBI will substitute the values of the DBI_USER and DBI_PASS environment variables, respectively. The DBI will warn if the environment variables are not defined. However, the everyday use of these environment variables is not recommended for security reasons. The mechanism is primarily intended to simplify testing. See below for alternative way to specify the username and password.

DBI->connect automatically installs the driver if it has not been installed yet. Driver installation either returns a valid driver handle, or it dies with an error message that includes the string "install_driver" and the underlying problem. So DBI->connect will die on a driver installation failure and will only return undef on a connect failure, in which case $DBI::errstr will hold the error message. Use eval { ... } if you need to catch the "install_driver" error.

The $data_source argument (with the "dbi:...:" prefix removed) and the $username and $password arguments are then passed to the driver for processing. The DBI does not define any interpretation for the contents of these fields. The driver is free to interpret the $data_source, $username, and $password fields in any way, and supply whatever defaults are appropriate for the engine being accessed. (Oracle, for example, uses the ORACLE_SID and TWO_TASK environment variables if no $data_source is specified.)

The AutoCommit and PrintError attributes for each connection default to "on". (See "AutoCommit" and "PrintError" for more information.) However, it is strongly recommended that you explicitly define AutoCommit rather than rely on the default. The PrintWarn attribute defaults to on if $^W is true, i.e., perl is running with warnings enabled.

The \%attr parameter can be used to alter the default settings of PrintError, RaiseError, AutoCommit, and other attributes. For example:

$dbh = DBI->connect($data_source, $user, $pass, {
PrintError => 0,
AutoCommit => 0
});

The username and password can also be specified using the attributes Username and Password, in which case they take precedence over the $username and $password parameters.

You can also define connection attribute values within the $data_source parameter. For example:

dbi:DriverName(PrintWarn=>1,PrintError=>0,Taint=>1):...

Individual attributes values specified in this way take precedence over any conflicting values specified via the \%attr parameter to connect.

The dbi_connect_method attribute can be used to specify which driver method should be called to establish the connection. The only useful values are 'connect', 'connect_cached', or some specialized case like 'Apache::DBI::connect' (which is automatically the default when running within Apache).

Where possible, each session ($dbh) is independent from the transactions in other sessions. This is useful when you need to hold cursors open across transactions--for example, if you use one session for your long lifespan cursors (typically read-only) and another for your short update transactions.

For compatibility with old DBI scripts, the driver can be specified by passing its name as the fourth argument to connect (instead of \%attr):

$dbh = DBI->connect($data_source, $user, $pass, $driver);

In this "old-style" form of connect, the $data_source should not start with "dbi:driver_name:". (If it does, the embedded driver_name will be ignored). Also note that in this older form of connect, the $dbh->{AutoCommit} attribute is undefined, the $dbh->{PrintError} attribute is off, and the old DBI_DBNAME environment variable is checked if DBI_DSN is not defined. Beware that this "old-style" connect will soon be withdrawn in a future version of DBI.


From http://search.cpan.org/~timb/DBI-1.616/DBI.pm#connect


http://steamsignature.com/card/1/76561197975867233.png

[Updated on: Sat, 05 November 2011 10:38]

Report message to a moderator

Previous Topic: BRenBot keeps failing to connect to the RenGuard master server
Next Topic: BrenBot 1.53 build9
Goto Forum:
  


Current Time: Sun Nov 03 09:09:10 MST 2024

Total time taken to generate the page: 0.00810 seconds