{
  "synLogic": "int $ret \u003d $api($1, $2, $3);",
  "help": "This api will initialize kafka ssl server certificate file path if verify the broker is enabled. This api is used for setting the path to a Certificate Revocation List (CRL) file for SSL/TLS communication with a Kafka broker.",
  "notes": "",
  "returns": "This API returns a non-negative integer indicating success, otherwise it returns a negative value indicating an error in C, In Java this function returns boolean value",
  "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 CRL File Path \u003c/td\u003e \u003ctd\u003e Path of the CRL File \u003c/td\u003e \u003c/tr\u003e \u003ctr\u003e \u003ctd\u003e Error Message \u003c/td\u003e \u003ctd\u003e Error message \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": "CRL File Path",
      "value": "",
      "css": "p-grid p-align-center w-100-p",
      "title": "Enter CRL file path",
      "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_crl_file",
  "syntax": "int ns_kafka_set_ssl_crl_file(int jpid, char *crlFilePath, char *error_msg);",
  "javaSyntax": "boolean ns_kafka_set_ssl_crl_file(JMSKey key, String crlFilePath);",
  "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    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_crl_file(jpid, \"crl_file\", error_msg)) \u003c 0) {\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 server certificate file path if verifiy broker is enabled\n        //ns_kafka_set_ssl_crl_file(key, crlFilePath)\n        if(!nsApi.ns_kafka_set_ssl_crl_file(key, \"crl_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_crl_file(int jpid, char *crlFilePath, char *error_msg);",
  "insertStrJava": "ns_kafka_set_ssl_crl_file(JMSKey key, String crlFilePath);",
  "description": "This api will initialize kafka ssl server certificate file path if verify the broker is enabled. This api is used for setting the path to a Certificate Revocation List (CRL) file for SSL/TLS communication with a Kafka broker."
}