Q101616: A Program to Generate Documentation on LAN Manager Servers
Article: Q101616
Product(s): Microsoft LAN Manager
Version(s): 
Operating System(s): 
Keyword(s): 
Last Modified: 30-JUL-2001
SUMMARY
=======
This article contains a REXX program that can be used to easily document much of
a server's configuration--including users, groups, resources and configurable
parameters.
MORE INFORMATION
================
To use the program do the following:
- Cut-and-paste the listing beginning with (including) the first dollar sign
  and continuing to (but not including) the pound sign.
- Search-and-replace the dollar sign with a forward slash (/).
- Save the file as LANDOC.CMD or some other *.CMD name.
There are three command line switches to the program:
- A or /A adds the results of "net access" to the document
- G or /G adds a verbose group listing to the document
- U or /U adds a verbose user listing to the document
"Verbose" means that instead of getting just a list of groups or users on the
server you will receive information on each individual group or user.
You must run this program at the server or other OS/2 machine while logged on
with ADMIN privileges. Examples of program execution at an OS/2 command prompt
are:
  landoc             (this produces minimum documentation)
  landoc a           (adds the "net access" results)
  landoc g           (adds group information)
  landoc u           (adds user information)
  landoc g u         (adds user and group information)
  landoc g u a       (maximum documentation)
NOTE: This program may take some time to run. It requires a minimum temporary
free disk space of approximately 24K plus 1K per user in NET.ACC and 1K per 30
groups in NET.ACC--if you use all options.
  $* MUST be logged on with ADMIN privilege *$
  parse upper arg cmd_param_1 cmd_param_2 cmd_param_3
  push cmd_param_1
  push cmd_param_2
  push cmd_param_3
  do 3
  pull parameter
  if (parameter = '/U') | (parameter = 'U') then
       do_user = 'yes'
  if (parameter = '/G') | (parameter = 'G') then
       do_group = 'yes'
  if (parameter = '/A') | (parameter = 'A') then
       do_access = 'yes'
  end
  "if exist lan-doc.bak del lan-doc.bak"
  "if exist lan.doc ren lan.doc lan-doc.bak"
  "if exist get_list.dat del get_list.dat"
  "net config workstation >> lan.tmp"
  "net config server >> lan.tmp"
  "net comm >> lan.tmp"
  "net device >> lan.tmp"
  "net print >> lan.tmp"
  "net accounts >> lan.tmp"
  call cleanup
  if do_user <> 'yes' then
       "net user >> lan.tmp"
  else
       do
       "net user >> get_list.dat"
       call do_list user 1
       end
  if do_group <> 'yes' then
       "net group >> lan.tmp"
  else
       do
       "net group >> get_list.dat"
       call do_list group 2
       end
  call cleanup
  "net share >> lan.tmp"
  if do_access = 'yes' then
       do
       "net access >> lan.tmp"
       end
  call cleanup
  exit
  do_list:
  parse arg use_type start_pos
  do i = 1 to 4
  tempstr = linein("get_list.dat",,1)
  end
  do while lines("get_list.dat") > 0
  do 3
  name = substr(tempstr,start_pos,25,' ')
  if substr(name,1,1) = ' ' then iterate
  "net " use_type name " >> lan.tmp"
  tempstr = delstr(tempstr,1,24+start_pos)
  end
  tempstr = linein("get_list.dat",,1)
  i = pos( "command completed successfully", tempstr,1)
  if  i > 0 then
       do while lines("get_list.dat") <> 0
       tempstr = linein("get_list.dat",,1)
          end
  end
  tempstr = lineout("get_list.dat")
  "del get_list.dat"
  return
  cleanup:
  tempstr = linein("lan.tmp",1,1)
  do while lines("lan.tmp") > 0
  i = pos( "command completed successfully", tempstr,1)
  if i = 0 then
     j = lineout("lan.doc",tempstr)
  else
     do
     j = lineout("lan.doc"," ")
     j = lineout("lan.doc","******************************************")
     j = lineout("lan.doc"," ")
     end
  tempstr = linein("lan.tmp",,1)
  end
  j = lineout("lan.tmp")
  "del lan.tmp"
  j = lineout("lan.doc"," ")
  j = lineout("lan.doc","*********************************************")
  j = lineout("lan.doc"," ")
  j = lineout("lan.doc")
  return
  #
Additional query words: 2.10 2.1 2.10a 2.1a 2.20 2.2
======================================================================
Keywords          :  
=============================================================================
THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY.
Copyright Microsoft Corporation 1986-2002.