{
  "synLogic": "int $ret \u003d $api($1, $2, $3);",
  "help": "The api ns_kafka_set_ssl_ca_file sets the SSL CA certificate file path for a Kafka client using the specified key. When working with Kafka and SSL encryption, you typically need to provide a CA (Certificate Authority) file that contains the trusted CA certificates used to validate the identity of the Kafka brokers.",
  "notes": "",
  "returns": "The function returns an integer value:  \n•0: If the SSL CA certificate file path is set successfully. \n-1: If there is an error while setting the SSL CA certificate file path. \nIt will return a boolean value in Java",
  "arguments": "\u003ctable class\u003d\"newGuiTable\" style\u003d\"width:100%\"\u003e \u003ctbody\u003e\u003ctr\u003e \u003cth\u003e Argument \u003c/th\u003e \u003cth\u003e Description \u003c/th\u003e \u003c/tr\u003e \u003ctr\u003e \u003ctd\u003e JPID \u003c/td\u003e \u003ctd\u003e It is the pool id returned from ns_kafka_init_producer () or ns_kafka_init_consumer () api. \u003c/td\u003e \u003c/tr\u003e \u003ctr\u003e \u003ctd\u003e CA Certificate File \u003c/td\u003e \u003ctd\u003e It is a digital certificate file that certifies the ownership of a public key by the named subject of the certificate. A string representing the file path of the SSL CA certificate. \u003c/td\u003e \u003c/tr\u003e \u003ctr\u003e \u003ctd\u003e Error Message \u003c/td\u003e \u003ctd\u003e Character array used to store error messages in case of any errors. \u003c/td\u003e \u003c/tr\u003e   \u003c/tbody\u003e\u003c/table\u003e",
  "parameterization": "",
  "component": [
    {
      "id": "$1",
      "type": "TextField",
      "label": "JMS Pool Connection Id",
      "value": "",
      "css": "p-grid p-align-center w-100-p",
      "title": "First character must be Alpha.\r\nOther characters are Alpha, Numeric or Underscore",
      "placeHolder": "",
      "style": "",
      "isDisabled": "",
      "labelVarCheckbox": "If JMS Connection id is a program variable",
      "argIndex": 0,
      "validate": {
        "inputType": "Text",
        "disabled": false,
        "pattern": "^[a-zA-Z][a-zA-Z0-9_]{0,63}$",
        "required": false,
        "min": 0,
        "max": 0,
        "method": "isValidVar(arg)"
      },
      "quotes": false
    },
    {
      "id": "$2",
      "type": "FILE_PATH",
      "label": "CA Certificate File",
      "value": "",
      "css": "p-grid p-align-center w-100-p",
      "title": "Enter CA certificate file",
      "placeHolder": "",
      "style": "",
      "isDisabled": "",
      "labelVarCheckbox": "",
      "argIndex": 0,
      "validate": {
        "inputType": "Text",
        "disabled": false,
        "required": true,
        "min": 0,
        "max": 0
      },
      "quotes": true
    },
    {
      "id": "$3",
      "type": "TextField",
      "label": "Error Message Buffer Pointer",
      "value": "",
      "css": "p-grid p-align-center w-100-p",
      "title": "Enter error message",
      "placeHolder": "",
      "style": "",
      "isDisabled": "",
      "labelVarCheckbox": "",
      "argIndex": 0,
      "validate": {
        "inputType": "Text",
        "disabled": false,
        "required": true,
        "min": 0,
        "max": 0
      },
      "quotes": false
    },
    {
      "id": "$ret",
      "type": "TextField",
      "label": "Return Variable",
      "value": "",
      "css": "p-grid p-align-center w-100-p",
      "title": "First character must be Alpha.\r\nOther characters are Alpha, Numeric or Underscore.",
      "placeHolder": "",
      "style": "",
      "isDisabled": "",
      "labelVarCheckbox": "",
      "argIndex": 0,
      "validate": {
        "inputType": "Text",
        "disabled": false,
        "pattern": "^[a-zA-Z][a-zA-Z0-9_]{0,63}$",
        "required": false,
        "min": 0,
        "max": 0,
        "method": "isValidVar(arg)"
      },
      "quotes": true
    }
  ],
  "name": "ns_kafka_set_ssl_ca_file",
  "syntax": "int ns_kafka_set_ssl_ca_file(int jpid, char *caCertifcateFilePath, char *error_msg);",
  "javaSyntax": "boolean ns_kafka_set_ssl_ca_file(JMSKey key, String caCertifcateFilePath);",
  "cEx": "flow()\n{\n  int jpid;        //JMS Pool Id\n  int jcid;        //JMS Connection Id\n  char error_msg[1024 + 1];        // Error string. Must be 1024 size\n  int ret;        // Error code\n  char *msg \u003d \"message will goes here\";        // Message to be produced\n  int msg_len \u003d strlen(msg);        // Message Length\n  char *key \u003d \"message_key\";        // Message Key\n  int key_length \u003d strlen(key);        // Message Length\n\n  if((jpid \u003d ns_kafka_init_producer(\"127.0.0.1\", 9092, \"topic\", 1, error_msg)) \u003c 0)\n  {\n    fprintf(stderr, \"Error in initializing Kafka producer. Error code \u003d %d, Error Msg \u003d %s\", jpid, error_msg);\n    return;\n  }\n  if((ret \u003d ns_kafka_set_ssl_ca_file(jpid, \"trusted\", error_msg)) \u003c 0)\n  {\n    fprintf(stderr, \"Error in setting Kafka ssl ca certificate.Error code \u003d %d, Error Msg \u003d %s\", ret, error_msg);\n    return;\n  }\n}",
  "javaEx": "public class flow implements NsFlow\n{\n  public int execute(NSApi nsApi) throws Exception \n  {\n        NSApi.JMSKey key \u003d null;\n\n        //This api will initialize kafka ssl ca certificate file path\n        //ns_kafka_set_ssl_ca_file(key, caCertifcateFilePath)\n        if(!nsApi.ns_kafka_set_ssl_ca_file(key, \"trusted_ca_file_path\") \u0026\u0026 key.getErrCode() !\u003d 0)\n        {\n         System.out.println(\"Error in setting Kafka ssl ca certificate. Error code \u003d \" + key.getErrCode() + \", Error Msg \u003d \" + key.getErrMsg());\n         return 0;\n        }\n  }\n}",
  "insertStrC": "ns_kafka_set_ssl_ca_file(int jpid, char *caCertifcateFilePath, char *error_msg);",
  "insertStrJava": "ns_kafka_set_ssl_ca_file(JMSKey key, String caCertifcateFilePath);",
  "description": "The api ns_kafka_set_ssl_ca_file sets the SSL CA certificate file path for a Kafka client using the specified key. When working with Kafka and SSL encryption, you typically need to provide a CA (Certificate Authority) file that contains the trusted CA certificates used to validate the identity of the Kafka brokers."
}