To add a custom scoring module to your decision model on the Lendsqr admin console, you will need to add a JSON model to the existing structure of the default Lendsqr decision model. 


Here is a step by step of how you can configure this on the admin console 


  1. Login to the admin console 
  2. Navigate to "Decision Models" under "Product Management".
    • Once logged in, locate the side navigation and click on "Product Management."
    • In the dropdown menu, select "Decision Models."



    3. Create or Update a Decision Model

  • To create a new decision model, click on the "New Decision Model" button.
  • To update an existing decision model, find the decision model in the list and click on the "Edit" button next to it.


    

    4. Access the decision model settings section

  • Scroll down to the "Decision Model Settings" section of the Edit decision model page.



    5. Add the Custom Scoring Module 

  • Add or modify the existing JSON logic with the custom module payload.
  • Insert the following JSON payload under the appropriate sequence in your decision model settings: 



Example JSON Logic

Below are different configurations of the custom scoring module:


Simple Case: GET Request (No API Key, Simple Scoring)


Description: This simple configuration performs a GET request to retrieve scoring data. No authentication or additional 

payload is required.

"custom": {
  "required": true,
  "sequence": 4,
  "continue_on_failure": false,
  "pre_offer": true,
  "identifier": "scoring-check1",
  "host": "https://example.com/simple",
  "method": "get",
  "minimum": 80
}



GET with Query Payload


Description: This configuration sends a GET request with query parameters (e.g., bvn and loan amount) and additional authentication.


"custom": {
  "required": true,
  "sequence": 5,
  "continue_on_failure": true,
  "pre_offer": false,
  "identifier": "scoring-check2",
  "host": "https://example.com/query",
  "method": "get",
  "headers": {
    "authorization": "Bearer xxx"
  },
  "query": {
    "bvn": "{{bvn}}",
    "loan_amount": 50000
  },
  "minimum": 70
}


POST with Body Payload


Description: This configuration uses a POST request with a JSON body payload to send scoring data.


"custom": {
  "required": true,
  "sequence": 6,
  "continue_on_failure": false,
  "pre_offer": true,
  "identifier": "scoring-check3",
  "host": "https://example.com/post",
  "headers": {
    "authorization": "Bearer xxx"
  },
  "method": "post",
  "body": {
    "bvn": "{{bvn}}",
    "loan_amount": 50000,
    "credit_score": 750
  },
  "minimum": 75
}


Complex Case: Scoring with Collection


Description: This configuration uses a POST request with a body payload containing a collection of users and their loan details.

"custom": {
  "required": true,
  "sequence": 8,
  "continue_on_failure": false,
  "pre_offer": true,
  "identifier": "scoring-check5",
  "host": "https://example.com/complex",
  "method": "post",
  "body": {
    "users": [
      {"user_id": "12345", "loan_amount": 50000},
      {"user_id": "67890", "loan_amount": 75000}
    ]
  },
  "minimum": 90
}


  6. Configure each JSON field 

  • Ensure that each field is correctly configured according to your custom module's requirements.


S/NVariableDescription
1requiredType: boolean (true or false)
Description: Indicates whether this module is mandatory (true) for the decision process. If set to true, the decision model will require this module to run successfully. If set to false, the module can be skipped without affecting the overall decision flow.
2sequenceType: integer
Description: Defines the execution order of the module within the decision model. A lower number means the module will run earlier in the sequence. This is important for determining the order in which different modules or rules are applied. 
3continue_on_failureType: boolean (true or false)
Description: Determines whether the decision process should continue if this module fails. If set to true, the model will proceed with subsequent steps even if the module fails. If set to false, a failure in this module will halt the decision process.
4pre_offerType: boolean (true or false)
Description: Specifies if the module should be executed before the loan offer is generated. If true, the module runs during the pre-offer phase, affecting the conditions under which a loan offer is made. If false, it is executed at a later stage.
5identifierType: string (URL)
Description: A unique identifier for the custom scoring module. This identifier is used to reference the module within the system and in logs, and must be unique across all modules to avoid conflicts. It helps in tracking and managing different modules effectively. 
6hostType: string (URL)
Description: The endpoint URL where the scoring logic or API is hosted. This URL is used to make requests to the external service that performs the scoring. It must be a valid URL and accessible from the Lendsqr platform. Make sure the endpoint is reliable and secure. 
7method Type: string (HTTP method, e.g., "get", "post")
Description: Specifies the HTTP method to be used when calling the host URL. Common methods include GET for retrieving data and POST for sending data to the server. The method should align with the API's requirements at the host URL.

For now we only support GET 
8minimumType: integer
Description: This is the minimum score a customer must get before they can pass the requirements for this module.
9headersType: string
Description: This is the authentication key or bearer token needed to call the host.
10queryType: object (optional)
Description: Key-value pairs sent as query parameters
11bodyType: object (optional)
Description: Key-value pairs sent as query parameters for POST requests.


   7. Save the Configuration

  • After adding the JSON payload, click on the "Save Changes" button to apply the changes to the decision model.