{
  "synLogic": "int $ret \u003d $api($1, $2, $3);",
  "help": "This function set an SSL certificate file for a particular Kafka instance. When working with Kafka and SSL encryption, you typically need to provide a certificate file that contains the public key and the corresponding private key used for authentication and establishing secure connections with the Kafka brokers.",
  "notes": "",
  "returns": "This function returns true for success and false for failure in Java and integer value in C.",
  "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 SSL Certificate File \u003c/td\u003e \u003ctd\u003e These are small data files that digitally bind a cryptographic key to an organizations details. \u003c/td\u003e \u003c/tr\u003e \u003ctr\u003e \u003ctd\u003e Error Message \u003c/td\u003e \u003ctd\u003e A character array in which any error message will be stored if the function call fails. \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": "SSL Certificate File",
      "value": "",
      "css": "p-grid p-align-center w-100-p",
      "title": "Enter SSL 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_cert_file",
  "syntax": "int ns_kafka_set_ssl_cert_file(int jpid, char *certificateFilePath, char *error_msg);",
  "javaSyntax": "boolean ns_kafka_set_ssl_cert_file(JMSKey key, String certificateFilePath);",
  "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  int msg_len \u003d 1024;\n  char msg[1024 + 1];        int hdr_len \u003d 1024;\n  char header[1024 + 1];\n\n  if((jpid \u003d ns_kafka_init_consumer(\"127.0.0.1\", 9092, \"topic\", \"consumer_group\", 5, error_msg)) \u003c 0)\n  {\n    fprintf(stderr, \"Error in initializing Kafka Consumer. Error code \u003d %d, Error Msg \u003d %s\", jpid, error_msg);\n    return;\n  }\n\n  if((ret \u003d ns_kafka_set_ssl_cert_file(jpid, \"certificate_file\", error_msg)) \u003c 0)\n  {\n    fprintf(stderr, \"Error in setting Kafka ssl 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 certificate file path\n        //ns_kafka_set_ssl_cert_file(key, certificateFilePath)\n        if(!nsApi.ns_kafka_set_ssl_cert_file(key, \"cert_file_path\") \u0026\u0026 key.getErrCode() !\u003d 0)\n        {\n         System.out.println(\"Error in setting Kafka ssl certificate. Error code \u003d \" + key.getErrCode() + \", Error Msg \u003d \" + key.getErrMsg());\n         return 0;\n        }\n  }\n}",
  "insertStrC": "ns_kafka_set_ssl_cert_file(int jpid, char *certificateFilePath, char *error_msg);",
  "insertStrJava": "ns_kafka_set_ssl_cert_file(JMSKey key, String certificateFilePath);",
  "description": "This function set an SSL certificate file for a particular Kafka instance. When working with Kafka and SSL encryption, you typically need to provide a certificate file that contains the public key and the corresponding private key used for authentication and establishing secure connections with the Kafka brokers."
}