Logo Search packages:      
Sourcecode: libnl2 version File versions  Download package

ct.c

/*
 * src/lib/ct.c         CLI Conntrack Helpers
 *
 *    This library is free software; you can redistribute it and/or
 *    modify it under the terms of the GNU Lesser General Public
 *    License as published by the Free Software Foundation version 2.1
 *    of the License.
 *
 * Copyright (c) 2008-2009 Thomas Graf <tgraf@suug.ch>
 */

/**
 * @ingroup cli
 * @defgroup cli_ct Connection Tracking
 *
 * @{
 */

#include <netlink/cli/utils.h>
#include <netlink/cli/ct.h>

struct nfnl_ct *nl_cli_ct_alloc(void)
{
      struct nfnl_ct *ct;

      ct = nfnl_ct_alloc();
      if (!ct)
            nl_cli_fatal(ENOMEM, "Unable to allocate conntrack object");

      return ct;
}

struct nl_cache *nl_cli_ct_alloc_cache(struct nl_sock *sk)
{
      return nl_cli_alloc_cache(sk, "conntrack", nfnl_ct_alloc_cache);
}

void nl_cli_ct_parse_family(struct nfnl_ct *ct, char *arg)
{
      int family;

      if ((family = nl_str2af(arg)) == AF_UNSPEC)
            nl_cli_fatal(EINVAL,
                       "Unable to nl_cli_ct_parse family \"%s\": %s",
                       arg, nl_geterror(NLE_INVAL));

      nfnl_ct_set_family(ct, family);
}

void nl_cli_ct_parse_protocol(struct nfnl_ct *ct, char *arg)
{
      int proto;

      if ((proto = nl_str2ip_proto(arg)) < 0)
            nl_cli_fatal(proto,
                       "Unable to nl_cli_ct_parse protocol \"%s\": %s",
                       arg, nl_geterror(proto));

      nfnl_ct_set_proto(ct, proto);
}

void nl_cli_ct_parse_mark(struct nfnl_ct *ct, char *arg)
{
      uint32_t mark = nl_cli_parse_u32(arg);
      nfnl_ct_set_mark(ct, mark);
}

void nl_cli_ct_parse_timeout(struct nfnl_ct *ct, char *arg)
{
      uint32_t timeout = nl_cli_parse_u32(arg);
      nfnl_ct_set_timeout(ct, timeout);
}

void nl_cli_ct_parse_id(struct nfnl_ct *ct, char *arg)
{
      uint32_t id = nl_cli_parse_u32(arg);
      nfnl_ct_set_id(ct, id);
}

void nl_cli_ct_parse_use(struct nfnl_ct *ct, char *arg)
{
      uint32_t use = nl_cli_parse_u32(arg);
      nfnl_ct_set_use(ct, use);
}

void nl_cli_ct_parse_src(struct nfnl_ct *ct, int reply, char *arg)
{
      int err;
      struct nl_addr *a = nl_cli_addr_parse(arg, nfnl_ct_get_family(ct));
      if ((err = nfnl_ct_set_src(ct, reply, a)) < 0)
            nl_cli_fatal(err, "Unable to set source address: %s",
                       nl_geterror(err));
}

void nl_cli_ct_parse_dst(struct nfnl_ct *ct, int reply, char *arg)
{
      int err;
      struct nl_addr *a = nl_cli_addr_parse(arg, nfnl_ct_get_family(ct));
      if ((err = nfnl_ct_set_dst(ct, reply, a)) < 0)
            nl_cli_fatal(err, "Unable to set destination address: %s",
                       nl_geterror(err));
}

void nl_cli_ct_parse_src_port(struct nfnl_ct *ct, int reply, char *arg)
{
      uint32_t port = nl_cli_parse_u32(arg);
      nfnl_ct_set_src_port(ct, reply, port);
}

void nl_cli_ct_parse_dst_port(struct nfnl_ct *ct, int reply, char *arg)
{
      uint32_t port = nl_cli_parse_u32(arg);
      nfnl_ct_set_dst_port(ct, reply, port);
}

void nl_cli_ct_parse_tcp_state(struct nfnl_ct *ct, char *arg)
{
      int state;

      if ((state = nfnl_ct_str2tcp_state(arg)) < 0)
            nl_cli_fatal(state,
                       "Unable to nl_cli_ct_parse tcp state \"%s\": %s",
                       arg, nl_geterror(state));

      nfnl_ct_set_tcp_state(ct, state);
}

void nl_cli_ct_parse_status(struct nfnl_ct *ct, char *arg)
{
      int status;

      if ((status = nfnl_ct_str2status(arg)) < 0)
            nl_cli_fatal(status,
                       "Unable to nl_cli_ct_parse flags \"%s\": %s",
                       arg, nl_geterror(status));

      nfnl_ct_set_status(ct, status);
}

#if 0
            } else if (arg_match("origicmpid")) {
                  if (argc > ++idx)
                        nfnl_ct_set_icmp_id(ct, 0, strtoul(argv[idx++], NULL, 0));
            } else if (arg_match("origicmptype")) {
                  if (argc > ++idx)
                        nfnl_ct_set_icmp_type(ct, 0, strtoul(argv[idx++], NULL, 0));
            } else if (arg_match("origicmpcode")) {
                  if (argc > ++idx)
                        nfnl_ct_set_icmp_code(ct, 0, strtoul(argv[idx++], NULL, 0));
            } else if (arg_match("replyicmpid")) {
                  if (argc > ++idx)
                        nfnl_ct_set_icmp_id(ct, 1, strtoul(argv[idx++], NULL, 0));
            } else if (arg_match("replyicmptype")) {
                  if (argc > ++idx)
                        nfnl_ct_set_icmp_type(ct, 1, strtoul(argv[idx++], NULL, 0));
            } else if (arg_match("replyicmpcode")) {
                  if (argc > ++idx)
                        nfnl_ct_set_icmp_code(ct, 1, strtoul(argv[idx++], NULL, 0));
            }
#endif

/** @} */

Generated by  Doxygen 1.6.0   Back to index