I'm trying to use terrasoft.axd to download an image that is loaded as a system setting. I am using the following query string /terrasoft.axd?s=nui-binary-syssetting&r=Glbxxx where Glbxxx is the system setting code. I don't understand why some calls return the correct image and others return a http error 401 (access denied).
The 401 Unauthorized error you are encountering is not related to access rights (Access Denied) but rather to session authentication. This happens because your session expired or was not active at the moment you made the request. As a result, the system does not recognize your authentication and returns a 401 Unauthorized response.
This is not an issue with the terrasoft.axd endpoint itself, but rather an authentication problem. We recommend checking whether your session is still active when making the request and re-authenticating if needed.
For more details, you can refer to the official HTTP 401 documentation: MDN - 401 Unauthorized
I want to implement a functionality on a web page where a Phone Number field is used to retrieve customer data. When a phone number is entered and submitted:
If a matching customer record exists in Creatio, the page should automatically populate with the customer’s details.
If no record is found, a new customer record should be created in Creatio.
Is this functionality achievable? Any guidance would be appreciated!
It is not. The new landing page designer is basically just a visual designer to generate the html. There is an optional feature you can enable to publish the html, which basically uploads the html to a free landing page host (can’t remember which one at the moment)
How can I capture the newly changed field value before saving a record in a crt.SaveRecordRequest in Creatio Freedom UI? Currently, I am getting the old value instead of the new one.
If you are looking into the direct way to get changed attributes values in the SaveRecordRequest - there is none documented on our side. But you can use HandleViewModelAttributeChangeRequest where request has the oldValue and value properties, save the original values of needed attributes into the separate parameters and use these parameters in your task.
Each Widgets calls behind the scene API with one key that is present in the global Area
Present that data in the widget
Now each widget can be consider as Page --
Now how easily create Page which invokes API and dispaly -- if API is returning 10 or so parameter do we need to create manually the page and have items and map items to API return value
In order to display the result of the API call on the widget you will have to create the custom widget and implement the API call for retrieving necessary data in its source code. The key from Global area that will be used for calling the API you can send to your custom widget as a parameter. Also in custom widget configuration you will have to define "items" list that will represent the structure of the data you want to display. When the API call returns the result you will have to parse it and map to the corresponding columns in widget ViewModel.
Currently it's not possible to display API call result in List component on the page.
If you want to display API call result on the page you can add the custom attributes to your page, save the parsed response there and then bind the attributes to the labels on the page to make it visible.
One question for the above method with handler the API call will be made from the client end -- wanted it to be done from server end (this way we can whitelist creatio iP range and only allow calls from those servers only)
I have a business process calling some subprocesses, and it should then open a new record page. but for some reason, the page doesn't open, and the process is left in the running state. does anybody know what can prevent opening a page?
Check the start of the process (select the green start where the process begins) and make sure it does not have the "run in background" option checked.
I've checked that, and it's not checked. I did some further analysis, and the record is created and i can open it, it only doesn't want to open during the process flow. Furthermore, if I run the process under my colleague's credentials, the record does open. So, one would think it's a permission problem, although we both have the same permissions, we both have the system administrator role, and i can open the record 'manually'...
I am looking to consume my own or an external API that returns a JSON response and embed an IFRAME inside a Creatio Freedom UI page to display the relevant data.
My Goal:
Call an API that responds with JSON data.
Display the API response inside an IFRAME in Freedom UI.
Ensure the IFRAME updates dynamically based on API data.
My Questions:
What is the best way to embed an IFRAME inside a Freedom UI page?
How can I dynamically set the IFRAME's src based on API response data?
Are there any security or CORS restrictions I should be aware of when using an external API?
If anyone has experience implementing this in Freedom UI or has sample configurations, I'd love to hear your insights!
However, an IFRAME cant just display data from an API. An IFRAME simply embeds another page, it would be the responsibility of the page you're embedding to retrieve and display the API data.
However, an IFRAME cant just display data from an API. An IFRAME simply embeds another page, it would be the responsibility of the page you're embedding to retrieve and display the API data.
The error you're encountering is related to your system being unable to find or load the e_sqlite3 library. This can be caused by several reasons. Please note that this issue is not related to the Creatio system itself but rather to a Microsoft component.
This article might help you: Microsoft.Data.Sqlite library 'e_sqlite3' not found:
Below are a few steps that may help resolve the issue (please note that these are general recommendations, and since the issue is related to Microsoft components https://www.nuget.org/packages, you might also find assistance on forums or by contacting Microsoft support):
1. Make sure the e_sqlite3 library is present.
2. Install or update the SQLitePCLRaw.bundle_e_sqlite3 package. You can do this via the NuGet Package Manager using the following command:
3. Ensure that your target platform is compatible with the library. For example, if you're building for x86, make sure you’re using the correct version of the library (x86 or x64).
Installing or updating the package via command line (cmd):
1. Open the command prompt: On Windows, press Win + R, type cmd, and press Enter.
2. Navigate to your project directory: Use the cd command to change to the folder where your project is located.
For example, cd path\to\your\project
3. Install or update the package: If you have NuGet CLI installed, you can run:
nuget install SQLitePCLRaw.bundle_e_sqlite3
However, if you're using .NET Core or .NET 5/6/7, it’s recommended to use the dotnet CLI instead:
dotnet add package SQLitePCLRaw.bundle_e_sqlite3
This command will automatically add the package to your project and update the .csprojfile.
Example commands:
1. Navigate to your project directory: cd C:\Projects\MyApp
2. Install the package: dotnet add package SQLitePCLRaw.bundle_e_sqlite3
After successful execution, dotnet will download and install the package. If everything goes well, you’ll see a message confirming the package has been added to your project.
I have a master record and a detail where I allow inline editing. Making changes on the detail triggers an update on the master record. Because the table behind the master record has live updates, the changes are immediately reflected on the master record.
All that logic works fine. The issue I have is that if the user makes changes to the master record and then changes to the detail (like adding a new detail, deleting or editing an existing one,) the changes on the master record are not saved,.
Is there any way to save the master record when the user saves the detail changes?