Codebase list reaver / master src / builder.h
master

Tree @master (Download .tar.gz)

builder.h @masterraw · history · blame

/*
 * Reaver - Packet building functions
 * Copyright (c) 2011, Tactical Network Solutions, Craig Heffner <[email protected]>
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 *
 *  In addition, as a special exception, the copyright holders give
 *  permission to link the code of portions of this program with the
 *  OpenSSL library under certain conditions as described in each
 *  individual source file, and distribute linked combinations
 *  including the two.
 *  You must obey the GNU General Public License in all respects
 *  for all of the code used other than OpenSSL. *  If you modify
 *  file(s) with this exception, you may extend this exception to your
 *  version of the file(s), but you are not obligated to do so. *  If you
 *  do not wish to do so, delete this exception statement from your
 *  version. *  If you delete this exception statement from all source
 *  files in the program, then also delete it here.
 */

#ifndef BUILDER_H
#define BUILDER_H

#include <arpa/inet.h>
#include "defs.h"
#include "globule.h"

#define SRATES_TAG_NUMBER       0x01
#define ERATES_TAG_NUMBER       0x32
#define WPS_TAG_SIZE            14
#define WPS_REGISTRAR_TAG       "\x00\x50\xF2\x04\x10\x4A\x00\x01\x10\x10\x3A\x00\x01\x02"

#define DOT1X_VERSION           0x01
#define DOT1X_START             0x01

#define FC_PROBE_REQUEST        0x0040
#define FC_STANDARD		0x0108

#define LLC_SNAP                0xAA

#define LISTEN_INTERVAL         0x0064
#define OPEN_SYSTEM             0

#define UNNUMBERED_FRAME        0x03
#define WFA_VENDOR_ID           "\x00\x37\x2A"


#ifndef IW_ESSID_MAX_SIZE
#define IW_ESSID_MAX_SIZE 32
#endif

size_t build_radio_tap_header(void *rt_header);
size_t build_dot11_frame_header(struct dot11_frame_header *fh, uint16_t fc);
size_t build_association_management_frame(struct association_request_management_frame *f);
size_t build_authentication_management_frame(struct authentication_management_frame *f);

size_t build_ssid_tagged_parameter(unsigned char buf[IW_ESSID_MAX_SIZE+2], char *essid);
size_t build_supported_rates_tagged_parameter(unsigned char *buf, size_t buflen);
size_t build_wps_tagged_parameter(unsigned char buf[2+WPS_TAG_SIZE]);
size_t build_htcaps_parameter(unsigned char *buf, size_t buflen);

void *build_wps_probe_request(unsigned char *bssid, char *essid, size_t *len);
void *build_snap_packet(size_t *len);
void *build_dot1X_header(uint8_t type, uint16_t payload_len, size_t *len);
void *build_eap_header(uint8_t id, uint8_t code, uint8_t type, uint16_t payload_len, size_t *len);
void *build_eapol_start_packet(size_t *len);
void *build_eap_packet(const void *payload, uint16_t payload_len, size_t *len);
void *build_eap_failure_packet(size_t *len);

#endif