Navision Integration Framework

Miklos_Hollender
Member Posts: 1,598
I started to write a general framework for accessing Navision data from outside with firing triggers. You just drop something like this into MSMQ or, better yet, a web service:
and you have updated a record. And same stuff for inserting, reading etc. I will publish it when it is finished, but I have some problems.
1. How should I handle locking? I'd like to avoid a SingleInstance CodeUnit, because that keeps throwing internal errors (4.0SP1), but without that, what else could maintain a lock between a reading and a modifing request?
2. How should I route answering to requests? It seems the client application will need at least two threads, one of them collecting answers from MSMQ and saving them, the other thread - that initiated the requests - will wait and periodically search the answers for it's RequestID to find something like "Modify OK" to know the operations has finished successfully. Is there an easier way for it?
<Modify RecordID = "Customer: Cust001" CallOnModify="True" RequestID="5FS4WG4WW-FW4TRWFWW3343-DWW343434-43W4WRW"> <Field FieldNo="2" CallOnValidate = "True">Forrester Ltd.</Field> <Field FieldNo="5" CallOnValidate = "True">Baker street 23</Field> </Modify>
and you have updated a record. And same stuff for inserting, reading etc. I will publish it when it is finished, but I have some problems.
1. How should I handle locking? I'd like to avoid a SingleInstance CodeUnit, because that keeps throwing internal errors (4.0SP1), but without that, what else could maintain a lock between a reading and a modifing request?
2. How should I route answering to requests? It seems the client application will need at least two threads, one of them collecting answers from MSMQ and saving them, the other thread - that initiated the requests - will wait and periodically search the answers for it's RequestID to find something like "Modify OK" to know the operations has finished successfully. Is there an easier way for it?
0
Comments
-
This is a great idea, but you'll be reinventing the wheel. Nav 5 might do something like this and you'll be reinventing the wheel. Just wait a few weeks until we something about it.0
-
maybe Mark will ask in detail at the tech ed 2006 meeting0
-
1. How should I handle locking? I'd like to avoid a SingleInstance CodeUnit, because that keeps throwing internal errors (4.0SP1), but without that, what else could maintain a lock between a reading and a modifing request?
Very hard... if you want to do more request in one transaction, you do not have another solution than collect the requests into some buffer and after zou know, that the transaction is prepared (you have something like EOT in the message queue) you need to process the buffer in one run.
Which internal error do you mean? How you are calling this codeunit? If you call it from CU1, you need to check if the CU is defined as global or local.0 -
ara3n,
I think we can safely assume that
1) In Nav5 it will not be implemented in pure C/AL, but also the fin.exe will be extended, which means if it has errors, which are usually plenty, we will not be able to fix it
2) it will cost extra money0 -
Well, the internal errors I got not only by NAS but running a s.i. CU in a client, because my first idea was to keep a RecRef in memory in a s.i. CU and send it "open", "validate", "insert" etc. messages through MSMQ.0
-
Do not forget to security - if anyone will be allowed to send such a XML to your system, you have BIG security hole...0
-
It's almost done, now I only have to write a few examples. One of them should be PHP. I have the following problem with using COM components from PHP:
$outMsg = $cc2->CreateoutMessage('Message queue://'); $outStream = $outMsg->GetStream(); $outStream->WRITE($xml);
Basically, the problem is that while PHP properly instantiates the OutMessage COM object returned by CreateoutMessage into $outMsg, it does not instantiate the COM OutStream object returned by GetStream(); into $outStream. $outStream becomes a zval (a generic, undefined PHP type) instead, and as it of course does not have a WRITE method, it fails.
Fatal error: Call to a member function WRITE() on a non-object.0 -
Amazing. In Ruby, it's even worse, even CreateoutMessage does not return a COM object. There must be something deeply wrong with the implementation of COM in dynamic languages. I think we'll have to stick to .NET for this one. I hope at least the .NET-COM interop works properly.0
-
BETA version just submitted, I think it will be available in the downloads soon. Please help me figuring out how to use it in PHP.0
-
Savatage wrote:maybe Mark will ask in detail at the tech ed 2006 meeting
Be patient Miklos for nav 5.0.0 -
Yeah. And what if that becomes the same quality as Employee Portal? It is Open Source, therefore here you can repair bugs... that one will be hardcoded into fin.exe I think.
Besides, I don't think they would explicitly make it easier to send in data from non-MS languages, it's not their style, isn't it?0 -
Mark Brummel wrote:Savatage wrote:maybe Mark will ask in detail at the tech ed 2006 meeting
Be patient Miklos for nav 5.0.0 -
If sp2 for v5 will be that long away, it means 5.0 will be in great quality that you can use for a year.
:whistle:0 -
ara3n wrote:If sp2 for v5 will be that long away, it means 5.0 will be in great quality that you can use for a year.
:whistle:
Because if you go to NAV 5.0 before any service packs, you will likely face a huge cost once SP1 and then again once SP2 comes out to upgrade your NAv5.0 database.Don't you think, each upgrade for a sp1 to have an NSC do it for an end user will not be cheap. if you have anything but an unmodified version of Navision, which of coarse nobody has an unmodified version of Navision.
0
Categories
- All Categories
- 73 General
- 73 Announcements
- 66.6K Microsoft Dynamics NAV
- 18.7K NAV Three Tier
- 38.4K NAV/Navision Classic Client
- 3.6K Navision Attain
- 2.4K Navision Financials
- 116 Navision DOS
- 851 Navision e-Commerce
- 1K NAV Tips & Tricks
- 772 NAV Dutch speaking only
- 617 NAV Courses, Exams & Certification
- 2K Microsoft Dynamics-Other
- 1.5K Dynamics AX
- 322 Dynamics CRM
- 111 Dynamics GP
- 10 Dynamics SL
- 1.5K Other
- 990 SQL General
- 383 SQL Performance
- 34 SQL Tips & Tricks
- 35 Design Patterns (General & Best Practices)
- 1 Architectural Patterns
- 10 Design Patterns
- 5 Implementation Patterns
- 53 3rd Party Products, Services & Events
- 1.6K General
- 1.1K General Chat
- 1.6K Website
- 83 Testing
- 1.2K Download section
- 23 How Tos section
- 252 Feedback
- 12 NAV TechDays 2013 Sessions
- 13 NAV TechDays 2012 Sessions