Orac  --  DBA GUI tool for Perl/Tk; Oracle, Informix and Sybase

NB: ....Oracle Development Usage Gradually Being Added...
    .........By Andy Duncan & Richard Sutherland.........

THIS IS A DEVELOPMENT VERSION OF ORAC, AND AN ATTEMPT TO ADD ORACLE 
DEVELOPMENT TOOLS TO ORAC, AS WELL AS DBA ONES.  FOR STABLE DBA USAGE,
UNTIL FURTHER NOTICE, USE THE Orac-1.2.0 DOWNLOAD.

   Copyright (c) 1998,1999,2000,2001 Andy Duncan, England

   email:         andy_j_duncan@yahoo.com
   CPAN id:       CPAN/authors/id/A/AN/ANDYDUNC

=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+
        Orac runs over the *Web* using a Netscape Perl/Tk Plug-In
        created by Frank Holt.  Please run up Orac, and go to Help
        information for more details (help/WebPlugIn.txt).
=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+-=+

NB: This README file does not contain all of the information within
the Orac distribution.  For more specialised information, please go
to our "docs" or "help" directories.

Orac-1.2.0 is the latest stable version of Orac.  You may wish
to download this if you have any problems with these later development
versions, if you are a DBA.

TERMS AND CONDITIONS OF USE:

   You may distribute under the terms of either the GNU General Public
   License or the Artistic License, as specified in the Perl README file,
   with the exception that it cannot be placed on a CD-ROM or similar media
   for commercial distribution without the prior approval of the author.

PLEASE NOTE:

   Some of the Oracle SQL scripts which come with this Perl program,
   are copyrighted to Brian Lomasky.  Please seek clarification from
   Brian before you extend the use of these SQL scripts beyond this
   Perl program.  Such scripts can be easily identified by the header:

   /* From Oracle Scripts, O Reilly and Associates, Inc. */
   /* Copyright 1998 by Brian Lomasky, DBA Solutions, Inc., */
   /* lomasky@earthlink.net */

WARNING:

IN NO EVENT SHALL THE AUTHORS OR DISTRIBUTORS BE LIABLE TO ANY PARTY
FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
ARISING OUT OF THE USE OF THIS SOFTWARE, ITS DOCUMENTATION, OR ANY
DERIVATIVES THEREOF, EVEN IF THE AUTHORS HAVE BEEN ADVISED OF THE
POSSIBILITY OF SUCH DAMAGE.

THE AUTHORS AND DISTRIBUTORS SPECIFICALLY DISCLAIM ANY WARRANTIES,
INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT.  THIS SOFTWARE
IS PROVIDED ON AN "AS IS" BASIS, AND THE AUTHORS AND DISTRIBUTORS HAVE
NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR
MODIFICATIONS.


PREREQUISITES (For Everybody)

   At least: perl5.005_02
             DBI-1.13
             Tk800.015
             Latest relevant DBD database driver for DBI-1.13

   Oracle developers will also require Richard Sutherland's DDL::Oracle
   module.  We are using:

             DDL-Oracle-1.04.tar.gz 

   This (or the latest version) is available from:

   http://www.perl.com/CPAN-local/modules/by-authors/id/R/RV/RVSUTHERL/

   For an indefinite period, the latest DDL::Oracle package will
   come automatically with the Orac download.  This may change.

LINUX USERS:

   There are some further notes at the end of this README file
   for Linux users.

WINDOWS NT USERS:

   There are some further notes at the end of this README file
   for Windows NT users.

REALLY QUICK START GUIDE:

   perl orac_dba.pl <RETURN>


SLIGHTLY LESS QUICK START GUIDE (based upon Oracle on Solaris):

*). Load perl5.005_02, DBD-Oracle-1.03, DBI-1.13 & Tk800.015
*). Unzip (gzip -d, gunzip) the Orac-x.y.z.tar.gz file
*). Untar (tar xvf) the Orac-x.y.z.tar file
*). Set ORACLE_HOME in your environment
*). Run orac_dba.pl, first making sure the top line of the
    file has the right Perl string address, eg:
        => #!/usr/local/bin/perl
    Or run it with the Perl program directly, 'perl orac_dba.pl'.
*). Most things should be fairly straightforward after that.


NOTE ON USER CUSTOMISATIONS

User customisations (e.g., last DB accessed and user tool menus) go to either:
   1) If $ORAC_HOME (%ORAC_HOME% for Windows) exists, to that directory
   2) If on Windows, %USERPROFILE%/orac
   3) $HOME/.orac

Users no longer have to cd into the Orac distribution directory.  On
Unix systems, you could have a symbolic link from
/usr/local/bin/orac_dba.pl to the Orac distribution directory.  On
Windows machines, you could have a shortcut to the Orac_dba.pl
(although this doesn't work from the command line).  $ORAC_HOME can be
set to a shared directory if users want to share their user
customisations.


ABOUT Orac:

Preamble: This tool was originally developed on an Ultra-5 Sun Solaris 2.6 Sun
workstation.  There may be incompatibilities on your workstation, which may
need a little source code tinkering.  Our apologies.  Please mail us if this
is the case.  Even better, email us the coded up solution :-)

Orac is a Perl/Tk tool written in order to store many different and hopefully
useful SQL scripts within one central easy-to-use interface repository.
It is a Read-Only 'as is' GUI tool (ie: no DDL, DML, transactions, commits or
rollbacks, only selects)* and will be updated continuously to improve its
functionality and GUI-ness simplicity.  If you have any useful SQL scripts,
which you would like to be included within Orac, or requirements which you
think may be useful to others, please mail them to me and we'll try and embed
them in the next release.

If you read through the revision history below, you'll see many such ideas
have been taken up, and are now integral parts of the main Orac tool.

Simple graphical ideas for turning difficult-to-read database information
into useful pictures are particularly welcomed, as is functionality
not currently supplied within other GUI tools.  General ideas for improving
Orac (which began life as a SQL script for killing rogue Oracle processes)
are always welcomed.

We hope you both enjoy using Orac, and save yourself some time by using it.

*Occasionally, this rule is bent a little to allow such tool extensions as
our 'Explain Plan' functionality for Oracle users.


Orac MONGERS (in alphabetical surname order):

Name           Email/Webpage                    Patches of Interest
----           -------------                    -------------------

Bruce Albrecht <bruce@zuhause.mn.org>           Multi-User Functionality

Kevin Brannen  <kbrannen@physiciansdata.com>    Informix/RulesMeister

Andy Duncan    <andy_j_duncan@yahoo.com>        Oracle, OracWeb

Sean Hull      <sean.hull@pobox.com>            Linux/Oracle
               http://www.iheavy.com/           OracWeb Guru Meister

Kevin Kitts    <kkitts@his.com>                 Linux/Webmaster
               http://www.kkitts.com/

Thomas Lowery  <stlassociates@usa.net>          Shell/OO Development
               http://tlowery.hypermart.net/

Charles Wolfe  <cwolfe@ix.netcom.com>           NT Guru

Alex Shnir     <alex@getmessage.com>            Sybase


FUTURE OF Orac:

We want to create a completely OS independent, database
independent Open Source tool.  If you'd like to help us do this, and/or join
the Orac Mongers listing above, please let us know and we'll go from there.


REVISION HISTORY:
-----------------
Vers Date   Comment
---- ----   -------
0.01 Jan 99
0.02 Jan 99 Original code revised to make more stable on other platforms.
            Removed all '-font' usage and wrapped some statements in 'eval'
            statements to prevent premature shutdowns.  Also took all SQL
            out of program and placed in flat files to be called
            as-and-when necessary (also allows for easier SQL modification).
0.03 Feb 99 After further comments, radical revision carried out to
            shrink Orac into 1 Perl script, rather than numerous heavy
            modules.  Also revised Orac to use Tk4 partly to remove errors
            for people using Tk4, and because the new 'Learning Perl/Tk'
            manual recommends G. Sarathy's Win32 binary executable, which
            currently uses Tk4.  Preparing code for first port away from
            Solaris 2.6 UNIX.
            Thanks to Tim Bunce for constructive criticism.
0.04 Apr 99 Adjustments after first DBI-Users release.
0.05 Apr 99 More Adjustments after first DBI-Users release.
            Thanks in particular to Sean Hull for support.
0.06 Apr 99 Cleaned up a few extraneous debug statements.  Decided to not
            attempt ports, after hearing from some Linux users that
            Orac ran "out-of-the-box", also NT and my mind do not fit
            together.  Also, must add more functionality.
            Tasklist this time, resizing of windows should be better.
            Hit Ratios values should be clearer.
            Thanks especially to Kevin Kitts.
0.07 May 99 More Buggette cleaning, and better screen resizing on Form.
            MTS support, under the Tuning button (thanks to Steve Shaw).
            Background colour option added (thanks to Honza Pazdziora)
            under File option.
            Language Independence added, edit the txt/language.txt file
            to change all Orac Menus, buttons etc, to your own text.
            New 'My Tools' menu Option created to add your own SQL
            reports on-the-fly.
            (thanks to Jared Still for the inspiration on this one)
            Addition of 'User' field on main database connection
            screen to allow DBAs to use secure system-like users,
            with more security conscious permissions.
            (Thanks to Kevin Kitts for this one).
Orac-1.0.0  New numbering system.  This is a rename of ORAC-DBA-0.07,
            and the latest totally 'stable' version.
            We are now using an Orac-x.y.z numbering system such that:
               x is the major version number
               y is the minor version number
               z is the minor minor version number
            When 'y' is 'even', Orac is stable, when 'odd', Orac
            is developmental (though we still recommend its download as
            we do not relase REALLY experimental versions).
Orac-1.1.0  First of new Developmental 1.1.z Series
            Finally got round to adding 'Interactive Form' for all
            the Oracle Views in the database, accessible by 'Object' menu.
            Added Orac icons for various iconizable windows.
            (Thanks to Edmund Mergl for sending us a coded patch).
            After an email from Kevin Brannen, and a fit of madness,
            decided to try and make Orac database independent.  Are
            we all mad?  Maybe, but it's fun, fun, fun in Orac City.
            (Thanks to Charles Wolfe for sending us some extremely
            valuable installation information.  He is a God-like
            Guru of a Class A1 nature)
            Thanks to Guy Harrison for allowing us to adapt his scripts
            from his excellent High-Performance Tuning manual.
            Many of these scripts have now been used in this version
            of Orac, and much more will be done later to improve our
            use of them.
            Added SQL Browser/Explain Plan for Oracle
            Better report formatting
            Current Oracle future plans include a 'dbish' window,
            Further non-Oracle database (particularly Informix) functionality,
            Eventual addition of Sybase functionality.
            More help files, comments in code,
            More modularity,
            +whatever else you'd like us to add?
Orac-1.1.1  (Oracle) Neater 'Explain Plan' utility, On-the-fly SQL execution
            utility.  Tidied a few 'uninitialized variable bugs'.
Orac-1.1.2  (Informix) More functionality added. (Oracle) More tidying, plus
            better/quicker use of config files, and use of SQL Browser without
            PLAN_TABLE in db.
Orac-1.1.3  A lot of file tidying for Oracle, and further Informix additions.
            May be a little flaky, and tidied up in the 1.1.4 release.
Orac-1.1.4 -
Orac-1.1.7  Private releases changing code from 'structured'
            - ok, spaghetti  :) - to the beginnings of object-oriented code.
            one known bug, under Oracle, the special buttons on 'MTS
            statistics', and 'whos locking who' screens, not working
            correctly.  This will be sorted out in 1.1.8 (promise).
Orac-1.1.8  Back to public releases of developing code.
            First cut of orac_Shell.
            Total use of generic_hlist() rather than gn_hl().
            Further improvement of windows handling.
            Known Oracle Bug with some interactive buttons, still on ice.
Orac-1.1.9  Small fix in orac_Base for show_sql() and also had
            to replace all the orac_Show() calls with the generic
            $dialog->Show function, to prevent screen lock-ups
            on NT.
Orac-1.1.10 A lot more tidying.
Orac-1.1.11 Additional Oracle items on menus.
Orac-1.1.12 Bug fixes for Orac-1.1.11 (thanks Duc)
Orac-1.1.13 More patches, plus latest orac_Shell
Orac-1.1.14 More of the same.
Orac-1.1.15 Gradual Addition of Alex's Sybase functionality.
            + multi-user functionality added by Bruce Albrecht
Orac-1.1.16 Private releases of 1.1.15 tidied up, and put together
            for this public release.
Orac-1.1.17 private: Further changes to orac_Shell, new orac_Sybase,
            brand new orac_FileSelect module.
Orac-1.1.18 -
Orac-1.1.25 Many incremental private releases making as many windows
            as possible independent, adding Font abilities, limited
            Print options and a generalised File viewer.  Also
            much more use of icons to ease use of program.  Functionally
            not much different from 1.1.16 but hopefully a lot easier,
            and a lot more pleasant to use.
Orac-1.1.26 First public release of 'new-look' iconized, independent
            windowed Orac.  Hope you like it!  :-)  (I do)
Orac-1.1.27 -
Orac-1.1.30 Incremental early development of Monitoring + bug fixes,
            + other bits
Orac-1.1.31 Public Release of OracMonitor.
Orac-1.1.32 -
Orac-1.1.33 Tidying, fixing etc,etc - thanks to Sean Kamath - and
            attempts at code reduction.  Thanks to Edmund Mergl for
            initial 8i fix.  More to be found I'm sure.
Orac-1.1.34 Cleaning up newly introduced bugs.
Orac-1.1.35 Horrible bug fix for ActiveState not requiring ORACLE_HOME,
            where unixlike does.
Orac-1.1.36 Attempt on Monitor fix.  Steve Humpage 'join' to 'catfile'
            fix for backward compatibility.
Orac-1.1.37 New orac_Sybase from Alex.
Orac-1.1.38 -
Orac-1.1.40 Final 1.1 KevinB Informix change, +changes to Shell
Orac-1.1.41 -
Orac-1.1.43 - ... Shell development, trying to fix Monitor Bug
Orac-1.1.44 Monitor Bug is an Oracle-Linux bug.  Oracle have been told
            and hopefully will fix in later Oracle version.
Orac-1.1.45 Bits and Bobs.
Orac-1.1.46 Final Beta release of Tom's Shell program + addition of
            primitive help for getting OracWeb going.
Orac-1.1.47 Mix-up on Beta module versions, should now be sorted out.
Orac-1.1.48 Change on Oracle curr_users_orac.1.sql script by Andre Seesink
            +other code changes by Andre marked in files :-)
Orac-1.1.49 Last Andre Seesink and Duncan Lawie upgrades, plus bug fix
            by DCL :-)
Orac-1.1.50 Slight changes, + more commenting and switching within the
            orac_Monitor module, which, after a consensus vote, will be kept
            within the distribution for later improvement despite problems.
            If you'd like to make this 100% kosher, please write and let
            us know :)
Orac-1.1.51 Heck and blast, a typo on my part.  Whoops, sorry fellas! :-)
Orac-1.2.0  After no adverse reports on 1.1.51, this is that release
            with this README file name and the program's version number
            changed.  Thanks to everyone who's helped us get this far.
            We ain't finished yet.
Orac-1.2.1  Yep, it HAS been a while, but let's get this monkey running
            again.  The VERY early beginnings of developer support
            for Oracle developers using Richard Sutherland's DDL option.
            Thanks to Andy Campbell, Sun employee and DBA genius! :-)
Orac-1.2.2  Much more embodiement of Richard Sutherland's DDL-Oracle
            coded by RVS and AndyD.  This version of Oracle now automatically 
            incorporates the latest version of DDL::Oracle.  Automatic
            detection of DBA or normal development user.  Wishlists
            are welcome of where Oracle Development functionality
            should go next.  We're just making this up as we go along! :-)

EXTRA NOTES FOR LINUX USERS:

Originally provided by Kevin Kitts.

Requirements for Running Orac (under Linux)
-----------------------------------------------
perl 5.05
Tk 800_015 perl module (www.cpan.org)
DBI/DBD perl modules (www.hermetica.com)
Orac Download the latest stable version (or
development version if looking for latest functionality)

Using Orac under Linux
--------------------------
I've found a number of problems running Orac under RedHat 5.2. In order
to get things to work it was necessary to get the latest *source* rpm for
perl and rebuild perl. The man pages for rpm will explain how to do this
rebuild - it is very straightforward. Also, the latest version of the
perl Tk module (800_015) will be required as well. Lastly, you'll need
to get the DBI/DBD modules and compile them.

Make sure that you can get sql*plus to work first. If that works, make sure
that the DBI/DBD make tests pass. If all of the above condtions hold true
you should have no problem running Orac.

KNOWN LINUX-ORACLE BUG

There is a known Oracle-Linux bug, which may cause the Orac Monitor to fail
when attempting to connect to recently shutdown databases.  Oracle have been
informed, and will hopefully fix bug in a future release.  This is a general
OCI bug, and has caused problems with other programs.  One workround is not
to use Orac Monitor, but if this required, if you don't need LOBS etc then 
you could try recompiling DBI with 'perl Makefile.PL -8'.  See DBI README
for more details on this.

This bug may also occur on other OSes, but cannot be replicated on Solaris.

EXTRA NOTES FOR WINDOWS NT USERS:

Using Orac under Windows NT
-------------------------------
Environment required:

Basic Perl Requirement:

*. ActivePerl build 519 (or latest)

Packages on top:

*. DBD-Oracle (or DBD-Sybase etc)
*. DBI
*. Tk
*. Win32-TieRegistry

The above environment was created under the following
operating system conditions:

NT 4.0 Enterprise Edition (SP 3, no compiler)
---------------------------------------------
Nothing special is needed for the installation,
which should run smoothly using these instructions:

*. Install the ActivePerl binary distribution
from ActiveState.com

*. Then download and install the binaries for the
various modules (Tk, DBI, DBD-Oracle, etc)
from ActiveState's ftp site.

All the modules come with working install scripts,
so installation is just a matter of running
package manager script which comes with ActivePerl.

Then download Orac-x.y.z, install and run.
(probably always best to use latest version)

(The above instructions have also been tried on a
Win98 box with complete success)

The ActiveState URLs are:

=> http://www.activestate.com/ActivePerl/
=> http://www.activestate.com/packages/zips/

Packages Required:
------------------
The ActiveState packages you will need, will be Tk, DBI and
whichever DBD driver you need (eg: DBD::Oracle, DBD::Sybase).

You may find problems with Win32-TieRegistry errors.  If
this is the case, you may also need to install the Win32-TieRegistry
package, also from packages/zips.

Download
--------
You can download the latest Orac via:

=> ftp://ftp.funet.fi/pub/languages/perl/CPAN/authors/id/A/AN/ANDYDUNC/

We have altered the DBI->connect routine to try a couple
of different versions-on-a-theme, to allow non-unix
boxes to connect remotely.  If you still cannot connect
remotely, you may have to slightly change the DBI->connect
statements to give DBI the right configuration for your
remote database connection.

EOF