Commit e32a719b4d802681401bc49b24f1097ff173acc9
1 parent
eb8d42dd
Exists in
master
Exclusão para posterior reposição com versão 2.6-Beta-2
git-svn-id: http://svn.softwarepublico.gov.br/svn/cacic/cacic/trunk/agente-windows@961 fecfc0c7-e812-0410-ae72-849f08638ee7
Showing
5 changed files
with
0 additions
and
1199 deletions
Show diff stats
col_hard/col_hard.cfg
| @@ -1,35 +0,0 @@ | @@ -1,35 +0,0 @@ | ||
| 1 | --$A8 | ||
| 2 | --$B- | ||
| 3 | --$C+ | ||
| 4 | --$D+ | ||
| 5 | --$E- | ||
| 6 | --$F- | ||
| 7 | --$G+ | ||
| 8 | --$H+ | ||
| 9 | --$I+ | ||
| 10 | --$J- | ||
| 11 | --$K- | ||
| 12 | --$L+ | ||
| 13 | --$M- | ||
| 14 | --$N+ | ||
| 15 | --$O+ | ||
| 16 | --$P+ | ||
| 17 | --$Q- | ||
| 18 | --$R- | ||
| 19 | --$S- | ||
| 20 | --$T- | ||
| 21 | --$U- | ||
| 22 | --$V+ | ||
| 23 | --$W- | ||
| 24 | --$X+ | ||
| 25 | --$YD | ||
| 26 | --$Z1 | ||
| 27 | --cg | ||
| 28 | --AWinTypes=Windows;WinProcs=Windows;DbiTypes=BDE;DbiProcs=BDE;DbiErrs=BDE; | ||
| 29 | --H+ | ||
| 30 | --W+ | ||
| 31 | --M | ||
| 32 | --$M16384,1048576 | ||
| 33 | --K$00400000 | ||
| 34 | --LE"c:\arquivos de programas\borland\delphi7\Projects\Bpl" | ||
| 35 | --LN"c:\arquivos de programas\borland\delphi7\Projects\Bpl" |
col_hard/col_hard.dof
| @@ -1,136 +0,0 @@ | @@ -1,136 +0,0 @@ | ||
| 1 | -[FileVersion] | ||
| 2 | -Version=7.0 | ||
| 3 | -[Compiler] | ||
| 4 | -A=8 | ||
| 5 | -B=0 | ||
| 6 | -C=1 | ||
| 7 | -D=1 | ||
| 8 | -E=0 | ||
| 9 | -F=0 | ||
| 10 | -G=1 | ||
| 11 | -H=1 | ||
| 12 | -I=1 | ||
| 13 | -J=0 | ||
| 14 | -K=0 | ||
| 15 | -L=1 | ||
| 16 | -M=0 | ||
| 17 | -N=1 | ||
| 18 | -O=1 | ||
| 19 | -P=1 | ||
| 20 | -Q=0 | ||
| 21 | -R=0 | ||
| 22 | -S=0 | ||
| 23 | -T=0 | ||
| 24 | -U=0 | ||
| 25 | -V=1 | ||
| 26 | -W=0 | ||
| 27 | -X=1 | ||
| 28 | -Y=1 | ||
| 29 | -Z=1 | ||
| 30 | -ShowHints=1 | ||
| 31 | -ShowWarnings=1 | ||
| 32 | -UnitAliases=WinTypes=Windows;WinProcs=Windows;DbiTypes=BDE;DbiProcs=BDE;DbiErrs=BDE; | ||
| 33 | -NamespacePrefix= | ||
| 34 | -SymbolDeprecated=1 | ||
| 35 | -SymbolLibrary=1 | ||
| 36 | -SymbolPlatform=1 | ||
| 37 | -UnitLibrary=1 | ||
| 38 | -UnitPlatform=1 | ||
| 39 | -UnitDeprecated=1 | ||
| 40 | -HResultCompat=1 | ||
| 41 | -HidingMember=1 | ||
| 42 | -HiddenVirtual=1 | ||
| 43 | -Garbage=1 | ||
| 44 | -BoundsError=1 | ||
| 45 | -ZeroNilCompat=1 | ||
| 46 | -StringConstTruncated=1 | ||
| 47 | -ForLoopVarVarPar=1 | ||
| 48 | -TypedConstVarPar=1 | ||
| 49 | -AsgToTypedConst=1 | ||
| 50 | -CaseLabelRange=1 | ||
| 51 | -ForVariable=1 | ||
| 52 | -ConstructingAbstract=1 | ||
| 53 | -ComparisonFalse=1 | ||
| 54 | -ComparisonTrue=1 | ||
| 55 | -ComparingSignedUnsigned=1 | ||
| 56 | -CombiningSignedUnsigned=1 | ||
| 57 | -UnsupportedConstruct=1 | ||
| 58 | -FileOpen=1 | ||
| 59 | -FileOpenUnitSrc=1 | ||
| 60 | -BadGlobalSymbol=1 | ||
| 61 | -DuplicateConstructorDestructor=1 | ||
| 62 | -InvalidDirective=1 | ||
| 63 | -PackageNoLink=1 | ||
| 64 | -PackageThreadVar=1 | ||
| 65 | -ImplicitImport=1 | ||
| 66 | -HPPEMITIgnored=1 | ||
| 67 | -NoRetVal=1 | ||
| 68 | -UseBeforeDef=1 | ||
| 69 | -ForLoopVarUndef=1 | ||
| 70 | -UnitNameMismatch=1 | ||
| 71 | -NoCFGFileFound=1 | ||
| 72 | -MessageDirective=1 | ||
| 73 | -ImplicitVariants=1 | ||
| 74 | -UnicodeToLocale=1 | ||
| 75 | -LocaleToUnicode=1 | ||
| 76 | -ImagebaseMultiple=1 | ||
| 77 | -SuspiciousTypecast=1 | ||
| 78 | -PrivatePropAccessor=1 | ||
| 79 | -UnsafeType=1 | ||
| 80 | -UnsafeCode=1 | ||
| 81 | -UnsafeCast=1 | ||
| 82 | -[Linker] | ||
| 83 | -MapFile=0 | ||
| 84 | -OutputObjs=0 | ||
| 85 | -ConsoleApp=1 | ||
| 86 | -DebugInfo=0 | ||
| 87 | -RemoteSymbols=0 | ||
| 88 | -MinStackSize=16384 | ||
| 89 | -MaxStackSize=1048576 | ||
| 90 | -ImageBase=4194304 | ||
| 91 | -ExeDescription= | ||
| 92 | -[Directories] | ||
| 93 | -OutputDir= | ||
| 94 | -UnitOutputDir= | ||
| 95 | -PackageDLLOutputDir= | ||
| 96 | -PackageDCPOutputDir= | ||
| 97 | -SearchPath= | ||
| 98 | -Packages=vcl;rtl;vclx;indy;inet;xmlrtl;vclie;inetdbbde;inetdbxpress;dbrtl;dsnap;dsnapcon;vcldb;soaprtl;VclSmp;dbexpress;dbxcds;inetdb;bdertl;vcldbx;webdsnap;websnap;adortl;ibxpress;teeui;teedb;tee;dss;visualclx;visualdbclx;vclactnband;vclshlctrls;IntrawebDB_50_70;Intraweb_50_70;Rave50CLX;Rave50VCL;dclOfficeXP | ||
| 99 | -Conditionals= | ||
| 100 | -DebugSourceDirs= | ||
| 101 | -UsePackages=0 | ||
| 102 | -[Parameters] | ||
| 103 | -RunParams= | ||
| 104 | -HostApplication= | ||
| 105 | -Launcher= | ||
| 106 | -UseLauncher=0 | ||
| 107 | -DebugCWD= | ||
| 108 | -[Language] | ||
| 109 | -ActiveLang= | ||
| 110 | -ProjectLang= | ||
| 111 | -RootDir= | ||
| 112 | -[Version Info] | ||
| 113 | -IncludeVerInfo=1 | ||
| 114 | -AutoIncBuild=0 | ||
| 115 | -MajorVer=2 | ||
| 116 | -MinorVer=5 | ||
| 117 | -Release=0 | ||
| 118 | -Build=773 | ||
| 119 | -Debug=0 | ||
| 120 | -PreRelease=0 | ||
| 121 | -Special=0 | ||
| 122 | -Private=0 | ||
| 123 | -DLL=0 | ||
| 124 | -Locale=2070 | ||
| 125 | -CodePage=1252 | ||
| 126 | -[Version Info Keys] | ||
| 127 | -CompanyName=Dataprev - Emp. de TI da Prev.Social - URES | ||
| 128 | -FileDescription=Coletor de Informações de Hardware do Sistema CACIC | ||
| 129 | -FileVersion=2.5.0.773 | ||
| 130 | -InternalName= | ||
| 131 | -LegalCopyright= | ||
| 132 | -LegalTrademarks= | ||
| 133 | -OriginalFilename= | ||
| 134 | -ProductName=Col_Hard | ||
| 135 | -ProductVersion=2.6 | ||
| 136 | -Comments=Baseado na licença GPL (General Public License) |
col_hard/col_hard.dpr
| @@ -1,1028 +0,0 @@ | @@ -1,1028 +0,0 @@ | ||
| 1 | -(** | ||
| 2 | ---------------------------------------------------------------------------------------------------------------------------------------------------------------- | ||
| 3 | -Copyright 2000, 2001, 2002, 2003, 2004, 2005 Dataprev - Empresa de Tecnologia e Informações da Previdência Social, Brasil | ||
| 4 | - | ||
| 5 | -Este arquivo é parte do programa CACIC - Configurador Automático e Coletor de Informações Computacionais | ||
| 6 | - | ||
| 7 | -O CACIC é um software livre; você pode redistribui-lo e/ou modifica-lo dentro dos termos da Licença Pública Geral GNU como | ||
| 8 | -publicada pela Fundação do Software Livre (FSF); na versão 2 da Licença, ou (na sua opinião) qualquer versão. | ||
| 9 | - | ||
| 10 | -Este programa é distribuido na esperança que possa ser util, mas SEM NENHUMA GARANTIA; sem uma garantia implicita de ADEQUAÇÂO a qualquer | ||
| 11 | -MERCADO ou APLICAÇÃO EM PARTICULAR. Veja a Licença Pública Geral GNU para maiores detalhes. | ||
| 12 | - | ||
| 13 | -Você deve ter recebido uma cópia da Licença Pública Geral GNU, sob o título "LICENCA.txt", junto com este programa, se não, escreva para a Fundação do Software | ||
| 14 | -Livre(FSF) Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA | ||
| 15 | - | ||
| 16 | -NOTA: O componente MiTeC System Information Component (MSIC) é baseado na classe TComponent e contém alguns subcomponentes baseados na classe TPersistent | ||
| 17 | - Este componente é apenas freeware e não open-source, e foi baixado de http://www.mitec.cz/Downloads/MSIC.zip | ||
| 18 | ---------------------------------------------------------------------------------------------------------------------------------------------------------------- | ||
| 19 | -*) | ||
| 20 | - | ||
| 21 | -program col_hard; | ||
| 22 | -{$R *.res} | ||
| 23 | -{$APPTYPE CONSOLE} | ||
| 24 | - | ||
| 25 | -uses | ||
| 26 | - Windows, | ||
| 27 | - Registry, | ||
| 28 | - SysUtils, | ||
| 29 | - Classes, | ||
| 30 | - IniFiles, | ||
| 31 | - MSI_SMBIOS, | ||
| 32 | - MSI_Devices, | ||
| 33 | - MSI_CPU, | ||
| 34 | - MSI_DISPLAY, | ||
| 35 | - MSI_MEDIA, | ||
| 36 | - MSI_NETWORK, | ||
| 37 | - MSI_XML_Reports, | ||
| 38 | - PJVersionInfo, | ||
| 39 | - CACIC_Library in '..\CACIC_Library.pas'; | ||
| 40 | - | ||
| 41 | -var | ||
| 42 | - v_mensagem, | ||
| 43 | - v_strCipherClosed : String; | ||
| 44 | - v_debugs : boolean; | ||
| 45 | - v_tstrCipherOpened, | ||
| 46 | - v_tstrCipherOpened1, | ||
| 47 | - tstrTripa1 : TStrings; | ||
| 48 | - intAux : integer; | ||
| 49 | - g_oCacic : TCACIC; | ||
| 50 | - | ||
| 51 | - | ||
| 52 | -// Dica baixada de http://www.marcosdellantonio.net/2007/06/14/operador-if-ternario-em-delphi-e-c/ | ||
| 53 | -// Fiz isso para não ter que acrescentar o componente Math ao USES! | ||
| 54 | -function iif(condicao : boolean; resTrue, resFalse : Variant) : Variant; | ||
| 55 | - Begin | ||
| 56 | - if condicao then | ||
| 57 | - Result := resTrue | ||
| 58 | - else | ||
| 59 | - Result := resFalse; | ||
| 60 | - End; | ||
| 61 | - | ||
| 62 | -procedure log_diario(strMsg : String); | ||
| 63 | -var | ||
| 64 | - HistoricoLog : TextFile; | ||
| 65 | - strDataArqLocal, strDataAtual : string; | ||
| 66 | -begin | ||
| 67 | - try | ||
| 68 | - FileSetAttr (g_oCacic.getCacicPath + 'cacic2.log',0); // Retira os atributos do arquivo para evitar o erro FILE ACCESS DENIED em máquinas 2000 | ||
| 69 | - AssignFile(HistoricoLog,g_oCacic.getCacicPath + 'cacic2.log'); {Associa o arquivo a uma variável do tipo TextFile} | ||
| 70 | - {$IOChecks off} | ||
| 71 | - Reset(HistoricoLog); {Abre o arquivo texto} | ||
| 72 | - {$IOChecks on} | ||
| 73 | - if (IOResult <> 0) then // Arquivo não existe, será recriado. | ||
| 74 | - begin | ||
| 75 | - Rewrite (HistoricoLog); | ||
| 76 | - Append(HistoricoLog); | ||
| 77 | - Writeln(HistoricoLog,FormatDateTime('dd/mm hh:nn:ss : ', Now) + '======================> Iniciando o Log <======================='); | ||
| 78 | - end; | ||
| 79 | - DateTimeToString(strDataArqLocal, 'yyyymmdd', FileDateToDateTime(Fileage(g_oCacic.getCacicPath + 'cacic2.log'))); | ||
| 80 | - DateTimeToString(strDataAtual , 'yyyymmdd', Date); | ||
| 81 | - if (strDataAtual <> strDataArqLocal) then // Se o arquivo INI não é da data atual... | ||
| 82 | - begin | ||
| 83 | - Rewrite (HistoricoLog); //Cria/Recria o arquivo | ||
| 84 | - Append(HistoricoLog); | ||
| 85 | - Writeln(HistoricoLog,FormatDateTime('dd/mm hh:nn:ss : ', Now) + '======================> Iniciando o Log <======================='); | ||
| 86 | - end; | ||
| 87 | - Append(HistoricoLog); | ||
| 88 | - Writeln(HistoricoLog,FormatDateTime('dd/mm hh:nn:ss : ', Now)+ '[Coletor HARD] '+strMsg); {Grava a string Texto no arquivo texto} | ||
| 89 | - CloseFile(HistoricoLog); {Fecha o arquivo texto} | ||
| 90 | -// FileSetAttr (ExtractFilePath(Application.Exename) + '\cacic2.log',6); // Muda o atributo para arquivo de SISTEMA e OCULTO | ||
| 91 | - | ||
| 92 | - except | ||
| 93 | - log_diario('Erro na gravação do log!'); | ||
| 94 | - end; | ||
| 95 | -end; | ||
| 96 | - | ||
| 97 | - | ||
| 98 | - | ||
| 99 | -Function CipherClose(p_DatFileName : string; p_tstrCipherOpened : TStrings) : String; | ||
| 100 | -var v_strCipherOpenImploded : string; | ||
| 101 | - v_DatFile : TextFile; | ||
| 102 | -begin | ||
| 103 | - try | ||
| 104 | - FileSetAttr (p_DatFileName,0); // Retira os atributos do arquivo para evitar o erro FILE ACCESS DENIED em máquinas 2000 | ||
| 105 | - AssignFile(v_DatFile,p_DatFileName); {Associa o arquivo a uma variável do tipo TextFile} | ||
| 106 | - | ||
| 107 | - // Criação do arquivo .DAT | ||
| 108 | - Rewrite (v_DatFile); | ||
| 109 | - Append(v_DatFile); | ||
| 110 | - | ||
| 111 | - v_strCipherOpenImploded := g_oCacic.implode(p_tstrCipherOpened,g_oCacic.getSeparatorKey); | ||
| 112 | - v_strCipherClosed := g_oCacic.enCrypt(v_strCipherOpenImploded); | ||
| 113 | - | ||
| 114 | - Writeln(v_DatFile,v_strCipherClosed); {Grava a string Texto no arquivo texto} | ||
| 115 | - | ||
| 116 | - CloseFile(v_DatFile); | ||
| 117 | - except | ||
| 118 | - end; | ||
| 119 | -end; | ||
| 120 | - | ||
| 121 | -Function CipherOpen(p_DatFileName : string) : TStrings; | ||
| 122 | -var v_DatFile : TextFile; | ||
| 123 | - v_strCipherOpened, | ||
| 124 | - v_strCipherClosed : string; | ||
| 125 | -begin | ||
| 126 | - v_strCipherOpened := ''; | ||
| 127 | - if FileExists(p_DatFileName) then | ||
| 128 | - begin | ||
| 129 | - AssignFile(v_DatFile,p_DatFileName); | ||
| 130 | - {$IOChecks off} | ||
| 131 | - Reset(v_DatFile); | ||
| 132 | - {$IOChecks on} | ||
| 133 | - if (IOResult <> 0) then // Arquivo não existe, será recriado. | ||
| 134 | - begin | ||
| 135 | - Rewrite (v_DatFile); | ||
| 136 | - Append(v_DatFile); | ||
| 137 | - end; | ||
| 138 | - | ||
| 139 | - Readln(v_DatFile,v_strCipherClosed); | ||
| 140 | - while not EOF(v_DatFile) do Readln(v_DatFile,v_strCipherClosed); | ||
| 141 | - CloseFile(v_DatFile); | ||
| 142 | - v_strCipherOpened:= g_oCacic.deCrypt(v_strCipherClosed); | ||
| 143 | - end; | ||
| 144 | - if (trim(v_strCipherOpened)<>'') then | ||
| 145 | - Result := g_oCacic.explode(v_strCipherOpened,g_oCacic.getSeparatorKey) | ||
| 146 | - else | ||
| 147 | - Result := g_oCacic.explode('Configs.ID_SO' + g_oCacic.getSeparatorKey + g_oCacic.getWindowsStrId + g_oCacic.getSeparatorKey + 'Configs.Endereco_WS'+g_oCacic.getSeparatorKey+'/cacic2/ws/',g_oCacic.getSeparatorKey); | ||
| 148 | - | ||
| 149 | - if Result.Count mod 2 <> 0 then | ||
| 150 | - Result.Add(''); | ||
| 151 | -end; | ||
| 152 | - | ||
| 153 | -Procedure SetValorDatMemoria(p_Chave : string; p_Valor : String; p_tstrCipherOpened : TStrings); | ||
| 154 | -begin | ||
| 155 | - // Exemplo: p_Chave => Configs.nu_ip_servidor : p_Valor => 10.71.0.120 | ||
| 156 | - if (p_tstrCipherOpened.IndexOf(p_Chave)<>-1) then | ||
| 157 | - p_tstrCipherOpened[v_tstrCipherOpened.IndexOf(p_Chave)+1] := p_Valor | ||
| 158 | - else | ||
| 159 | - Begin | ||
| 160 | - p_tstrCipherOpened.Add(p_Chave); | ||
| 161 | - p_tstrCipherOpened.Add(p_Valor); | ||
| 162 | - End; | ||
| 163 | -end; | ||
| 164 | -Function GetValorDatMemoria(p_Chave : String; p_tstrCipherOpened : TStrings) : String; | ||
| 165 | -begin | ||
| 166 | - if (p_tstrCipherOpened.IndexOf(p_Chave)<>-1) then | ||
| 167 | - Result := p_tstrCipherOpened[p_tstrCipherOpened.IndexOf(p_Chave)+1] | ||
| 168 | - else | ||
| 169 | - Result := ''; | ||
| 170 | -end; | ||
| 171 | -function VerFmt(const MS, LS: DWORD): string; | ||
| 172 | - // Format the version number from the given DWORDs containing the info | ||
| 173 | -begin | ||
| 174 | - Result := Format('%d.%d.%d.%d', | ||
| 175 | - [HiWord(MS), LoWord(MS), HiWord(LS), LoWord(LS)]) | ||
| 176 | -end; | ||
| 177 | - | ||
| 178 | -function GetVersionInfo(p_File: string):string; | ||
| 179 | -var PJVersionInfo1: TPJVersionInfo; | ||
| 180 | -begin | ||
| 181 | - PJVersionInfo1 := TPJVersionInfo.Create(nil); | ||
| 182 | - PJVersionInfo1.FileName := PChar(p_File); | ||
| 183 | - Result := VerFmt(PJVersionInfo1.FixedFileInfo.dwFileVersionMS, PJVersionInfo1.FixedFileInfo.dwFileVersionLS); | ||
| 184 | - PJVersionInfo1.Free; | ||
| 185 | -end; | ||
| 186 | - | ||
| 187 | -procedure log_DEBUG(p_msg:string); | ||
| 188 | -Begin | ||
| 189 | - if v_Debugs then log_diario('(v.'+getVersionInfo(ParamStr(0))+') DEBUG - '+p_msg); | ||
| 190 | -End; | ||
| 191 | - | ||
| 192 | -// Função criada devido a divergências entre os valores retornados pelos métodos dos componentes MSI e seus Reports. | ||
| 193 | -function Parse(p_ClassName, p_SectionName, p_DataName:string; p_Report : TStringList) : String; | ||
| 194 | -var intClasses, intSections, intDatas, v_achei_SectionName, v_array_SectionName_Count : integer; | ||
| 195 | - v_ClassName, v_DataName, v_string_consulta : string; | ||
| 196 | - v_array_SectionName : tstrings; | ||
| 197 | -begin | ||
| 198 | - Log_DEBUG('p_ClassName => "'+p_ClassName+'" p_SectionName => "'+p_SectionName+'" p_DataName => "'+p_DataName+'"'); | ||
| 199 | - Result := ''; | ||
| 200 | - if (p_SectionName <> '') then | ||
| 201 | - Begin | ||
| 202 | - v_array_SectionName := g_oCacic.explode(p_SectionName,'/'); | ||
| 203 | - v_array_SectionName_Count := v_array_SectionName.Count; | ||
| 204 | - End | ||
| 205 | - else v_array_SectionName_Count := 0; | ||
| 206 | - | ||
| 207 | - v_achei_SectionName := 0; | ||
| 208 | - v_ClassName := 'classname="' + p_ClassName + '">'; | ||
| 209 | - v_DataName := '<data name="' + p_DataName + '"'; | ||
| 210 | - intClasses := 0; | ||
| 211 | - try | ||
| 212 | - While intClasses < p_Report.Count Do | ||
| 213 | - Begin | ||
| 214 | - if (pos(v_ClassName,p_Report[intClasses])>0) then | ||
| 215 | - Begin | ||
| 216 | - intSections := intClasses; | ||
| 217 | - While intSections < p_Report.Count Do | ||
| 218 | - Begin | ||
| 219 | - | ||
| 220 | - if (p_SectionName<>'') then | ||
| 221 | - Begin | ||
| 222 | - v_string_consulta := '<section name="' + v_array_SectionName[v_achei_SectionName]+'">'; | ||
| 223 | - if (pos(v_string_consulta,p_Report[intSections])>0) then v_achei_SectionName := v_achei_SectionName+1; | ||
| 224 | - End; | ||
| 225 | - | ||
| 226 | - if (v_achei_SectionName = v_array_SectionName_Count) then | ||
| 227 | - Begin | ||
| 228 | - | ||
| 229 | - intDatas := intSections; | ||
| 230 | - While intDatas < p_Report.Count Do | ||
| 231 | - Begin | ||
| 232 | - | ||
| 233 | - if (pos(v_DataName,p_Report[intDatas])>0) then | ||
| 234 | - Begin | ||
| 235 | - Result := Copy(p_Report[intDatas],pos('>',p_Report[intDatas])+1,length(p_Report[intDatas])); | ||
| 236 | - Result := StringReplace(Result,'</data>','',[rfReplaceAll]); | ||
| 237 | - intClasses := p_Report.Count; | ||
| 238 | - intSections := p_Report.Count; | ||
| 239 | - intDatas := p_Report.Count; | ||
| 240 | - End; | ||
| 241 | - intDatas := intDatas + 1; | ||
| 242 | - End; //for intDatas... | ||
| 243 | - End; // if pos(v_SectionName... | ||
| 244 | - intSections := intSections + 1; | ||
| 245 | - End; // for intSections... | ||
| 246 | - End; // if pos(v_ClassName... | ||
| 247 | - intClasses := intClasses + 1; | ||
| 248 | - End; // for intClasses... | ||
| 249 | - except | ||
| 250 | - Begin | ||
| 251 | - log_diario('ERRO! Problema na rotina parse'); | ||
| 252 | - End; | ||
| 253 | - end; | ||
| 254 | - end; | ||
| 255 | - | ||
| 256 | -function GetFolderDate(Folder: string): TDateTime; | ||
| 257 | -var | ||
| 258 | - Rec: TSearchRec; | ||
| 259 | - Found: Integer; | ||
| 260 | - Date: TDateTime; | ||
| 261 | -begin | ||
| 262 | - if Folder[Length(folder)] = '\' then | ||
| 263 | - Delete(Folder, Length(folder), 1); | ||
| 264 | - Result := 0; | ||
| 265 | - Found := FindFirst(Folder, faDirectory, Rec); | ||
| 266 | - try | ||
| 267 | - if Found = 0 then | ||
| 268 | - begin | ||
| 269 | - Date := FileDateToDateTime(Rec.Time); | ||
| 270 | - Result := Date; | ||
| 271 | - end; | ||
| 272 | - finally | ||
| 273 | - FindClose(Rec); | ||
| 274 | - end; | ||
| 275 | -end; | ||
| 276 | - | ||
| 277 | -procedure Grava_Debugs(strMsg : String); | ||
| 278 | -var | ||
| 279 | - DebugsFile : TextFile; | ||
| 280 | - strDataArqLocal, strDataAtual, v_file_debugs : string; | ||
| 281 | -begin | ||
| 282 | - try | ||
| 283 | - v_file_debugs := g_oCacic.getCacicPath + 'Temp\Debugs\debug_'+StringReplace(ExtractFileName(StrUpper(PChar(ParamStr(0)))),'.EXE','',[rfReplaceAll])+'.txt'; | ||
| 284 | - FileSetAttr (v_file_debugs,0); // Retira os atributos do arquivo para evitar o erro FILE ACCESS DENIED em máquinas 2000 | ||
| 285 | - AssignFile(DebugsFile,v_file_debugs); {Associa o arquivo a uma variável do tipo TextFile} | ||
| 286 | - | ||
| 287 | - {$IOChecks off} | ||
| 288 | - Reset(DebugsFile); {Abre o arquivo texto} | ||
| 289 | - {$IOChecks on} | ||
| 290 | - | ||
| 291 | - if (IOResult <> 0) then // Arquivo não existe, será recriado. | ||
| 292 | - begin | ||
| 293 | - Rewrite(DebugsFile); | ||
| 294 | - Append(DebugsFile); | ||
| 295 | - Writeln(DebugsFile,FormatDateTime('dd/mm hh:nn:ss : ', Now) + '======================> Iniciando o Debug <======================='); | ||
| 296 | - end; | ||
| 297 | - DateTimeToString(strDataArqLocal, 'yyyymmdd', FileDateToDateTime(Fileage(v_file_debugs))); | ||
| 298 | - DateTimeToString(strDataAtual , 'yyyymmdd', Date); | ||
| 299 | - | ||
| 300 | - if (strDataAtual <> strDataArqLocal) then // Se o arquivo não é da data atual... | ||
| 301 | - begin | ||
| 302 | - Rewrite(DebugsFile); //Cria/Recria o arquivo | ||
| 303 | - Append(DebugsFile); | ||
| 304 | - Writeln(DebugsFile,FormatDateTime('dd/mm hh:nn:ss : ', Now) + '======================> Iniciando o Debug <======================='); | ||
| 305 | - end; | ||
| 306 | - | ||
| 307 | - Append(DebugsFile); | ||
| 308 | - Writeln(DebugsFile,FormatDateTime('dd/mm hh:nn:ss : ', Now) + strMsg); {Grava a string Texto no arquivo texto} | ||
| 309 | - CloseFile(DebugsFile); {Fecha o arquivo texto} | ||
| 310 | - except | ||
| 311 | - log_diario('Erro na gravação do Debug!'); | ||
| 312 | - end; | ||
| 313 | -end; | ||
| 314 | - | ||
| 315 | - | ||
| 316 | - | ||
| 317 | -// Converte caracteres básicos da tabela Ansi para Ascii | ||
| 318 | -// Solução temporária. | ||
| 319 | -function AnsiToAscii( StrANSI: String ): String; | ||
| 320 | -var i: Integer; | ||
| 321 | - StrASCII, Carac : string; | ||
| 322 | - Letras_ANSI : array[150..255] of String; | ||
| 323 | -begin | ||
| 324 | - Letras_ANSI[150] := ' '; | ||
| 325 | - Letras_ANSI[169] := '©'; | ||
| 326 | - Letras_ANSI[174] := '®'; | ||
| 327 | - Letras_ANSI[181] := 'µ'; | ||
| 328 | - Letras_ANSI[192] := 'A'; | ||
| 329 | - Letras_ANSI[193] := 'A'; | ||
| 330 | - Letras_ANSI[194] := 'A'; | ||
| 331 | - Letras_ANSI[195] := 'A'; | ||
| 332 | - Letras_ANSI[196] := 'A'; | ||
| 333 | - Letras_ANSI[197] := 'A'; | ||
| 334 | - Letras_ANSI[198] := 'A'; | ||
| 335 | - Letras_ANSI[199] := 'C'; | ||
| 336 | - Letras_ANSI[200] := 'E'; | ||
| 337 | - Letras_ANSI[201] := 'E'; | ||
| 338 | - Letras_ANSI[202] := 'E'; | ||
| 339 | - Letras_ANSI[203] := 'E'; | ||
| 340 | - Letras_ANSI[204] := 'I'; | ||
| 341 | - Letras_ANSI[205] := 'I'; | ||
| 342 | - Letras_ANSI[206] := 'I'; | ||
| 343 | - Letras_ANSI[207] := 'I'; | ||
| 344 | - Letras_ANSI[208] := 'D'; | ||
| 345 | - Letras_ANSI[209] := 'N'; | ||
| 346 | - Letras_ANSI[210] := 'O'; | ||
| 347 | - Letras_ANSI[211] := 'O'; | ||
| 348 | - Letras_ANSI[212] := 'O'; | ||
| 349 | - Letras_ANSI[213] := 'O'; | ||
| 350 | - Letras_ANSI[214] := 'O'; | ||
| 351 | - Letras_ANSI[215] := 'x'; | ||
| 352 | - Letras_ANSI[216] := 'O'; | ||
| 353 | - Letras_ANSI[217] := 'U'; | ||
| 354 | - Letras_ANSI[218] := 'U'; | ||
| 355 | - Letras_ANSI[219] := 'U'; | ||
| 356 | - Letras_ANSI[220] := 'U'; | ||
| 357 | - Letras_ANSI[221] := 'Y'; | ||
| 358 | - Letras_ANSI[222] := 'd'; | ||
| 359 | - Letras_ANSI[223] := 'b'; | ||
| 360 | - Letras_ANSI[224] := 'a'; | ||
| 361 | - Letras_ANSI[225] := 'a'; | ||
| 362 | - Letras_ANSI[226] := 'a'; | ||
| 363 | - Letras_ANSI[227] := 'a'; | ||
| 364 | - Letras_ANSI[228] := 'a'; | ||
| 365 | - Letras_ANSI[229] := 'a'; | ||
| 366 | - Letras_ANSI[230] := 'a'; | ||
| 367 | - Letras_ANSI[231] := 'c'; | ||
| 368 | - Letras_ANSI[232] := 'e'; | ||
| 369 | - Letras_ANSI[233] := 'e'; | ||
| 370 | - Letras_ANSI[234] := 'e'; | ||
| 371 | - Letras_ANSI[235] := 'e'; | ||
| 372 | - Letras_ANSI[236] := 'i'; | ||
| 373 | - Letras_ANSI[237] := 'i'; | ||
| 374 | - Letras_ANSI[238] := 'i'; | ||
| 375 | - Letras_ANSI[239] := 'i'; | ||
| 376 | - Letras_ANSI[240] := 'o'; | ||
| 377 | - Letras_ANSI[241] := 'n'; | ||
| 378 | - Letras_ANSI[242] := 'o'; | ||
| 379 | - Letras_ANSI[243] := 'o'; | ||
| 380 | - Letras_ANSI[244] := 'o'; | ||
| 381 | - Letras_ANSI[245] := 'o'; | ||
| 382 | - Letras_ANSI[246] := 'o'; | ||
| 383 | - Letras_ANSI[247] := 'o'; | ||
| 384 | - Letras_ANSI[248] := 'o'; | ||
| 385 | - Letras_ANSI[249] := 'u'; | ||
| 386 | - Letras_ANSI[250] := 'u'; | ||
| 387 | - Letras_ANSI[251] := 'u'; | ||
| 388 | - Letras_ANSI[252] := 'u'; | ||
| 389 | - Letras_ANSI[253] := 'y'; | ||
| 390 | - Letras_ANSI[254] := 'b'; | ||
| 391 | - Letras_ANSI[255] := 'y'; | ||
| 392 | - | ||
| 393 | - i := 1; | ||
| 394 | - StrASCII := ''; | ||
| 395 | - while (i <= Length(StrANSI)) do | ||
| 396 | - begin | ||
| 397 | - if (Copy(StrANSI,i,2)='&#') then | ||
| 398 | - Begin | ||
| 399 | - Carac := Letras_ANSI[StrToInt(Copy(StrANSI,i+2,3))]; | ||
| 400 | - i := i+ 5; | ||
| 401 | - End | ||
| 402 | - else if (Copy(StrANSI,i,4)='>') then | ||
| 403 | - Begin | ||
| 404 | - Carac := '?'; | ||
| 405 | - i := i+ 3; | ||
| 406 | - End | ||
| 407 | - else if (Copy(StrANSI,i,6)='"') then | ||
| 408 | - Begin | ||
| 409 | - Carac := '-'; | ||
| 410 | - i := i+ 5; | ||
| 411 | - End | ||
| 412 | - else if (Copy(StrANSI,i,6)=''') then | ||
| 413 | - Begin | ||
| 414 | - Carac := ''; | ||
| 415 | - i := i+ 5; | ||
| 416 | - End | ||
| 417 | - else if (Copy(StrANSI,i,5)='&') then | ||
| 418 | - Begin | ||
| 419 | - Carac := ''; | ||
| 420 | - i := i+ 4; | ||
| 421 | - End | ||
| 422 | - else Carac := Copy(StrANSI,i,1); | ||
| 423 | - StrASCII := StrASCII + Carac; | ||
| 424 | - i := i+1; | ||
| 425 | - End; | ||
| 426 | - Result := StrASCII; | ||
| 427 | -end; | ||
| 428 | -// Baixada de http://www.geocities.com/SiliconValley/Bay/1058/fdelphi.html | ||
| 429 | -Function Rat(OQue: String; Onde: String) : Integer; | ||
| 430 | -// Procura uma string dentro de outra, da direita para esquerda | ||
| 431 | -// Retorna a posição onde foi encontrada ou 0 caso não seja encontrada | ||
| 432 | -var | ||
| 433 | -Pos : Integer; | ||
| 434 | -Tam1 : Integer; | ||
| 435 | -Tam2 : Integer; | ||
| 436 | -Achou : Boolean; | ||
| 437 | -begin | ||
| 438 | -Tam1 := Length(OQue); | ||
| 439 | -Tam2 := Length(Onde); | ||
| 440 | -Pos := Tam2-Tam1+1; | ||
| 441 | -Achou := False; | ||
| 442 | -while (Pos >= 1) and not Achou do | ||
| 443 | - begin | ||
| 444 | - if Copy(Onde, Pos, Tam1) = OQue then | ||
| 445 | - begin | ||
| 446 | - Achou := True | ||
| 447 | - end | ||
| 448 | - else | ||
| 449 | - begin | ||
| 450 | - Pos := Pos - 1; | ||
| 451 | - end; | ||
| 452 | - end; | ||
| 453 | -Result := Pos; | ||
| 454 | -end; | ||
| 455 | - | ||
| 456 | -Function TrataExcecoesMacAddress(p_mac:String; p_excecao:String): String; | ||
| 457 | -var tstrEXCECOES : TStrings; | ||
| 458 | -var intAux1, v_conta_EXCECOES : integer; | ||
| 459 | - | ||
| 460 | -Begin | ||
| 461 | - Result := ''; | ||
| 462 | - v_conta_EXCECOES := 0; | ||
| 463 | - if (p_excecao <> '') then | ||
| 464 | - Begin | ||
| 465 | - tstrEXCECOES := g_oCacic.explode(p_excecao,','); // Excecoes a serem tratadas | ||
| 466 | - for intAux1 := 0 to tstrEXCECOES.Count-1 Do | ||
| 467 | - Begin | ||
| 468 | - if (rat(tstrEXCECOES[intAux1],p_mac) > 0) then | ||
| 469 | - Begin | ||
| 470 | - v_conta_EXCECOES := 1; | ||
| 471 | - break; | ||
| 472 | - End; | ||
| 473 | - End; | ||
| 474 | - End; | ||
| 475 | - if (v_conta_EXCECOES = 0) then | ||
| 476 | - Begin | ||
| 477 | - Result := p_mac; | ||
| 478 | - End; | ||
| 479 | -End; | ||
| 480 | - | ||
| 481 | -procedure Executa_Col_Hard; | ||
| 482 | -var v_te_cpu_fabricante, | ||
| 483 | - v_te_cpu_desc, | ||
| 484 | - v_te_cpu_serial, | ||
| 485 | - v_te_cpu_frequencia, | ||
| 486 | - v_te_placa_rede_desc, | ||
| 487 | - v_te_placa_som_desc, | ||
| 488 | - v_te_cdrom_desc, | ||
| 489 | - v_te_teclado_desc, | ||
| 490 | - v_te_modem_desc, | ||
| 491 | - v_te_mouse_desc, | ||
| 492 | - v_te_mem_ram_desc, | ||
| 493 | - v_te_mem_ram_tipo, | ||
| 494 | - v_qt_placa_video_mem, | ||
| 495 | - v_te_placa_video_resolucao, | ||
| 496 | - v_te_placa_video_desc, | ||
| 497 | - v_qt_placa_video_cores, | ||
| 498 | - v_te_bios_fabricante, | ||
| 499 | - v_te_bios_data, | ||
| 500 | - v_te_bios_desc, | ||
| 501 | - v_te_placa_mae_fabricante, | ||
| 502 | - v_te_placa_mae_desc, | ||
| 503 | - UVC, | ||
| 504 | - ValorChaveRegistro, | ||
| 505 | - v_DataName, | ||
| 506 | - v_SectionName, | ||
| 507 | - v_Macs_Invalidos, | ||
| 508 | - v_Mac_Address, | ||
| 509 | - v_Tripa_CDROM, | ||
| 510 | - v_Tripa_TCPIP, | ||
| 511 | - v_Tripa_CPU, | ||
| 512 | - strAux, | ||
| 513 | - v_PhysicalAddress, | ||
| 514 | - v_IPAddress, | ||
| 515 | - v_IPMask, | ||
| 516 | - v_Gateway_IPAddress, | ||
| 517 | - v_DHCP_IPAddress, | ||
| 518 | - v_PrimaryWINS_IPAddress, | ||
| 519 | - v_SecondaryWINS_IPAddress : String; | ||
| 520 | - i, j, count : Integer; | ||
| 521 | - v_qt_mem_ram : WORD; | ||
| 522 | - v_CPU : TMiTeC_CPU; | ||
| 523 | - v_DISPLAY : TMiTeC_Display; | ||
| 524 | - v_MEDIA : TMiTeC_Media; | ||
| 525 | - v_DEVICES : TMiTeC_Devices; | ||
| 526 | - v_TCP : TMiTeC_TCPIP; | ||
| 527 | - v_SMBIOS : TMiTeC_SMBIOS; | ||
| 528 | - v_MemoriaRAM : TMemoryStatus; | ||
| 529 | - v_Report, | ||
| 530 | - v_tstrCPU, | ||
| 531 | - v_tstrCDROM, | ||
| 532 | - v_tstrTCPIP : TStringList; | ||
| 533 | - | ||
| 534 | - v_cpu_freq : TStrings; | ||
| 535 | - v_registry : TRegistry; | ||
| 536 | - | ||
| 537 | -begin | ||
| 538 | - | ||
| 539 | - v_Debugs := false; | ||
| 540 | - if DirectoryExists(g_oCacic.getCacicPath + 'Temp\Debugs') then | ||
| 541 | - Begin | ||
| 542 | - if (FormatDateTime('ddmmyyyy', GetFolderDate(g_oCacic.getCacicPath + 'Temp\Debugs')) = FormatDateTime('ddmmyyyy', date)) then | ||
| 543 | - Begin | ||
| 544 | - v_Debugs := true; | ||
| 545 | - //log_diario('Pasta "' + g_oCacic.getCacicPath + 'Temp\Debugs" com data '+FormatDateTime('dd-mm-yyyy', GetFolderDate(g_oCacic.getCacicPath + 'Temp\Debugs'))+' encontrada. DEBUG ativado.'); | ||
| 546 | - End; | ||
| 547 | - End; | ||
| 548 | - | ||
| 549 | - Try | ||
| 550 | - SetValorDatMemoria('Col_Hard.Inicio', FormatDateTime('hh:nn:ss', Now), v_tstrCipherOpened1); | ||
| 551 | - v_Report := TStringList.Create; | ||
| 552 | - log_diario('Coletando informações de Hardware.'); | ||
| 553 | - | ||
| 554 | - v_cpu_freq := TStringList.Create; | ||
| 555 | - v_tstrCPU := TStringList.Create; | ||
| 556 | - v_tstrCDROM := TStringList.Create; | ||
| 557 | - v_tstrTCPIP := TStringList.Create; | ||
| 558 | - | ||
| 559 | - Try | ||
| 560 | - Begin | ||
| 561 | - Log_Debug('Instanciando SMBIOS para obter frequencia de CPU...'); | ||
| 562 | - v_SMBIOS := TMiTeC_SMBIOS.Create(nil); | ||
| 563 | - v_SMBIOS.RefreshData; | ||
| 564 | - v_te_cpu_frequencia := 'ND'; | ||
| 565 | - if(v_SMBIOS.Processor[0].Frequency > 0) then | ||
| 566 | - v_te_cpu_frequencia := inttostr(v_SMBIOS.Processor[0].Frequency) + 'Mhz' // Frequancia de CPU via BIOS | ||
| 567 | - else begin | ||
| 568 | - v_registry := TRegistry.Create; | ||
| 569 | - try | ||
| 570 | - v_registry.RootKey := HKEY_LOCAL_MACHINE; | ||
| 571 | - try | ||
| 572 | - if(v_registry.Openkey('HARDWARE\DESCRIPTION\System\CentralProcessor\0\', False)) then begin | ||
| 573 | - v_te_cpu_frequencia := inttostr(v_registry.ReadInteger('~MHz'))+'Mhz'; // Frequencia de CPU via Regitry | ||
| 574 | - v_registry.CloseKey; | ||
| 575 | - end; | ||
| 576 | - except | ||
| 577 | - log_diario('CPU - informação de frequência ['+v_te_cpu_frequencia+'] não disponível (by SMBIOS/Registry): '); | ||
| 578 | - end; | ||
| 579 | - finally | ||
| 580 | - v_registry.Free; | ||
| 581 | - end; | ||
| 582 | - end; | ||
| 583 | - v_SMBIOS.Free; | ||
| 584 | - | ||
| 585 | - Log_Debug('CPU - frequência estática (by SMBIOS/Registry): '+v_te_cpu_frequencia); | ||
| 586 | - | ||
| 587 | - Log_Debug('Instanciando v_CPU...'); | ||
| 588 | - v_CPU := TMiTeC_CPU.Create(nil); | ||
| 589 | - Log_Debug('Atualização de dados de CPU...'); | ||
| 590 | - v_CPU.RefreshData; | ||
| 591 | - Log_Debug('Dados de CPU atualizados - OK!'); | ||
| 592 | - | ||
| 593 | - // Obtem dados de CPU | ||
| 594 | - Try | ||
| 595 | - for i:=0 to v_CPU.CPUCount-1 do begin | ||
| 596 | - v_te_cpu_serial := v_CPU.SerialNumber; | ||
| 597 | - v_te_cpu_desc := v_CPU.CPUName; | ||
| 598 | - if(v_te_cpu_desc = '') then | ||
| 599 | - v_te_cpu_desc := v_CPU.MarketingName; | ||
| 600 | - | ||
| 601 | - v_te_cpu_fabricante := cVendorNames[v_CPU.Vendor].Prefix; | ||
| 602 | - | ||
| 603 | - Log_Debug('CPU - frequência dinâmica (by CPU): '+inttostr(v_CPU.Frequency) + 'Mhz'); | ||
| 604 | - | ||
| 605 | - // Se pegou ao menos a descrição, adiciona-se à tripa... | ||
| 606 | - if (v_te_cpu_desc <> '') then | ||
| 607 | - Begin | ||
| 608 | - v_tstrCPU.Add('te_cpu_desc###' + v_te_cpu_desc + '#FIELD#' + | ||
| 609 | - 'te_cpu_fabricante###' + v_te_cpu_fabricante + '#FIELD#' + | ||
| 610 | - 'te_cpu_serial###' + v_te_cpu_serial + '#FIELD#' + | ||
| 611 | - 'te_cpu_frequencia###' + v_te_cpu_frequencia); | ||
| 612 | - Log_Debug('Adicionando a tstrCPU: "'+v_tstrCPU[v_tstrCPU.count-1]); | ||
| 613 | - Log_DEBUG('Tamanho de v_tstrCPU 0: '+intToStr(v_tstrCPU.Count)); | ||
| 614 | - End; | ||
| 615 | - end; | ||
| 616 | - Except | ||
| 617 | - log_diario('Problemas ao coletar dados de CPU!'); | ||
| 618 | - end; | ||
| 619 | - v_CPU.Free; | ||
| 620 | - Log_DEBUG('Tamanho de v_tstrCPU 1: '+intToStr(v_tstrCPU.Count)); | ||
| 621 | - | ||
| 622 | - // Media informations | ||
| 623 | - Try | ||
| 624 | - v_MEDIA := TMiTeC_Media.Create(nil); | ||
| 625 | - v_MEDIA.RefreshData; | ||
| 626 | - if v_Media.SoundCardIndex>-1 then begin | ||
| 627 | - //n:=Tree.Items.AddChild(r,Media.Devices[Media.SoundCardIndex]); | ||
| 628 | - v_te_placa_som_desc := v_Media.Devices[v_Media.SoundCardIndex]; | ||
| 629 | - end; | ||
| 630 | - except log_diario('Problemas ao coletar dados de Aúdio'); | ||
| 631 | - end; | ||
| 632 | - | ||
| 633 | - Log_Debug('Dados de aúdio coletados - OK!'); | ||
| 634 | - | ||
| 635 | - // Devices informations | ||
| 636 | - Try | ||
| 637 | - Log_Debug('Instanciando v_DEVICES...'); | ||
| 638 | - v_DEVICES := TMiTeC_Devices.Create(nil); | ||
| 639 | - Log_Debug('RefreshingData...'); | ||
| 640 | - v_DEVICES.RefreshData; | ||
| 641 | - if v_Debugs then MSI_XML_Reports.Devices_XML_Report(v_DEVICES,TRUE,v_Report); | ||
| 642 | - Log_Debug('v_DEVICES.DeviceCount = '+intToStr(v_DEVICES.DeviceCount)); | ||
| 643 | - i := 0; | ||
| 644 | - While i < v_DEVICES.DeviceCount do | ||
| 645 | - Begin | ||
| 646 | - v_mensagem := 'Obtendo Descrição de CDROM'; | ||
| 647 | - Log_Debug('Percorrendo v_DEVICES.Devices['+intToStr(i)+']...'); | ||
| 648 | - | ||
| 649 | - if v_DEVICES.Devices[i].DeviceClass=dcCDROM then | ||
| 650 | - Begin | ||
| 651 | - // Vamos tentar de tudo! :)))) | ||
| 652 | - v_te_cdrom_desc := Trim(v_DEVICES.Devices[i].Name); | ||
| 653 | - if Trim(v_te_cdrom_desc)='' then | ||
| 654 | - v_te_cdrom_desc := v_DEVICES.Devices[i].FriendlyName; | ||
| 655 | - if Trim(v_te_cdrom_desc)='' then | ||
| 656 | - v_te_cdrom_desc := v_DEVICES.Devices[i].Description; | ||
| 657 | - | ||
| 658 | - if (v_te_cdrom_desc <> '') then | ||
| 659 | - Begin | ||
| 660 | - v_tstrCDROM.Add('te_cdrom_desc###'+v_te_cdrom_desc); | ||
| 661 | - Log_Debug('Adicionando a tstrCDROM: "'+v_tstrCDROM[v_tstrCDROM.count-1]+'"'); | ||
| 662 | - Log_Debug('CDROM Informations - OK!'); | ||
| 663 | - End; | ||
| 664 | - End; | ||
| 665 | - | ||
| 666 | - | ||
| 667 | - v_mensagem := 'Obtendo Descrição de Modem'; | ||
| 668 | - if v_DEVICES.Devices[i].DeviceClass=dcModem then | ||
| 669 | - Begin | ||
| 670 | - if Trim(v_DEVICES.Devices[i].FriendlyName)='' then | ||
| 671 | - v_te_modem_desc := Trim(v_DEVICES.Devices[i].Description) | ||
| 672 | - else | ||
| 673 | - v_te_modem_desc := Trim(v_DEVICES.Devices[i].FriendlyName); | ||
| 674 | - | ||
| 675 | - Log_Debug('MODEM Informations - OK!'); | ||
| 676 | - End; | ||
| 677 | - | ||
| 678 | - v_mensagem := 'Obtendo Descrição de Mouse'; | ||
| 679 | - if v_DEVICES.Devices[i].DeviceClass=dcMouse then | ||
| 680 | - Begin | ||
| 681 | - if Trim(v_DEVICES.Devices[i].FriendlyName)='' then | ||
| 682 | - v_te_mouse_desc := Trim(v_DEVICES.Devices[i].Description) | ||
| 683 | - else | ||
| 684 | - v_te_mouse_desc := Trim(v_DEVICES.Devices[i].FriendlyName); | ||
| 685 | - | ||
| 686 | - Log_Debug('MOUSE Informations - OK!'); | ||
| 687 | - End; | ||
| 688 | - | ||
| 689 | - v_mensagem := 'Obtendo Descrição de Teclado'; | ||
| 690 | - if v_DEVICES.Devices[i].DeviceClass=dcKeyboard then | ||
| 691 | - Begin | ||
| 692 | - if Trim(v_DEVICES.Devices[i].FriendlyName)='' then | ||
| 693 | - v_te_teclado_desc := Trim(v_DEVICES.Devices[i].Description) | ||
| 694 | - else | ||
| 695 | - v_te_teclado_desc := Trim(v_DEVICES.Devices[i].FriendlyName); | ||
| 696 | - | ||
| 697 | - Log_Debug('KEYBOARD Informations - OK!'); | ||
| 698 | - End; | ||
| 699 | - | ||
| 700 | - v_mensagem := 'Obtendo Descrição de Vídeo'; | ||
| 701 | - if v_DEVICES.Devices[i].DeviceClass=dcDisplay then | ||
| 702 | - Begin | ||
| 703 | - if Trim(v_DEVICES.Devices[i].FriendlyName)='' then | ||
| 704 | - v_te_placa_video_desc := Trim(v_DEVICES.Devices[i].Description) | ||
| 705 | - else | ||
| 706 | - v_te_placa_video_desc := Trim(v_DEVICES.Devices[i].FriendlyName); | ||
| 707 | - | ||
| 708 | - Log_Debug('DISPLAY Informations - OK!'); | ||
| 709 | - End; | ||
| 710 | - | ||
| 711 | - i := i+1; | ||
| 712 | - End; | ||
| 713 | - except log_diario('Problema em DEVICES Details!'); | ||
| 714 | - end; | ||
| 715 | - v_DEVICES.Free; | ||
| 716 | - | ||
| 717 | - | ||
| 718 | - // Memory informations | ||
| 719 | - Try | ||
| 720 | - Begin | ||
| 721 | - v_MemoriaRAM.dwLength := SizeOf(v_MemoriaRAM); | ||
| 722 | - GlobalMemoryStatus(v_MemoriaRAM); | ||
| 723 | - v_qt_mem_ram := v_MemoriaRAM.dwTotalPhys div 1024000; | ||
| 724 | - Log_Debug('MEMORY Informations - OK!'); | ||
| 725 | - End; | ||
| 726 | - except log_diario('Problema em MEMORY Details!'); | ||
| 727 | - end; | ||
| 728 | - | ||
| 729 | - Try | ||
| 730 | - Begin | ||
| 731 | - v_SMBIOS := TMiTeC_SMBIOS.Create(nil); | ||
| 732 | - v_SMBIOS.RefreshData; | ||
| 733 | - with v_SMBIOS do begin | ||
| 734 | - if v_SMBIOS.MemoryDeviceCount>0 then begin | ||
| 735 | - for i:=0 to v_SMBIOS.MemoryDeviceCount-1 do | ||
| 736 | - if (v_SMBIOS.MemoryDevice[i].Size>0) then begin | ||
| 737 | - if v_SMBIOS.MemoryDevice[i].Device>smmdUnknown then | ||
| 738 | - v_te_mem_ram_tipo:=MemoryDeviceTypes[v_SMBIOS.MemoryDevice[i].Device] | ||
| 739 | - else | ||
| 740 | - v_te_mem_ram_tipo:=MemoryFormFactors[v_SMBIOS.MemoryDevice[i].FormFactor]; | ||
| 741 | - | ||
| 742 | - if (v_te_mem_ram_desc <> '') then | ||
| 743 | - v_te_mem_ram_desc := v_te_mem_ram_desc + ' - '; | ||
| 744 | - | ||
| 745 | - v_te_mem_ram_desc := v_te_mem_ram_desc + 'Slot '+ inttostr(i) + ': ' | ||
| 746 | - + v_SMBIOS.MemoryDevice[i].Manufacturer + ' ' | ||
| 747 | - + inttostr(v_SMBIOS.MemoryDevice[i].Size) + 'MB ' | ||
| 748 | - + '(' + v_te_mem_ram_tipo +')'; | ||
| 749 | - end; | ||
| 750 | - end | ||
| 751 | - else if v_SMBIOS.MemoryModuleCount > -1 then | ||
| 752 | - Begin | ||
| 753 | - for i:=0 to v_SMBIOS.MemoryModuleCount-1 do begin | ||
| 754 | - if (v_SMBIOS.MemoryModule[i].Size <> 0) then begin | ||
| 755 | - v_te_mem_ram_tipo := v_SMBIOS.GetMemoryTypeStr(v_SMBIOS.MemoryModule[i].Types); | ||
| 756 | - if (v_te_mem_ram_desc <> '') then | ||
| 757 | - v_te_mem_ram_desc := v_te_mem_ram_desc + ' - '; | ||
| 758 | - v_te_mem_ram_desc := v_te_mem_ram_desc + 'Slot '+ inttostr(i) + ': ' | ||
| 759 | - + v_SMBIOS.MemoryDevice[i].Manufacturer + ' ' | ||
| 760 | - + inttostr(v_SMBIOS.MemoryModule[i].Size) + 'MB ' | ||
| 761 | - + '(' + v_te_mem_ram_tipo +')'; | ||
| 762 | - end; | ||
| 763 | - end; | ||
| 764 | - end; | ||
| 765 | - end; | ||
| 766 | - | ||
| 767 | - if (trim(v_te_placa_mae_fabricante)='') then begin | ||
| 768 | - v_te_placa_mae_fabricante := v_SMBIOS.MainBoardManufacturer; | ||
| 769 | - if (trim(v_te_placa_mae_fabricante)='') then | ||
| 770 | - v_te_placa_mae_fabricante := v_SMBIOS.SystemManufacturer; | ||
| 771 | - end; | ||
| 772 | - | ||
| 773 | - if (trim(v_te_placa_mae_desc)='') then begin | ||
| 774 | - v_te_placa_mae_desc := v_SMBIOS.MainBoardModel; | ||
| 775 | - if (trim(v_te_placa_mae_desc)='') then | ||
| 776 | - v_te_placa_mae_desc := v_SMBIOS.SystemModel; | ||
| 777 | - end; | ||
| 778 | - | ||
| 779 | - | ||
| 780 | - v_te_bios_data := v_SMBIOS.BIOSDate; | ||
| 781 | - v_te_bios_fabricante := v_SMBIOS.BIOSVendor; | ||
| 782 | - v_te_bios_desc := v_SMBIOS.BIOSVersion; | ||
| 783 | - | ||
| 784 | - v_SMBIOS.Free; | ||
| 785 | - Log_Debug('SMBIOS Informations - OK!'); | ||
| 786 | - End; | ||
| 787 | - Except log_diario('Problema em SMBIOS Details!'); | ||
| 788 | - End; | ||
| 789 | - | ||
| 790 | - // Display informations | ||
| 791 | - Try | ||
| 792 | - Begin | ||
| 793 | - v_DISPLAY := TMiTeC_Display.Create(nil); | ||
| 794 | - v_DISPLAY.RefreshData; | ||
| 795 | - | ||
| 796 | - if (trim(v_te_placa_video_desc)='') then v_te_placa_video_desc := v_DISPLAY.Adapter; | ||
| 797 | - v_qt_placa_video_cores := IntToStr(v_DISPLAY.ColorDepth); | ||
| 798 | - v_qt_placa_video_mem := IntToStr(v_DISPLAY.Memory div 1048576 ) + 'MB'; | ||
| 799 | - v_te_placa_video_resolucao := IntToStr(v_DISPLAY.HorzRes) + 'x' + IntToStr(v_DISPLAY.VertRes); | ||
| 800 | - | ||
| 801 | - v_DISPLAY.Free; | ||
| 802 | - Log_Debug('VIDEO Informations - OK!'); | ||
| 803 | - End; | ||
| 804 | - Except log_diario('Problema em VIDEO Details!'); | ||
| 805 | - End; | ||
| 806 | - | ||
| 807 | - // Network informations | ||
| 808 | - Try | ||
| 809 | - Begin | ||
| 810 | - v_TCP := TMiTeC_TCPIP.Create(nil); | ||
| 811 | - v_TCP.RefreshData; | ||
| 812 | - | ||
| 813 | - v_mensagem := 'Ativando TCP Getinfo...'; | ||
| 814 | - | ||
| 815 | - i := 0; | ||
| 816 | - v_Macs_Invalidos := trim(GetValorDatMemoria('TCPIP.TE_ENDERECOS_MAC_INVALIDOS',v_tstrCipherOpened)); | ||
| 817 | - | ||
| 818 | - // Avalia quantidade de placas de rede e obtem respectivos dados | ||
| 819 | - if v_TCP.AdapterCount>0 then | ||
| 820 | - for i:=0 to v_TCP.AdapterCount-1 do begin | ||
| 821 | - v_te_placa_rede_desc := v_TCP.Adapter[i].Name; | ||
| 822 | - v_PhysicalAddress := v_TCP.Adapter[i].Address; | ||
| 823 | - v_IPAddress := v_TCP.Adapter[i].IPAddress[0]; | ||
| 824 | - v_IPMask := v_TCP.Adapter[i].IPAddressMask[0]; | ||
| 825 | - v_Gateway_IPAddress := v_TCP.Adapter[i].Gateway_IPAddress[0]; | ||
| 826 | - v_DHCP_IPAddress := v_TCP.Adapter[i].DHCP_IPAddress[0]; | ||
| 827 | - v_PrimaryWINS_IPAddress := v_TCP.Adapter[i].PrimaryWINS_IPAddress[0]; | ||
| 828 | - v_SecondaryWINS_IPAddress := v_TCP.Adapter[i].SecondaryWINS_IPAddress[0]; | ||
| 829 | - | ||
| 830 | - if (trim( v_te_placa_rede_desc + | ||
| 831 | - v_PhysicalAddress + | ||
| 832 | - v_IPAddress + | ||
| 833 | - v_IPMask + | ||
| 834 | - v_Gateway_IPAddress + | ||
| 835 | - v_DHCP_IPAddress + | ||
| 836 | - v_PrimaryWINS_IPAddress + | ||
| 837 | - v_SecondaryWINS_IPAddress)<>'') then | ||
| 838 | - Begin | ||
| 839 | - v_tstrTCPIP.Add('te_placa_rede_desc###' + v_te_placa_rede_desc +'#FIELD#'+ | ||
| 840 | - 'te_node_address###' + v_PhysicalAddress +'#FIELD#'+ | ||
| 841 | - 'te_ip###' + v_IPAddress +'#FIELD#'+ | ||
| 842 | - 'te_mascara###' + v_IPMask +'#FIELD#'+ | ||
| 843 | - 'te_gateway###' + v_Gateway_IPAddress +'#FIELD#'+ | ||
| 844 | - 'te_serv_dhcp###' + v_DHCP_IPAddress +'#FIELD#'+ | ||
| 845 | - 'te_wins_primario###' + v_PrimaryWINS_IPAddress +'#FIELD#'+ | ||
| 846 | - 'te_wins_secundario###' + v_SecondaryWINS_IPAddress); | ||
| 847 | - Log_Debug('Adicionando a tstrTCPIP: "'+v_tstrTCPIP[v_tstrTCPIP.count-1]+'"'); | ||
| 848 | - End | ||
| 849 | - End; | ||
| 850 | - v_TCP.Free; | ||
| 851 | - Log_Debug('TCPIP Informations - OK!'); | ||
| 852 | - End; | ||
| 853 | - Except log_diario('Problema em TCP Details!'); | ||
| 854 | - End; | ||
| 855 | - | ||
| 856 | - // Caso exista a pasta ..temp/debugs, será criado o arquivo diário debug_<coletor>.txt | ||
| 857 | - // Usar esse recurso apenas para debug de coletas mal-sucedidas através do componente MSI-Mitec. | ||
| 858 | - if v_Debugs then | ||
| 859 | - Begin | ||
| 860 | - i := 0; | ||
| 861 | - while i < v_Report.count-1 do | ||
| 862 | - Begin | ||
| 863 | - Grava_Debugs(v_report[i]); | ||
| 864 | - i := i + 1; | ||
| 865 | - End; | ||
| 866 | - v_report.Free; | ||
| 867 | - End; | ||
| 868 | - End; | ||
| 869 | - Except | ||
| 870 | - End; | ||
| 871 | - | ||
| 872 | - // Crio as Tripas dos múltiplos ítens... | ||
| 873 | - v_Tripa_CPU := ''; | ||
| 874 | - v_tstrCPU.Sort; | ||
| 875 | - Log_DEBUG('Tamanho de v_tstrCPU 2: '+intToStr(v_tstrCPU.Count)); | ||
| 876 | - i := 0; | ||
| 877 | - while (i < v_tstrCPU.Count) do | ||
| 878 | - Begin | ||
| 879 | - v_Tripa_CPU := v_Tripa_CPU + iif(v_Tripa_CPU = '','','#CPU#'); | ||
| 880 | - v_Tripa_CPU := v_Tripa_CPU + v_tstrCPU[i]; | ||
| 881 | - i := i + 1; | ||
| 882 | - End; | ||
| 883 | - | ||
| 884 | - v_Tripa_CDROM := ''; | ||
| 885 | - v_tstrCDROM.Sort; | ||
| 886 | - Log_DEBUG('Tamanho de v_tstrCDROM: '+intToStr(v_tstrCDROM.Count)); | ||
| 887 | - i := 0; | ||
| 888 | - while (i < v_tstrCDROM.Count) do | ||
| 889 | - Begin | ||
| 890 | - v_Tripa_CDROM := v_Tripa_CDROM + iif(v_Tripa_CDROM = '','','#CDROM#'); | ||
| 891 | - v_Tripa_CDROM := v_Tripa_CDROM + v_tstrCDROM[i]; | ||
| 892 | - i := i + 1; | ||
| 893 | - End; | ||
| 894 | - | ||
| 895 | - v_Tripa_TCPIP := ''; | ||
| 896 | - v_tstrTCPIP.Sort; | ||
| 897 | - Log_DEBUG('Tamanho de v_tstrTCPIP: '+intToStr(v_tstrTCPIP.Count)); | ||
| 898 | - i := 0; | ||
| 899 | - while (i < v_tstrTCPIP.Count) do | ||
| 900 | - Begin | ||
| 901 | - v_Tripa_TCPIP := v_Tripa_TCPIP + iif(v_Tripa_TCPIP = '','','#TCPIP#'); | ||
| 902 | - v_Tripa_TCPIP := v_Tripa_TCPIP + v_tstrTCPIP[i]; | ||
| 903 | - i := i + 1; | ||
| 904 | - End; | ||
| 905 | - | ||
| 906 | - Try | ||
| 907 | - // Monto a string que será comparada com o valor armazenado no registro. | ||
| 908 | - v_mensagem := 'Montando pacote para comparações...'; | ||
| 909 | - UVC := g_oCacic.trimEspacosExcedentes(v_Tripa_TCPIP + ';' + | ||
| 910 | - v_Tripa_CPU + ';' + | ||
| 911 | - v_Tripa_CDROM + ';' + | ||
| 912 | - v_te_mem_ram_desc + ';' + | ||
| 913 | - IntToStr(v_qt_mem_ram) + ';' + | ||
| 914 | - v_te_bios_desc + ';' + | ||
| 915 | - v_te_bios_data + ';' + | ||
| 916 | - v_te_bios_fabricante + ';' + | ||
| 917 | - v_te_placa_mae_fabricante + ';' + | ||
| 918 | - v_te_placa_mae_desc + ';' + | ||
| 919 | - v_te_placa_video_desc + ';' + | ||
| 920 | - v_te_placa_video_resolucao + ';' + | ||
| 921 | - v_qt_placa_video_cores + ';' + | ||
| 922 | - v_qt_placa_video_mem + ';' + | ||
| 923 | - v_te_placa_som_desc + ';' + | ||
| 924 | - v_te_teclado_desc + ';' + | ||
| 925 | - v_te_modem_desc + ';' + | ||
| 926 | - v_te_mouse_desc); | ||
| 927 | - Except log_diario('Problema em comparação de envio!'); | ||
| 928 | - End; | ||
| 929 | - | ||
| 930 | - // Obtenho do registro o valor que foi previamente armazenado | ||
| 931 | - ValorChaveRegistro := Trim(GetValorDatMemoria('Coletas.Hardware',v_tstrCipherOpened)); | ||
| 932 | - | ||
| 933 | - SetValorDatMemoria('Col_Hard.Fim' , FormatDateTime('hh:nn:ss', Now), v_tstrCipherOpened1); | ||
| 934 | - | ||
| 935 | - // Se essas informações forem diferentes significa que houve alguma alteração | ||
| 936 | - // na configuração de hardware. Nesse caso, gravo as informações no BD Central | ||
| 937 | - // e, se não houver problemas durante esse procedimento, atualizo as | ||
| 938 | - // informações no registro. | ||
| 939 | - If (GetValorDatMemoria('Configs.IN_COLETA_FORCADA_HARD',v_tstrCipherOpened)='S') or | ||
| 940 | - (g_oCacic.trimEspacosExcedentes(UVC) <> g_oCacic.trimEspacosExcedentes(ValorChaveRegistro)) Then | ||
| 941 | - Begin | ||
| 942 | - Try | ||
| 943 | - //Envio via rede para ao Agente Gerente, para gravação no BD. | ||
| 944 | - SetValorDatMemoria('Col_Hard.te_Tripa_TCPIP' , g_oCacic.trimEspacosExcedentes( v_Tripa_TCPIP ), v_tstrCipherOpened1); | ||
| 945 | - SetValorDatMemoria('Col_Hard.te_Tripa_CPU' , g_oCacic.trimEspacosExcedentes( v_Tripa_CPU ), v_tstrCipherOpened1); | ||
| 946 | - SetValorDatMemoria('Col_Hard.te_Tripa_CDROM' , g_oCacic.trimEspacosExcedentes( v_Tripa_CDROM ), v_tstrCipherOpened1); | ||
| 947 | - SetValorDatMemoria('Col_Hard.te_placa_mae_fabricante' , g_oCacic.trimEspacosExcedentes( v_te_placa_mae_fabricante ) , v_tstrCipherOpened1); | ||
| 948 | - SetValorDatMemoria('Col_Hard.te_placa_mae_desc' , g_oCacic.trimEspacosExcedentes( v_te_placa_mae_desc ) , v_tstrCipherOpened1); | ||
| 949 | - SetValorDatMemoria('Col_Hard.qt_mem_ram' , g_oCacic.trimEspacosExcedentes( IntToStr(v_qt_mem_ram) ) , v_tstrCipherOpened1); | ||
| 950 | - SetValorDatMemoria('Col_Hard.te_mem_ram_desc' , g_oCacic.trimEspacosExcedentes( v_te_mem_ram_desc ) , v_tstrCipherOpened1); | ||
| 951 | - SetValorDatMemoria('Col_Hard.te_bios_desc' , g_oCacic.trimEspacosExcedentes( v_te_bios_desc ) , v_tstrCipherOpened1); | ||
| 952 | - SetValorDatMemoria('Col_Hard.te_bios_data' , g_oCacic.trimEspacosExcedentes( v_te_bios_data ) , v_tstrCipherOpened1); | ||
| 953 | - SetValorDatMemoria('Col_Hard.te_bios_fabricante' , g_oCacic.trimEspacosExcedentes( v_te_bios_fabricante ) , v_tstrCipherOpened1); | ||
| 954 | - SetValorDatMemoria('Col_Hard.qt_placa_video_cores' , g_oCacic.trimEspacosExcedentes( v_qt_placa_video_cores ) , v_tstrCipherOpened1); | ||
| 955 | - SetValorDatMemoria('Col_Hard.te_placa_video_desc' , g_oCacic.trimEspacosExcedentes( v_te_placa_video_desc ) , v_tstrCipherOpened1); | ||
| 956 | - SetValorDatMemoria('Col_Hard.qt_placa_video_mem' , g_oCacic.trimEspacosExcedentes( v_qt_placa_video_mem ) , v_tstrCipherOpened1); | ||
| 957 | - SetValorDatMemoria('Col_Hard.te_placa_video_resolucao', g_oCacic.trimEspacosExcedentes( v_te_placa_video_resolucao ) , v_tstrCipherOpened1); | ||
| 958 | - SetValorDatMemoria('Col_Hard.te_placa_som_desc' , g_oCacic.trimEspacosExcedentes( v_te_placa_som_desc ) , v_tstrCipherOpened1); | ||
| 959 | - SetValorDatMemoria('Col_Hard.te_teclado_desc' , g_oCacic.trimEspacosExcedentes( v_te_teclado_desc ) , v_tstrCipherOpened1); | ||
| 960 | - SetValorDatMemoria('Col_Hard.te_mouse_desc' , g_oCacic.trimEspacosExcedentes( v_te_mouse_desc ) , v_tstrCipherOpened1); | ||
| 961 | - SetValorDatMemoria('Col_Hard.te_modem_desc' , g_oCacic.trimEspacosExcedentes( v_te_modem_desc ) , v_tstrCipherOpened1); | ||
| 962 | - SetValorDatMemoria('Col_Hard.UVC' , g_oCacic.trimEspacosExcedentes( UVC ) , v_tstrCipherOpened1); | ||
| 963 | - CipherClose(g_oCacic.getCacicPath + 'temp\col_hard.dat', v_tstrCipherOpened1); | ||
| 964 | - Except log_diario('Problema em gravação de dados no DAT!'); | ||
| 965 | - End; | ||
| 966 | - end | ||
| 967 | - else | ||
| 968 | - Begin | ||
| 969 | - SetValorDatMemoria('Col_Hard.nada','nada', v_tstrCipherOpened1); | ||
| 970 | - SetValorDatMemoria('Col_Hard.Fim' , FormatDateTime('hh:nn:ss', Now), v_tstrCipherOpened1); | ||
| 971 | - CipherClose(g_oCacic.getCacicPath + 'temp\col_hard.dat', v_tstrCipherOpened1); | ||
| 972 | - End; | ||
| 973 | - Except | ||
| 974 | - Begin | ||
| 975 | - SetValorDatMemoria('Col_Hard.nada','nada', v_tstrCipherOpened1); | ||
| 976 | - SetValorDatMemoria('Col_Hard.Fim' , '99999999', v_tstrCipherOpened1); | ||
| 977 | - CipherClose(g_oCacic.getCacicPath + 'temp\col_hard.dat', v_tstrCipherOpened1); | ||
| 978 | - log_diario('Problema na execução => ' + v_mensagem); | ||
| 979 | - End; | ||
| 980 | - End; | ||
| 981 | - g_oCacic.Free(); | ||
| 982 | -end; | ||
| 983 | - | ||
| 984 | -// ATENÇÃO: Caso haja falha na execução deste agente pela estação de trabalho, | ||
| 985 | -// a provável causa será a falta da Runtime Library RTL70.BPL, que | ||
| 986 | -// costuma ser "confundida" com vírus e apagada por alguns anti-vírus | ||
| 987 | -// como o Avasti. | ||
| 988 | -// SOLUÇÃO: Baixar a partir do endereço http://nwvault.ign.com/View.php?view=Other.Detail&id=119 o pacote | ||
| 989 | -// D70_Installer.zip, descompactar e executar na estação de trabalho. | ||
| 990 | -var strAux : String; | ||
| 991 | -const CACIC_APP_NAME = 'col_hard'; | ||
| 992 | -begin | ||
| 993 | - g_oCacic := TCACIC.Create(); | ||
| 994 | - g_oCacic.setBoolCipher(true); | ||
| 995 | - | ||
| 996 | - if( not g_oCacic.isAppRunning( CACIC_APP_NAME ) ) then | ||
| 997 | - if (ParamCount>0) then | ||
| 998 | - Begin | ||
| 999 | - strAux := ''; | ||
| 1000 | - For intAux := 1 to ParamCount do | ||
| 1001 | - Begin | ||
| 1002 | - if LowerCase(Copy(ParamStr(intAux),1,11)) = '/cacicpath=' then | ||
| 1003 | - begin | ||
| 1004 | - strAux := Trim(Copy(ParamStr(intAux),12,Length((ParamStr(intAux))))); | ||
| 1005 | - //log_DEBUG('Parâmetro /CacicPath recebido com valor="'+strAux+'"'); | ||
| 1006 | - end; | ||
| 1007 | - end; | ||
| 1008 | - | ||
| 1009 | - if (strAux <> '') then | ||
| 1010 | - Begin | ||
| 1011 | - g_oCacic.setCacicPath(strAux); | ||
| 1012 | - | ||
| 1013 | - v_tstrCipherOpened := TStrings.Create; | ||
| 1014 | - v_tstrCipherOpened := CipherOpen(g_oCacic.getCacicPath + g_oCacic.getDatFileName); | ||
| 1015 | - | ||
| 1016 | - v_tstrCipherOpened1 := TStrings.Create; | ||
| 1017 | - v_tstrCipherOpened1 := CipherOpen(g_oCacic.getCacicPath + 'temp\col_hard.dat'); | ||
| 1018 | - | ||
| 1019 | - Try | ||
| 1020 | - Executa_Col_Hard; | ||
| 1021 | - Except | ||
| 1022 | - SetValorDatMemoria('Col_Hard.nada', 'nada', v_tstrCipherOpened1); | ||
| 1023 | - CipherClose(g_oCacic.getCacicPath + 'temp\col_hard.dat', v_tstrCipherOpened1); | ||
| 1024 | - End; | ||
| 1025 | - Halt(0); | ||
| 1026 | - End; | ||
| 1027 | - End; | ||
| 1028 | -end. |
col_hard/col_hard.res
No preview for this file type
col_hard/col_hard_icon.ico
No preview for this file type