# DCinfra.cfg: Collects Oracle Fusion Middleware Infrastructure 12c Information # $Id: DCinfra.cfg,v 1.3 2014/10/07 06:00:10 RDA Exp $ # ARCS: $Header: /home/cvs/cvs/RDA_8/src/scripting/lib/collect/OFM/DCinfra.cfg,v 1.3 2014/10/07 06:00:10 RDA Exp $ # # Copyright (c) 2002, 2016, Oracle and/or its affiliates. All rights reserved. # # Change history # 20141002 KRA Improve domain validation. ############################################################################### # Collect the Oracle Fusion Middleware Infrastructure 12c setup information ############################################################################### #------------------------------------------------------------------------------ # Module definition #------------------------------------------------------------------------------ col=${B_IN_USE} dsc='Collects Oracle Fusion Middleware Infrastructure 12c Information' man='Applies to Oracle Fusion Middleware Infrastructure 12c and later' pre=OFM:DCinit req=?B_REQ_WREQ:OFM:DCwreq rpt=B_IN_USE tgt=${I_OHC/C} trg=?B_REQ_WREQ:OFM:DCwreq var=not_used # Flow:in_use,B_IN_USE exe=sdcl { "if ${GRP.INIT.I_OH} "{var ${I_OHC/T} = $itm = last " var (${B_REQ_WREQ/T},$ORACLE_HOME) = (undef,$itm->get_first('D_ORACLE_HOME')) " if compare('VALID',getTopProductVersion($ORACLE_HOME,'oracle.opss.core'),'12') " var @{AUX.var} = (cond(${PRF.B_TESTS},'in_use','B_IN_USE')) " keep $ORACLE_HOME "} " "macro check_domain "{loop $dom (findDir($arg[0],'^\.+$','npv')) " {if grepFile(catFile($dom,'config','config.xml'),'^'Perform offline collection',\ ON =>'Perform online collection (using WLS connection)'] val=F #------------------------------------------------------------------------------ # Select the domain(s) #------------------------------------------------------------------------------ [I_DOMAINS] typ=I cls='DOM' dsc='Oracle WebLogic domain target list' end='.' exe=sdcl { "var ($top,@itm,%dom,%dup,%SERVERS) = (${D_DOMAIN_ROOT}) "keep %SERVERS "if ${PRF/B_OFM_IPS} "{var $dir = cleanNative([$top,${PRF/T_DOMAIN},'']) " var $dom{getShortPath($dir,true)} = [$top,${PRF/T_DOMAIN},$dir] "} "elsif ${T_DOMAINS/E} "{var ($lst,$srv) = () " if ${T_SERVERS/E} " {if compare('eq',last,'HASH') " var $srv = ${T_SERVERS} " else " var $lst = [@{T_SERVERS}] " } " loop $nam (@{T_DOMAINS}) " {var $dir = cleanNative([$top,$nam,'']) " if grepFile(catFile($dir,'config','config.xml'),\ " '^{$nam} " } " } "} "elsif findDir($top,'^\.+$','nv') "{loop $sub (last) " {next !grepFile(catFile($top,$sub,'config','config.xml'),\ " '^true,\ " B_MISSING_HOME=>true,\ " B_MISSING_PRODUCT=>true,\ " B_MISSING_WL_HOME=>true,\ " D_DOMAIN_HOME=>$key,\ " D_DOMAIN_ROOT=>$top,\ " T_DOMAIN_NAME=>$sub}) " next !?$tgt->get_attr('BEA_HOME') " next !?testFile('f',catFile(last,'domain-registry.xml')) " next exists($dup{$reg = last}) " loop $xml (xmlFind(xmlLoadFile($reg),'domain-registry/domain')) " {var $dir = cleanNative([xmlValue($xml,'location'),'']) " if grepFile(catFile($dir,'config','config.xml'),'^',length($dir),length($dom{$key}->[2]))) " {if expr('>',scalar(@dir = splitDir($dir)),1) " {var $nam = pop(@dir) " var $dom{getShortPath($dir,true)} = [catNative(@dir,''),$nam,$dir] " } " } " } " } " var $dup{$reg} = true " } "} "loop $dir (keys(%dom)) " call push(@itm,\ " nvl(findItem('DOM','D_DOMAIN_HOME',$dir,true),\ " defineTarget('DOM',{D_DOMAIN_ROOT=>$top = $dom{$dir}->[0],\ " T_DOMAIN_NAME=>$nam = $dom{$dir}->[1],\ " T_TITLE=>"Domain ${VAR.nam} (in ${VAR.top})"}))) "var $dft = undef "if ?$dom{$dir = getShortPath(${ENV.DOMAIN_HOME},true)} " var $dft = findItem('DOM','D_DOMAIN_HOME',$dir,true) "if ?$dft " var ${AUX.dft} = last "else " var ${AUX.dft} = [@itm] "if expr('==',scalar(@itm),1) "{if expr('>=',${CUR.N_LEVEL},${PRF/N_OFM_LEVEL:0}) " var ${AUX.vis} = true " else " {var ${AUX.vis} = false " call unshift(@{AUX.W_NEXT},'domain_comment') " } "} } [domain_comment] typ=C dsc='Report RDA has determined the domain home to collect' inp="\nOracle WebLogic Server domain home target list:\n\ When RDA discovers only one domain home, domain home list selection \ is suppressed.\n\ RDA will target the domain home:\n\ \040'${T_DOMAIN_NAME/P}' (in ${D_DOMAIN_ROOT/P})" vis=false [set_req_domain] typ=B dft=false dsc='Does INFRA require Oracle WebLogic request handler execution?' nam=B_REQ_WREQ exe=sdcl { "var ($flg,%DOMAINS,%USERS) = (false) "keep %DOMAINS,%USERS "loop $tgt (@{I_DOMAINS}) "{var $dir = $tgt->get_first('D_DOMAIN_HOME') " next !grepFile(catFile($dir,'config','config.xml'),'^get_oid " var ${MOD.WREQ_OFM_INFRA_${VAR.oid}.I_DOMAIN:\ " 'Target associated with the domain'} = $tgt " var ${MOD.WREQ_OFM_INFRA_${VAR.oid}.T_TOP_FOCUS:\ " 'Focus areas for Oracle WebLogic Server Middleware collection'} = \ " 'Generic' " if compare('eq',${W_TYPE},'OFF') " var ${MOD.WREQ_OFM_INFRA_${VAR.oid}.T_DOM_FOCUS:\ " 'Focus areas for Oracle WebLogic Server domain collection'} = \ " 'ExtDomCfg,ExtSnmCfg,ExtSrvCfg,MinDomCfg,MinSrvCfg,\ " NodDomCfg,NodDomLog,SrvErr,SrvExc,SrvJvm,WlstOff,WlstOffMB' " else " var ${MOD.WREQ_OFM_INFRA_${VAR.oid}.T_DOM_FOCUS:\ " 'Focus areas for Oracle WebLogic Server domain collection'} = \ " 'ExtDomCfg,ExtSnmCfg,ExtSrvCfg,MinDomCfg,MinSrvCfg,\ " NodDomCfg,NodDomLog,SrvErr,SrvExc,SrvJvm,WlstOn,WlstDomCfg,\ " WlstDomClu,WlstDomRun,WlstDomSrv,WlstSrvCfg,WlstSrvExp,WlstSrvImg,\ " WlstSrvRun,WlstSrvThd,WlstOff,WlstOffMB' " var $DOMAINS{${MOD.WREQ_OFM_INFRA_${VAR.oid}/I}->get_path} = $tgt " var $flg = true "} "var ${AUX.dft} = $flg } [loop_domains] typ=L dft=keys(%DOMAINS) dsc='Iterate on each domain' nam=-RUN/SDSL.K_OID var=loop:T_SERVERS,chk_type #------------------------------------------------------------------------------ # Select the server(s) #------------------------------------------------------------------------------ [T_SERVERS] typ=M bef="\nServer list for '${T_TMP_NAM}' - domain home (in ${D_TMP_DOM}):" def="COL/${RUN.SDSL.K_OID}" dft='*' dsc='Domain server list' itm=[@{T_TMP_ITM}] pck=true val=E exe=sdcl { "var ($tgt,@itm) = ($DOMAINS{${RUN.SDSL.K_OID}}) "if ${PRF/B_OFM_IPS} " call push(@itm,${PRF/T_SERVER},${PRF/T_SERVER}) "elsif exists($SERVERS{$top = $tgt->get_first('D_DOMAIN_HOME')}) "{loop $srv (@{$SERVERS{$top}}) " {if ?testDir('d',catDir($top,'servers',$srv,'logs')) " call push(@itm,$srv,$srv) " } "} "else "{loop $srv (findDir(catDir($top,'servers'),'^[^\.]+$','n')) " {if ?testDir('d',catDir($top,'servers',$srv,'logs')) " call push(@itm,$srv,$srv) " } "} "var ${T_TMP_NAM/T} = $tgt->get_first('T_DOMAIN_NAME') "var ${D_TMP_DOM/T} = \ " catNative($tgt->get_first('D_DOMAIN_ROOT'),${T_TMP_NAM},'') "var @{T_TMP_ITM/T} = @itm "if ${PRF/N_OFM_LEVEL} "{var $cnt = scalar(@itm) " if or(expr('==',$cnt,2),\ " and(expr('==',$cnt,4),grep(@itm,'^AdminServer$','if'))) " {var ${AUX.lvl} = ${PRF/N_OFM_LEVEL} " call unshift(@{AUX.W_NEXT},'server_comment') " } " else " var ${AUX.bef} = "\nServer list for '${T_TMP_NAM}' - domain home \ " (in ${D_TMP_DOM}):\n\ " Two or more managed servers have been discovered." "} } [server_comment] typ=C def="COL/${RUN.SDSL.K_OID}" dsc='Report RDA has determined the server(s) to collect' inp="\nServer list for '${T_TMP_NAM}' - domain home (in ${D_TMP_DOM}):\n\ When RDA discovers only one managed server and/or an AdminServer, server \ list selection is suppressed.\n\ RDA will target the server(s):\n\ ${T_TMP_SERVERS}" # stopwords AdminServer vis=false exe=sdcl { "var ($cnt,$str) = (0) "loop $srv (@{T_SERVERS}) " var $str = join("\n",$str,sprintf(" %d %s",incr($cnt),$srv)) "var ${T_TMP_SERVERS/T} = $str } #------------------------------------------------------------------------------ # Identify the user #------------------------------------------------------------------------------ [chk_type] typ=T dft=${W_TYPE} dsc='Apply the type-related setup' nam=- var=ON:T_USER [T_USER] typ=T def="COL/${RUN.SDSL.K_OID}" dsc='Oracle WebLogic server user name' nam=- ref=is_valid_user('T_USER',last) val=E exe=sdcl { "if ?$USERS{${T_TMP_NAM}} "{var ${AUX.dft} = last " var ${AUX.err} = 'User name cannot be empty and should not contain spacing \ " characters.' " var ${AUX.inp} = "Enter the user name to connect to the AdminServer of \ " '${T_TMP_NAM}' domain (${D_TMP_DOM})" " var ${AUX.lvl} = 3 "} "else "{var $tgt = addTarget($DOMAINS{${RUN.SDSL.K_OID}}) " if !length($usr = $tgt->get_attr('DOMAIN_USER')) " var $usr = 'weblogic' " var ${AUX.dft} = $usr " var ${AUX.err} = 'User name cannot be empty and should not contain spacing \ " characters.' " var ${AUX.inp} = "Enter the user name to connect to the AdminServer of \ " '${T_TMP_NAM}' domain (${D_TMP_DOM})" "} } #------------------------------------------------------------------------------ # Database settings #------------------------------------------------------------------------------ [B_DB_AUTO] typ=B dft=${PRF.B_DB_AUTO:true} dsc='Do you want RDA to get the database connection details automatically?' inp='Do you want RDA to get the database connection details \ automatically (Y/N)?' lvl=6 var=true:T_INFRA_USER,set_target:\ I_DB [T_INFRA_USER] typ=T dft='system' dsc='User to connect to infrastructure database' inp='Enter an Oracle user identifier (user name only) to access infrastructure \ database information.' [set_target] typ=B dsc='Determine the query target' nam=- exe=sdcl { "if !?${I_DB} "{var ($src,$tgt,$usr,%ds) = () " loop $key (keys(%DOMAINS)) " {var $tgt = $DOMAINS{$key} " var $dir = $tgt->get_first('D_DOMAIN_HOME') " next !?$fil = testFile('r',catFile($dir,'config','config.xml')) " call find_datasource(\%ds,$dir,$fil,'LocalSvcTblDataSource') " var ($usr,$src) = get_db_details($obj = \ " xmlLoadFile($ds{'LocalSvcTblDataSource'})) " break $usr " if xmlFind($obj,'jdbc-data-source/jdbc-data-source-params/data-source-list') " {loop $nam (split(',',xmlData(last))) " {call find_datasource(\%ds,$dir,$fil,$nam) " var ($usr,$src) = get_db_details(xmlLoadFile($ds{$nam})) " break $usr " } " } " } " " # Determine the corresponding query target " var $ttl = 'OFM.INFRA queries' " if findItem('DQ',{B_DEDICATED=>true,\ " T_TITLE=>$ttl}) " var $db = defineTarget(last,{I_DRIVER=>$tgt,\ " T_SOURCE=>$src,\ " T_TYPE=>'JDBC',\ " T_USER=>${T_INFRA_USER}}) " else " var $db = defineTarget('DQ',{B_DEDICATED=>true,\ " I_DRIVER=>$tgt,\ " T_SOURCE=>$src,\ " T_TITLE=>$ttl,\ " T_TYPE=>'JDBC',\ " T_USER=>${T_INFRA_USER}}) " var ${I_DB:'Database to analyze'} = $db "} } [I_DB] typ=I cls='DQ' dft=${SET.DB.DB.I_DB} dsc='Database to analyze' exe=sdcl { "var ${RUN.CLASS.DQ.B_LOCAL} = ${B_LOCAL: ${PRF.B_LOCAL}} "var ${RUN.CLASS.DQ.B_SYSDBA} = ${B_SYSDBA: ${PRF.B_SYSDBA}} "var ${RUN.CLASS.DQ.T_SOURCE} = ${T_SOURCE: ${PRF.T_SOURCE}} "var ${RUN.CLASS.DQ.T_USER} = ${T_INFRA_USER:${PRF.T_INFRA_USER}} " "if ${CUR.B_NO_DIALOG} " var ${AUX.dft} = \ " nvl(findItem('DQ',{T_USER =>${RUN.CLASS.DQ.T_USER},\ " T_SOURCE=>${RUN.CLASS.DQ.T_SOURCE}}),\ " defineTarget('DQ',{})) " "var ($src,$tgt,$usr,%ds) = () "loop $key (keys(%DOMAINS)) "{var $tgt = $DOMAINS{$key} " var $dir = $tgt->get_first('D_DOMAIN_HOME') " next !?$fil = testFile('r',catFile($dir,'config','config.xml')) " call find_datasource(\%ds,$dir,$fil,'LocalSvcTblDataSource') " var ($usr,$src) = get_db_details($obj = \ " xmlLoadFile($ds{'LocalSvcTblDataSource'})) " break $usr " if xmlFind($obj,'jdbc-data-source/jdbc-data-source-params/data-source-list') " {loop $nam (split(',',xmlData(last))) " {call find_datasource(\%ds,$dir,$fil,$nam) " var ($usr,$src) = get_db_details(xmlLoadFile($ds{$nam})) " break $usr " } " } " var ${RUN.CLASS.DQ.I_DRIVER} = $tgt "} } #------------------------------------------------------------------------------ # Common settings #------------------------------------------------------------------------------ [I_OHC] typ=I cls='OH' dsc='Target associated with the Oracle home' vis=false