WHAT AM I
---------

File README for DBIx::FileSystem

DBIx::FileSystem - Manage database tables like a filesystem

   (C) 2003, 2018  by Alexander Haderer

   You may distribute under the terms of the GNU General Public License.


DESCRIPTION:
------------

from the manpage:

The module DBIx::FileSystem offers you a filesystem like view to
database tables. To interact with the database tables, FileSystem
implements a command line shell which offers not only a subset of well
known shell commands to navigate, view and manipulate data in tables, but
also gives the convenience of history, command line editing and tab
completion. FileSystem sees the database as a filesystem: each
table is a different directory with the tablename as the directory
name and each row in a table is a file within that directory. 

DBIx::FileSystem also contains a class to access the data in the
Database. The function get_conf_by_var() respects the defaultfile
function from the shell.

The motivation for FileSystem was the need for a terminal based
configuration interface to manipulate database entries which are used
as configuration data for a server process. FileSystem is neither
complete nor a replacement for dbish or other full-feature SQL shells
or editors. Think of FileSystem as a replacement for a Web/CGI based
graphical user interface for manipulating database contents.

EXAMPLE:
--------

The file pawactl implements a sample shell using DBIx::FileSystem. It 
implements the configure shell of a virtual package warehouse. 
Sample session:

----------> pawactl sample session start --------->

  pawactl (/source): ls
  (dest)          acity           factory2        lcity           
  (source)        bcity           generic         
  (warehouse)     factory1        kcity           
  pawactl (/source): cat bcity 
  #
  # Settings for SourceName 'bcity' (defaults: 'generic')
  #
  # - this is a comment, comments always start in the first column.
  # - all lines begin in the first column or are blank lines
  # - a unset variable will write NULL into the database column
  # - unset variables use the default values
  #

  #
  # SourceID
  # Internal source idenficator (4 characters)
  #
  # default: ----
  #
  SourceID = CIB

  ... more file contents ...

  pawactl (/source): sum bcity 
  SourceID     = CIB
  Distance     = 2434
  Destination  = moon
  pawactl (/source): vgrep destina
       acity: Destination = mars
       bcity: Destination = moon
    factory1: Destination = moon
    factory2: Destination = venus
     fromfar: Destination = mars
     generic: Destination = *unset*
       kcity: Destination = moon
  pawactl (/source): cd dest 
  pawactl (/dest): ls
  (dest)          (warehouse)     moon            venus           
  (source)        mars            neptun          
  pawactl (/dest): rm venus
  rm: cannot remove: file 'venus' referenced by:
    source/factory2
    warehouse/sx0001
  pawactl (/dest): vi venus

     ... vi session ...
     ... save & quit ...


  ERROR: line 23: invalid value: valid range: (1..100)
  Do you want to edit again ('n' will abort) [y/n] ? n
  pawactl (/dest): 

<---------- pawactl sample session end <---------

REQUIREMENTS:
-------------

  - build, test and install Perl 5         (at least 5.003)
  - build, test and install the DBI module (at least 1.00)
  - build, test and install Gnu::ReadLine  (recommended)
  - to use datatypes 'cidr' and 'inet': a PostgreSql database
  - a database server running
  - a perl DBD module installed to connect to the database server


PLATFORMS:
----------

  This release of DBIx::FileSystem has been developed using FreeBSD.


INSTALLATION:
-------------

1.   perl Makefile.PL
2.   make
3.   make test
4.   make install

( 1. to 3. as normal user, not as root ! )


TESTING:
--------

- the shell: t/00_shell.t:

  The test currently is only a dummy because I don't know how to test
  an interactive shell across many different platforms and terminals.
  Workaround: Do a test of all required modules. Run the sample pawactl.


- access class: t/02_access_data.t

  This test requires a running database server containing the sample database 
  coming with the sample program pawactl. To prepare the tests for the
  access class do:

  1. create the database on the server using SQL or commandline:
  	CREATEDB warehouse
  2. modify example 'pawactl' to connect to this database. Edit the lines
     where these variables are set:
        $DBCONN
	$DBUSER
	$DBPWD
  3. run example 'perl -Iblib/lib examples/pawactl recreatedb' to install 
     the sample data in db
  4. modify the test t/02_access_data.t to connect to the sample database.
     Edit the lines where the following variables are set, so that they have
     the same values as in pawactl:
        $DBCONN
	$DBUSER
	$DBPWD
  5. do not change the sample database by playing around with pawactl!
  6. now you can test:
  	either: 'make test'
	or manually: 'perl -Iblib/lib t/02_access_data.t'


  
USING EXAMPLES:
---------------

To play around with the example warehouse you need a sample database:

  1. create the database on the server using SQL or commandline:
  	createdb warehouse
  2. modify example 'pawactl' to connect to this database. Edit the lines
     where these variables are set:
        $DBCONN
	$DBUSER
	$DBPWD
  3. run example 'perl -Iblib/lib examples/pawactl recreatedb' to install 
     the sample data in db
  4. play around with the example shell: 'perl -Iblib/lib examples/pawactl'
     NOTE: take a look at the comments in pawactl
  5. play around with the access sample: 'perl -Iblib/lib examples/access'



CHANGES:
--------

1.00	24 Mar 2003
	initial version

1.01	8 Apr 2003
	- rmcheck option added
	- volok option added
	- vi now can create new files (usefull with 'NOT NULL' constraint)

1.02	7 May 2003
	- added (dummy) t/dummy.t testing
	- internal release

1.03	8 May 2003
	- rename: t/dummy.t to t/use.t

1.04	16 June 2003
	- cp: missing filenamecheck for new file added
	- vdirs: desc now may be multiline by adding '\n' to the text

1.05	10 July 2003
	- the valok custom check functions now get a second parameter holding
	  a hash ref of all variables read in from the to-be-edited-file,
	  key is the columnname (cols)
	- pawactl modify to show an example how to use the above hashref

1.06	14 July 2003
	- comcol in %vdirs hash introduced: define a column that will hold
	  comments for a file
	- introduced new commands 'll' and 'ld' 
	- check length of fnamcol column againtst $LS_COL_WIDTH
	- added possibility to add custom commands
	- rmcheck and volok callbacks: added param dbh

1.07	21 july 2003
	- added missing t/use.t to MANIFEST

1.08 	11 aug 2003 
	- more %vdirs checking at startup
	- vi/cat now use 'desc' instead of 'var' when column is fnamcol

1.09	03 feb 2004
	- delcp option: when saving a file this var will also checked 
	  against duplicate entries in other files in this dir (unique test)
	- delcp now is called 'uniq', print out warning msg when delcp used
	- added 'vgrep' command

1.10	skipped

1.1	skipped

1.2	10 jun 2007
	- extended int datatype to behave like a collection of configurable
	  flags (bits) if option 'flags' is set
	- added new types 'cidr' and 'inet' (will work with PostgreSql only)
	- added flags example to pawactl
	- added cidr example to pawactl
	- minor bug fixes in application and docs

1.3	11 jul 2007
	- bugfix: display of defaultvalues from defaultfile wrong (cat/vi)
	- pawactl: setup some more usefull sample values

1.4	11 nov 2007
	- extended int datatype to behave like a enum integer type if option
	  'enums' is set
	- added enums example to pawactl

1.5	4 dec 2007
	- added access class for database values, the access function 
	  respects the defaultfile function

1.6	12 dec 2007
	- fixed locale dependency in test 01_access_isanumber.t

1.7	13 dec 2007
	- using multiple 'use constant' instead of single one to be
	  compatible with older perls
	- added missing requirement "Test::Simple" to Makefile.PL

1.8	21 jan 2008
	- bugfix: 'use of uninitialized value' when saving a file where a
	  var is NULL/undef and defined with option 'uniq'

1.9 	28 mar 2008
	- bugfix: user supplied valok-check got string 'NULL' instead of 
	  undef when an enum has nothing selected
	- bugfix: enum descriptions in vi/cat now sorted numerically by 
	  enum value instead of lexically by enum value

2.0 	08 jul 2008
	- added new alternate parameter rdbh for constructor of access class
	- added test for above parameter

2.1	missing

2.2	08 sep 2011
	- modified handling of 'ref' type: Now similar like enum/flags
	- new column property 'cpdelete': delete value on copy 'cp'

2.3	18 oct 2011
	- bugfix: can now save a flags field with undefined value as given
	  when editing a file with vi

2.4	04 jan 2012
	- bugfix: #466 fisctl shell -- use of uninitialized value bei cat/vi

2.5	22 feb 2018
	- bugfix: #2962 DBIx::FileSystem: Bugfix POSIX::tmpnam --> File::Temp

COPYRIGHT:
----------

You may distribute under the terms of either the GNU General Public
License or the Artistic License, as specified in the Perl README file.


HOW TO GET THE LATEST VERSION:
------------------------------

Look at CPAN.


IF YOU HAVE PROBLEMS:
---------------------

Please send comments and bug-reports to <afrika@cpan.org>


---------------------------------------------------------------------------
   Alexander Haderer   					afrika@cpan.org
---------------------------------------------------------------------------