I have a task scheduled that runs every 15 minutes and I want a DD BPM to trigger off of it. I have created an in-transaction DD under SysAgentSched. I have made a condition statement that looks for the description to match the name of the schedule I created and for a change to the next run from any to another. I have written up some C# code that should trigger whenever these conditions are met that will update an existing row of data in the UD02 table. Credit to this post for the idea:
The problem Iām having is that my code doesnāt seem to be writing at all. I have confirmed this code to write perfectly fine in another BPM. I have also tested to be sure that the schedule is working by assigning a task to it. Does anyone have some troubleshooting techniques that I can try?
Throw a Show Message widget between the condition and Exec Custom Code widgets, just to make sure that its even coming out of the TRUE port of the condition block.
I went ahead and swapped over to a standard definition and changed the next change to last changed on. After doing this and setting up emails to pop up I get the email from the false side. Thanks @ckrusen for helping diagnose which side we were hitting! In addition I found that we were hitting the false side of the condition because of a typo.
If your code to set the checkbox seems to work, Iād think what youāre using should be fine.
The only thing I can think of to look into, is the .DefaultIfEmpty().FirstOrDefault() ending of that expression.
I canāt say that I fully understand what the .DefaultIfEmpty() does. Is it for when thereās no matching record, or for when a record is found, but the value is null?
Also, doesnāt .DefaultIfEmpty() usually specify a value to use when it is empty? Like: .DefaultIfEmpty(1)
You are correct on the default if empty. Its for when there is nothing there and we want there to be a value. As for the code to get the data from the check box its the exact same as what I use for most if not all of my other bpmās that require data from other tables.
Hate to bother you man, but Iām stumped. I have always used this line of code to pull relevant data from tables outside the scope of the bpm Iām working on, or at least something similar.
Db.OrderRel.Where( r =>r.Company == callContextClient.CurrentCompany && r.OrderNum == 1 && r.OrderLine == 1 && r.OrderRelNum == 1).Select( r =>r.ReqDate.ToString()).DefaultIfEmpty().FirstOrDefault()
In the current Standard Data Directive under SysAgentSched I cannot get that code to populate anything, hence why Iām getting the false statement from earlier. Its defaulting to nothing because it sees nothing. Is there a reason that I cannot access revelant data in a standard data directive?
If this triggers on a taskSchedule the callContextClient is null it wonāt have currentCompany in it. (hard code it if you can)
I didnāt read the rest of the thread (sorry burried) but maybe that helps.
New problem, I have begun building out this DD for multiple companies in the same instance and I am not getting the desired results. I have built this Data Directive as Company specific to save on confusion and named them according to the company they were built in. The data directive should fire every time the schedule changes, in this case, every 10 minutes, and send out an email based on the conditioning path laid out for it. I get the email from the original company that I built this for, but I get no emails from the second or third. I have skipped the process of creating a process set and adding something to it and instead decided to simply generate a report on each run of the schedule. I am receiving emails related to the report generation, but not for the data directive running. I believe this may be caused by the fact that I am using a standard directive instead of an in-transaction directive. However, with both of these data directives being in separate companies and being company-specific, I thought they wouldnāt interfere with each other.
It would be much better / easier /less risky to just write a UBAQ put the BPM Code on the GetList Post Processing and schedule that UBAQ Export to run every 10 minutes.
Then you can make a separate BAQ for eachā¦ as a matter of fact you are in 10.2.700 you have functionsā¦ Just write Scheduled Functions why donāt you just schedule a function to do this for you? Seems a lot safer.
I figured out how to get my c code in there. I would like some help understanding how to call in a table for these functions. I am receiving the following error code when trying to assign a variable:
I have created a reference for the table I would like to use, but maybe this isnāt what Iām supposed to use.
Iāve figured out how to get the custom code in there. Had to read through the following post and some of the comments to figure out the checkboxes allowed or disallowed code.
I am now getting the following error whenever the function runs. I get that its related to my keys in UD02 but past that I donāt understand how the parameter value could be blank:
This is what my current function looks like. I just want to pull in the only item in UD02. I believe that using the GetById is how I would go about this. I then have an assign statement to grab the value of Ud02.Checkbox01 and assign it to a variable. Lastly, I want an email to go out if the function operates correctly.
Figured out that the error was that I was passing null values into new parameters key1-5. Solved this by assigning values to the variables before the BO call.
New error below. I have no idea where this one stems from, but I assume it has to do with my variables again, or my c# custom code. New function set up, errors, and C# below:
@josecgomez
I figured out my issue was with my variables. I was placing them under the Request parameters within the signature instead of just setting them up as variables within the function designer.
New challenge:
I am trying to have this function update table ud02 when certain criteria are met. I would like to use the set field widget in function designer. I also thought that after setting the field to true I would need to call in the update bo method caller. Below is what I have created, but it does not push the updates to the ud02 table.