Uma integração entre o Protheus e outros sistemas pode ser feita de várias formas, xml, arquivo txt etc. Eu resolvi fazer algo mais direto, ou seja, uma aplicação no Protheus(BD Sql Server) que enxerga o banco de dados do outro sistema, que usa o BD Postgres, e monta uma tabela temporária tratando esses dados e logo depois inserindo-os no Protheus através de rotinas automáticas. Apesar do banco do outro sistema não ter nada haver com o banco de dados do Protheus, podemos conectar a ele da seguinte forma:
1- Crie uma ODBC no servidor do BD do Protheus para o outro banco. No caso do Postgres, eu tive que baixar um drive para conexão ODBC específica para ele. Observe configuração de porta, senha e tal. No final, verifique se a conexão foi bem sucedida. Caso tenha sido, deveremos executar o próximo passo.
2- Valide a conexão ODBC da mesma forma que se faz com uma ODBC criada para o Protheus, ou seja, vá ao TOTVSDBMonitor e na aba configurações, escolha a aba Postgres ou a do BD do outro sistema que você quer se conectar. Crie um ambiente, coloque a senha correta e no assistente é só fazer a validação da conexão.
3- Com a validação ok, é hora de enxergar o outro banco. Vamos então criar uma rotina básica de comunicação com nosso BD da outra aplicação.
-----------------------------------------------------------------------------------------------
User Function JOBATAE1()
Private cBDProd := "MSSQL/Interface" // comunicacao com BD Protheus. Usado na funcao //TCLINK.
Private cBDAtae := "POSTGRES/atae" // comunicacao com BD sistema ATAE. Usado na //funcao.
Private cIPBD := "192.168.1.244" // IP do servidor de aplicacoes
Private _nTcConn // conectar com ATAE
Private _nTcCon2 // conectar com Protheus
TCCONTYPE("TCPIP") // tipo de conexao que sera usada
_nTcConn := TCLink(cBDAtae,cIPBD) // conexao com ATAE(sistema que usa o BD PostGres)
_nTcCon2 := TCLink(cBDProd,cIPBD) // conexao com Protheus
-----------------------------------------------------------------------------------------------
Neste primeiro trecho observe que criei duas variáves :
cBDProd
cBDAtae
Elas guardam a string de conexao com os respectivos BD. Logo depois temos a variável
cIPBD que contém o IP do servidor de aplicações do Protheus. Essas variáveis serão usadas na função TCLink pois ela tem a seguinte sintaxe:
TCLink(cConectString,cServer)
cConectString: String composta conforme a regra:
Para TOPConnect NT : Nome do Banco de Dados / Nome do Ambiente
Para TOPConnect/400: Nome do Ambiente
cServer: Endereço IP do servidor TOPConnect.
As variáveis _nTcConn e _nTcCon2 recebem o resultado da conexão, ou seja, o TCLink retorna um número negativo caso a conexão não tenho tido êxito. Neste caso existe a possibilidade de algum dos servidores de BD estarem offline ou a string de conexão está incorreta.
Continuando nossa aplicação temos:
-----------------------------------------------------------------------------------------------
If ( _nTcConn <>
//mostra alerta de erro com a conexão BD postgres ou BD Protheus
Alert("*** Erro de conexão ***")
Else
Alert("*** Conexão OK ***")
TCSETCONN(_nTcConn) // setando conexao com Postgres
LerTab() // lendo uma tabela Postgres
InsProt() // pegando os dados do Postgres e inserindo no Protheus
EndIf
Return
Static Function LerTab()
Local cQuery := " SELECT * FROM CLIENTE "
dbUseArea(.T., "TOPCONN", TCGenQry(,,cQuery), "TRS", .F., .T.)
TRS->(DbGoTop())
Alert(TRS->NOME)
Return
Static Function InsProt()
TCSETCONN(_nTcCon2) // conectando com o Protheus
RPCSetType(3)
RPCSetEnv("01","01","user","senhaUser") // logando no Protheus
// faca um loop para carregar os dados da tabela TRS para seu array
// e execute sua rotina automática
TRS->(DbCloseArea())
Return
-----------------------------------------------------------------------------------------------
Na segunda parte da rotina podemos ver que após verificar se as conexões estão Ok, usamos o comando TCSETCONN(_nTcConn) para setar a conexão da rotina para o BD postgres. A partir daí é tudo quase igual a qualquer rotina para criar uma tabela temporária baseada em informações do Protheus. Observe apenas a sintaxe usada na variável cQuery que terá que obedecer as regras do banco. Depois de recuperar as informações da tabela CLIENTE do postgres, é só usar o comando TCSETCONN(_nTcCon2) para se comunicar com o Protheus e a parti daí usar os comandos RPCSetType e RPCSetEnv para logar na empresa e filial. Depois disso, execute sua rotina automática e pronto, sua integração foi feita.
Eu estava precisando disso... valeu a dica !
ResponderExcluirMuito bom..... Parabéns pela dica
ResponderExcluir