--- /dev/null
+CC=gcc
+CFLAGS=-I.
+DEPS =
+OBJ = socket.o main.o gs105e.o shell.o shell_ip.o shell_vlan.o shell_port.o
+
+%.o: %.c $(DEPS)
+ $(CC) -c -o $@ $< $(CFLAGS)
+
+gsconfig: $(OBJ)
+ gcc -o $@ $^ $(CFLAGS)
+
+clean:
+ rm *.o -rf
+ rm gsconfig -rf
--- /dev/null
+
+#include "gs105e.h"
+#include "socket.h"
+#include <string.h>
+#include <stdio.h>
+#include <stdlib.h>
+
+unsigned char * gs105e_queryData;
+unsigned int gsDataLen;
+
+struct vlan * getVlanSetting(unsigned int vlanId) {
+ struct vlan * _vlan = settings.vlans;
+
+ while (_vlan != NULL) {
+ if (_vlan->id == vlanId)
+ return _vlan;
+ _vlan = _vlan->next;
+ }
+
+ return NULL;
+}
+
+void addVlanSetting(unsigned int vlanId, unsigned char tagged, unsigned char member) {
+ struct vlan * old = settings.vlans;
+ struct vlan * new = (struct vlan *) malloc (sizeof( struct vlan) );
+ new->id = vlanId;
+ new->tag = tagged;
+ new->members = member;
+ new->next = old;
+ settings.vlans = new;
+}
+
+void hexDump (char * data, int len) {
+ int n;
+ for (n = 0; n < len; n++) {
+ if (n % 16 == 0)
+ printf("\n %06X |",n);
+ printf(" %02X", (int)data[n] & 0xFF);
+ }
+ printf("\n");
+}
+void addData(char * data, int len) {
+ gsDataLen += len;
+ gs105e_queryData = (char * )realloc(gs105e_queryData, sizeof(char) * gsDataLen);
+ memcpy(&gs105e_queryData[gsDataLen - len], data, len);
+}
+void addQuery(int qid) {
+ char queryData[] = {qid / 256, qid % 256, 0, 0};
+ addData(queryData, 4);
+}
+
+void addActData(int actId, int len, char * data) {
+
+ char actData[] = {actId / 256, actId % 256, len / 256, len % 256};
+ addData(actData, 4);
+
+ addData(data, len);
+}
+void gs105e_init(void) {
+ packetId = 0;
+ gs105e_devs = NULL;
+ gs105e_queryData = NULL;
+ gsDataLen = 0;
+ settings.vlans = NULL;
+}
+
+
+
+
+
+char newPacketId() {
+ packetId ++;
+ packetId %= 256;
+ return (char)packetId;
+}
+
+void makeHeader(unsigned int queryType) {
+ int n;
+
+
+
+ gs105e_queryData = (unsigned char * )realloc(gs105e_queryData, sizeof(char) * 32);
+ gsDataLen = 32;
+
+
+ for (n = 0; n < 32; n++)
+ gs105e_queryData[n] = 0;
+
+ gs105e_queryData[0] = queryType / 256;
+ gs105e_queryData[1] = queryType % 256;
+
+ memcpy(&gs105e_queryData[8], myMac, 6);
+ if (memcpy(settings.mac, "\x00\x00\x00\x00\x00\x00", 6))
+ memcpy(&gs105e_queryData[14], settings.mac, 6);
+
+ memcpy(&gs105e_queryData[24], "\x4e\x53\x44\x50", 4); //Magic!! :-O
+ if (settings.password != NULL && queryType == QR_EXEC) {
+
+ addActData(GS_PASSWORD, strlen(settings.password), settings.password);
+ }
+
+
+
+}
+
+
+void debug(void) {
+ hexDump(gs105e_queryData, gsDataLen);
+}
+
+void emptyBuffer(void) {
+ char tmp[2500];
+ while (recvBroadcast(tmp) > 0 ) {
+ ;;
+ }
+}
+
+void gs105e_query (void) {
+ emptyBuffer();
+ gs105e_queryData[23] = newPacketId();
+
+ if (gs105e_queryData[gsDataLen - 4] != 0xFF | gs105e_queryData[gsDataLen - 3] != 0xFF | gs105e_queryData[gsDataLen - 2] != 0x00 | gs105e_queryData[gsDataLen - 1] != 0x00)
+ addData("\xFF\xFF\x00\x00", 4);
+ sendBroadcast(gs105e_queryData, gsDataLen);
+
+}
+
+unsigned long toLong(char * data) {
+ int n;
+ unsigned long a;
+ for (n = 0; n < 8; n++) {
+ a <<= 8;
+ a |= ((unsigned long)data[n]) & 0xFF;
+ }
+ return a;
+}
+
+unsigned int toUInt4(char * data) {
+ int n;
+ unsigned int a;
+ for (n = 0; n < 4; n++) {
+ a <<= 8;
+ a |= ((unsigned int )data[n]) & 0xFF;
+ }
+ return a;
+}
+
+unsigned int toUInt(char * data) {
+ int n;
+ unsigned int a;
+ for (n = 0; n < 2; n++) {
+ a <<= 8;
+ a |= ((unsigned int )data[n]) & 0xFF;
+ }
+ return a;
+}
+
+void gs105e_interpret_slice(unsigned int ID, char * data, int len) {
+ int mLen , tmp;
+ struct portStatistic *p;
+ switch (ID) {
+ case GS_MODEL:;
+
+ mLen = (strstr(data, " ") - data) + 1;
+ settings.model = realloc(settings.model, sizeof(char) * mLen);
+ memcpy(settings.model, data, mLen);
+ break;
+ case GS_NAME:;
+ mLen= (strchr(data, 0x00) - data) + 1;
+ settings.name = realloc(settings.name, sizeof(char) * mLen);
+ memcpy(settings.name, data, mLen);
+ break;
+ case GS_MAC:;
+ memcpy(settings.mac, data, 6);
+ break;
+ case GS_IP:;
+ memcpy(settings.ip, data, 4);
+ break;
+ case GS_SUBNETMSK:;
+ memcpy(settings.subnetmask, data, 4);
+ break;
+ case GS_GATEWAY:;
+ memcpy(settings.gateway, data, 4);
+ break;
+ case GS_FIRMWAREVER:;
+ settings.swVersion = realloc(settings.swVersion, sizeof(char) * len);
+ memcpy(settings.swVersion, data, len);
+ break;
+ case GS_PACKETSTATISTICS:;
+ tmp = (unsigned int)data[0] - 1;
+ if (tmp > 5)
+ return;
+ p = &settings.portStatistics[tmp];
+ p->portId = tmp + 1;
+ p->bytesIn = toLong(&data[1]);
+ p->bytesOut = toLong(&data[9]);
+ p->errors = toLong(&data[41]);
+ break;
+ case GS_VLAN:;
+ unsigned int vlanId = toUInt(data);
+ unsigned char tagged = (unsigned char) data[3];
+ unsigned char memberOf = (unsigned char) data[2];
+ struct vlan * _vlan = getVlanSetting(vlanId);
+
+ if (_vlan == NULL) {
+ addVlanSetting(vlanId, tagged, memberOf);
+ }else {
+ _vlan->members = memberOf;
+ _vlan->tag = tagged;
+
+ }
+
+
+ break;
+ case GS_PORTSTATUS:;
+ unsigned int portId = (unsigned int) data[0];
+ unsigned char state = (unsigned char) data[1];
+ p = &settings.portStatistics[portId - 1];
+ p->state = state;
+ break;
+ case GS_PORTDIAG:;
+ p = &settings.portStatistics[data[0]];
+ p->cableError = toUInt4(&data[1]);
+ p->errorDist = toUInt4(&data[5]);
+ break;
+ case ACT_DHCP:;
+ settings.dhcp = data[1] & 0x03;
+ break;
+ }
+}
+
+int gs105e__receive(void) {
+ char data[2500];
+ int len = recvBroadcast(data);
+ int n;
+
+ unsigned int id;
+ unsigned int slLen;
+
+
+// if (len > 0)
+// hexDump(data, len);
+ if (len == -1) {
+// printf("Received No or Invalid Packet\n");
+ return -1;
+ }
+ if (memcmp(&data[8], myMac, 6) | data[0] != 0x01 | (!(data[1] == 0x02 | data[1] == 0x04))) {
+ return -1;
+ }
+
+ for (n = 32; n < len; ) {
+ id = (data[n] * 256) + data[n + 1];
+ slLen = (data[n+2] * 256) + data[n + 3];
+
+ gs105e_interpret_slice(id, &data[n + 4], slLen);
+ n += slLen + 4;
+ }
+ return 0;
+
+
+}
+
+int gs105e_receive(void) {
+ if (gs105e__receive() == -1) {
+ gs105e_query();
+ return gs105e_receive();
+ }
+ return 0;
+}
+
+
+int gs105e_actRecv(void) {
+ char data[2500];
+ int len = recvBroadcast_tout(data);
+ int n;
+
+ unsigned int id;
+ unsigned int slLen;
+
+
+// if (len > 0)
+// hexDump(data, len);
+ if (len == -1) {
+// printf("Received No or Invalid Packet\n");
+ return -1;
+ }
+ if (memcmp(&data[8], myMac, 6) | data[0] != 0x01 | (!(data[1] == 0x02 | data[1] == 0x04))) {
+ gs105e_actRecv();
+ return -1;
+ }
+
+ if (data[2] == 0) {
+ return data[2];
+ }
+}
+int gs105e_act() {
+ gs105e_query();
+ return gs105e_actRecv();
+}
+
+
+int gs105e_addVlan(int vlanId) {
+ makeHeader(QR_EXEC);
+
+ char data[4] = {vlanId / 256, vlanId % 256, 0, 0};
+
+ addActData(ACT_ADDVLAN, 4, data);
+
+ return gs105e_act();
+
+}
+
+int gs105e_setVlanMembers(unsigned int vlanId, unsigned int members, unsigned int tagged) {
+ char data[4] = {0, vlanId & 0xFF, (char)members & 0xFF, (char)tagged & 0xFF};
+ makeHeader(QR_EXEC);
+ addActData(GS_VLAN, 4, data);
+ return gs105e_act();
+
+}
+
+
+int gs105e_delVlan(int vlanId) {
+ makeHeader(QR_EXEC);
+
+ char data[2] = {vlanId / 256, vlanId % 256};
+
+ addActData(ACT_DELVLAN, 2, data);
+
+ return gs105e_act();
+
+}
+int gs105e_restart(int vlanId) {
+ makeHeader(QR_EXEC);
+
+ char data[1] = {1};
+
+ addActData(ACT_RESTART, 1, data);
+
+ return gs105e_act();
+
+}
+
+int gs105e_mirrorPorts(int outputPort, int mirrorMask) {
+ makeHeader(QR_EXEC);
+ char data[3] = {outputPort, 0, mirrorMask};
+
+ addActData(ACT_PORTMIRROR, 3, data);
+ return gs105e_act();
+}
+
+int gs105e_cableDiagnostics(int port) {
+ makeHeader(QR_EXEC);
+ char data[1] = {port};
+
+ addActData(ACT_PORTMIRROR, 3, data);
+ return gs105e_act();
+}
+
+int gs105e_setName(char * data) {
+ makeHeader(QR_EXEC);
+
+
+ addActData(GS_NAME, strlen(data), data);
+ return gs105e_act();
+}
+
+int gs105e_dhcpSettings(int action) {
+ makeHeader(QR_EXEC);
+ char data[1] = {(char)action};
+
+ addActData(ACT_DHCP, 1, data);
+ return gs105e_act();
+}
+
+void addDiscoveredDevice(int id) {
+
+ struct gs105e_discovered * ddev = gs105e_devs;
+
+ if (ddev == NULL) {
+ ddev = (struct gs105e_discovered *)malloc(sizeof(struct gs105e_discovered));
+ gs105e_devs = ddev;
+ }else {
+ while (ddev != NULL) {
+ if (memcmp(ddev->mac, settings.mac, 6))
+ continue;
+ ddev = ddev->next;
+ }
+ }
+
+ if (ddev == NULL) {
+ struct gs105e_discovered * ddev = gs105e_devs;
+ gs105e_devs = (struct gs105e_discovered *)malloc(sizeof(struct gs105e_discovered));
+ gs105e_devs->next = ddev;
+ ddev = gs105e_devs;
+ }
+ ddev->name = settings.name;
+ memcpy(ddev->mac, settings.mac, 6);
+ memcpy(ddev->ip, settings.ip, 4);
+ memcpy(ddev->gateway, settings.gateway, 4);
+ ddev->model = settings.model;
+ ddev->id = id;
+
+}
+
+
+int gs105e_discover(void) {
+ int n = 0;
+ struct gs105e_discovered * ddev = gs105e_devs;
+ struct gs105e_discovered * ddev_T;
+ while (ddev != NULL) {
+ ddev_T = ddev;
+ ddev = ddev->next;
+ free(ddev_T);
+ }
+ gs105e_devs = NULL;
+
+ makeHeader(QR_REQ);
+ addQuery(GS_MODEL);
+ addQuery(GS_NAME);
+ addQuery(GS_MAC);
+ addQuery(GS_IP);
+ addQuery(GS_SUBNETMSK);
+ addQuery(GS_GATEWAY);
+
+ gs105e_query ();
+ gs105e_query ();
+ while (gs105e__receive() == 0) {
+ addDiscoveredDevice(n + 1);
+ n++;
+ }
+ return n;
+
+}
+
+
+void gs105e_queryAll(void) {
+
+
+
+ if (settings.vlans != NULL) {
+ struct vlan * vl = settings.vlans;
+ struct vlan * vl_T;
+ while (vl != NULL) {
+ vl_T = vl;
+ vl = vl->next;
+ free(vl_T);
+ }
+ settings.vlans = NULL;
+ }
+
+ makeHeader(QR_REQ);
+ addQuery(GS_MODEL);
+ addQuery(GS_NAME);
+ addQuery(GS_MAC);
+ addQuery(GS_IP);
+ addQuery(GS_SUBNETMSK);
+ addQuery(GS_GATEWAY);
+ addQuery(GS_PACKETSTATISTICS);
+ addQuery(GS_FIRMWAREVER);
+ addQuery(ACT_DHCP);
+ addQuery(GS_PORTSTATUS);
+ addQuery(GS_VLAN);
+
+ gs105e_query ();
+ gs105e_receive();
+}
--- /dev/null
+#ifndef GS105E_H
+#define GS105E_H
+#include <stdio.h>
+
+#define GS_MODEL 0x0001
+#define GS_NAME 0x0003
+#define GS_MAC 0x0004
+#define GS_IP 0x0006
+#define GS_SUBNETMSK 0x0007
+#define GS_GATEWAY 0x0008
+
+#define GS_NEWPASSWORD 0x0009
+#define GS_PASSWORD 0x000a
+
+#define GS_FIRMWAREVER 0x000d
+
+#define GS_PACKETSTATISTICS 0x1000
+
+#define GS_VLAN 0x2800
+#define GS_PORTSTATUS 0x0c00
+#define GS_PORTDIAG 0x1c00
+#define ACT_DHCP 0x000b
+
+
+#define ACT_ADDVLAN 0x2800
+#define ACT_DELVLAN 0x2c00
+#define ACT_RESTART 0x0013
+#define ACT_PORTMIRROR 0x5c00
+
+
+
+#define QR_REQ 0x0101
+#define QR_ANSWER 0x0102
+#define QR_EXEC 0x0103
+#define QR_EXECUTED 0x0104
+
+#define MSK_PORT1 0x80
+#define MSK_PORT2 0x40
+#define MSK_PORT3 0x20
+#define MSK_PORT4 0x10
+#define MSK_PORT5 0x08
+
+
+#define DHCP_ON 0x01
+#define DHCP_OFF 0x00
+#define DHCP_RENEW 0x02
+
+int packetId;
+
+struct vlan {
+ int id;
+ char members;
+ char tag;
+ struct vlan * next;
+};
+
+struct portSniffing {
+ char ports;
+ char output;
+};
+
+struct portStatistic {
+ char portId;
+ unsigned long bytesIn;
+ unsigned long bytesOut;
+ unsigned long errors;
+ char state;
+ char cableError;
+ char errorDist;
+};
+
+struct gs105e_settings {
+
+ char * password;
+ char * model;
+
+ char mac[6];
+ char ip[4];
+ char subnetmask[4];
+ char gateway[4];
+
+ char * name;
+ char * swVersion;
+
+ char dhcp;
+
+ struct vlan * vlans;
+
+
+
+ struct portStatistic portStatistics[5];
+
+ struct portSniffing portMonitor;
+
+
+};
+
+
+struct gs105e_discovered {
+ int id;
+ char * model;
+
+ char mac[6];
+ char ip[4];
+ char subnetmask[4];
+ char gateway[4];
+
+ char * name;
+ struct gs105e_discovered * next;
+};
+
+
+struct gs105e_discovered * gs105e_devs ;
+
+struct gs105e_settings settings;
+
+void debug(void);
+
+void gs105e_init(void) ;
+void makeHeader(unsigned int queryType);
+
+void gs105e_query (void);
+
+int gs105e_addVlan(int vlanId) ;
+int gs105e_delVlan(int vlanId) ;
+int gs105e_discover(void);
+
+int gs105e_setName(char * data);
+#endif
--- /dev/null
+#include <stdio.h>
+#include "socket.h"
+#include "packet.h"
+#include "gs105e.h"
+#include <stdlib.h>
+#include <string.h>
+#include "shell.h"
+#include <pwd.h>
+int shellHandler = 0;
+
+/*void shellHandlers[] = {
+
+
+}*/
+
+
+int main () {
+ int n;
+
+ init_socket();
+
+ myMac = get_mac("eth0");
+
+ gs105e_init();
+
+ shell();
+ /*
+ printf("Model: %s\n", settings.model);
+ struct vlan * vl = settings.vlans;
+
+ if (vl == NULL) {
+ printf("NO Vlans\n");
+ } else
+ printf("Vlans\n");
+
+ while (vl != NULL) {
+ printf("%u\t", vl->id);
+ for (n = 0; n < 5; n++)
+ printf("%c\t", vl->members & (0x80 >> n) ? (vl->tag & (0x80 >> n) ? 'T' : 'U') : '-', (unsigned int) vl->members);
+ printf("\n");
+ vl = vl->next;
+ }
+
+ for (n = 0; n < 5; n++) {
+ printf("Port %u\t%s\t\t%lu Bytes in\t\t%lu Bytes out\n", n + 1,
+ (settings.portStatistics[n].state == 0x05 ? "1000 Mbit/s" : (settings.portStatistics[n].state == 0x04 ? "100 Mbit/s" : (settings.portStatistics[n].state == 0x03 ? "10 Mbit/s": (settings.portStatistics[n].state == 0x00 ? "no connection": "???")))), settings.portStatistics[n].bytesIn, settings.portStatistics[n].bytesOut);
+ }
+
+
+
+ //settings.password = "password";
+
+ //gs105e_mirrorPorts(3, MSK_PORT1|MSK_PORT4);
+
+ */
+}
+
+
+
+
+
--- /dev/null
+#include "packet.h"
+
+unsigned short toShort(char * data) {
+ return (((unsigned short) data[0]) << 8) | ((unsigned short) data[1]);
+}
+
+struct packet genPacket(char * data, int length) {
+
+ struct packet pck;
+ //(*((unsigned long*)&dns_server_ip[0]))
+
+
+ pck.packetId = toShort(&data[0]);
+ pck.packetLen = toShort(&data[2]);
+
+
+
+ pck.data = 0;
+
+ return pck;
+}
--- /dev/null
+
+
+struct packet genPacket(char * data, int length);
+
+struct packet {
+ unsigned short packetId;
+ unsigned short packetLen;
+ char myMac[6];
+
+ char devMac[6];
+
+ unsigned char * data;
+};
--- /dev/null
+#include "shell.h"
+
+
+unsigned int countTokens(char * data, char * deli) {
+ unsigned int n = 0;
+ char * lp;
+
+ char * da = malloc(sizeof(char) * strlen(data));
+ strcpy(da, data);
+
+ lp = strtok(da, deli);
+ while (lp != NULL) {
+ lp = strtok(NULL, deli);
+ n++;
+ }
+
+ return n;
+}
+
+unsigned int split(char *** _data, char * text, char * deli) {
+
+
+
+ unsigned int elements = countTokens(text, deli);
+
+ *_data = malloc( sizeof(char *) * (elements + 1));
+
+ char ** data = (char **)*_data;
+
+ char * lp = strtok(text, deli);
+
+ unsigned int n = 0;
+
+ data[elements - 1] = NULL;
+
+ while (lp != NULL) {
+ data[n] = (char*)malloc( sizeof(char *) * (strlen(lp) + 1));
+ strcpy(data[n], lp);
+ data[n][strlen(lp)] = 0;
+ lp = strtok(NULL, deli);
+ n++;
+ }
+ return elements;
+}
+
+void printIp(char * data) {
+ printf("\033[92m%u.%u.%u.%u\033[0m\n",data[0]&0xff, data[1]&0xff, data[2]&0xff, data[3]&0xff);
+}
+void printError(int errCode) {
+ switch (errCode) {
+ case 0x00:;
+ printf("\033[92mSuccess!\033[0m\n");
+ gs105e_queryAll();
+ break;
+ case -1:;
+ printf("\033[91mSwitch does not answer!\033[0m\n");
+ break;
+ case 0x07:;
+ printf("\033[91mWrong Password, try again!\033[0m\n");
+ settings.password = NULL;
+ break;
+ default:;
+ printf("\033[91mUups, unknown Error!?\033[0m\n");
+ break;
+ }
+}
+
+void shell_set(char ** argv, int elem) {
+
+ int n;
+ if (strncmp(argv[1], "name", 4) == 0) {
+ if (elem != 3) {
+ printf("set name [name]\n");
+ return;
+ }
+ printError(gs105e_setName(argv[2]));
+ }
+}
+
+void password(void) {
+ if (settings.password == NULL) {
+ printf("\033[91mWarning: As the protocol of the switch wants it that way, all configuration packets are send as broadcasts, meaning everyone on this net can sniff your password!\033[0m\n");
+ settings.password = getpass("Password: ");
+ }
+}
+
+
+
+
+int shell (void) {
+
+ char cmd[300];
+ int elem = 0;
+ char **argv;
+ int n;
+
+ struct gs105e_discovered * ddev;
+
+ char * dev = "nodev";
+ while (1) {
+ printf("\033[96mgs (\033[93m%s\033[96m)# \033[0m", dev);
+ cmd[0] = 0;
+ fflush(0);
+ if (fgets(cmd, 300, stdin) == NULL) { //STRG + D
+ printf("\nExiting ...\n");
+ return 0;
+
+ }
+
+
+
+ cmd[strlen(cmd) - 1] = 0;
+
+ //Check for an empty command line
+ if (strlen(cmd) == 0) {
+ continue;
+ }
+
+
+ //Check for the exit Command
+ if (strncmp(cmd, "exit", 4) == 0 && strlen(cmd) == 4)
+ return 0;
+
+ elem = split(&argv, cmd, " ");
+
+
+
+ if (strncmp(argv[0], "discover", 8) == 0) {
+ n = gs105e_discover();
+ printf("Discovered \033[92m%i\033[0m devices\n", n);
+
+ ddev = gs105e_devs;
+
+ printf("ID\tName\t\tMAC\t\tIP\n");
+
+ while (ddev != NULL) {
+ printf("%i\t%s\t\t%X:%X:%X:%X:%X:%X\t%u.%u.%u.%u\n", ddev->id, ddev->name, ddev->mac[0]&0xff, ddev->mac[1]&0xff, ddev->mac[2]&0xff, ddev->mac[3]&0xff, ddev->mac[4]&0xff, ddev->mac[5]&0xff, ddev->ip[0]&0xff, ddev->ip[1]&0xff, ddev->ip[2]&0xff, ddev->ip[3]&0xff);
+ ddev = ddev->next;
+ }
+
+ if (n == 1) {
+ printf("only one switch, selecting 1\n");
+
+ memcpy(settings.mac, gs105e_devs->mac, 6);
+ gs105e_queryAll();
+ dev = gs105e_devs->name;
+ }
+ }
+
+
+
+ if (strncmp(argv[0], "select", 6) == 0 && elem == 2) {
+ n = atoi(argv[1]);
+ if (n == 0){
+ printf("Please select a valid ID\n");
+ continue;
+ }
+ ddev = gs105e_devs;
+ while (ddev != NULL) {
+ if (n == ddev->id)
+ break;
+ ddev = ddev->next;
+ }
+
+ if (ddev == NULL){
+ printf("Please select a valid ID\n");
+ continue;
+ }
+
+ memcpy(settings.mac, ddev->mac, 6);
+ gs105e_queryAll();
+ dev = ddev->name;
+
+ }
+
+ if (strncmp(dev, "nodev", 6) == 0){
+ printf("Discover and select device first!\n");
+ continue;
+ }
+
+ if (strncmp(argv[0], "ip", 2) == 0) {
+ shell_ip(argv, elem);
+ }
+ if (strncmp(argv[0], "vlan", 4) == 0) {
+ shell_vlan(argv, elem);
+ }
+ if (strncmp(argv[0], "port", 4) == 0) {
+ shell_port(argv, elem);
+ }
+
+
+
+
+ }
+}
+
--- /dev/null
+#ifndef SHELL_H
+#define SHELL_H
+
+#include <stdio.h>
+#include "socket.h"
+
+#include "gs105e.h"
+#include <stdlib.h>
+#include <string.h>
+
+#include <pwd.h>
+
+void shell_ip(char ** argv, int elem);
+
+
+int shell(void);
+void password(void) ;
+void printError(int errCode);
+void printIp(char * data);
+void shell_port(char ** argv, int elem);
+
+#endif
--- /dev/null
+#include "shell.h"
+void shell_ip(char ** argv, int elem) {
+
+ int n;
+ if (elem == 1) {
+ printf(" ip [show|dhcp|set] \n");
+ return;
+ }
+
+ if (strncmp(argv[1], "show", 2) == 0) {
+
+ printf("IP:\t\t");
+ printIp(settings.ip);
+ printf("DHCP:\t\t%s\n", settings.dhcp == 0x01 ? "ON":"OFF");
+ printf("Subnetmask:\t");
+ printIp(settings.subnetmask);
+ printf("Gateway:\t");
+ printIp(settings.gateway);
+ printf("\n");
+ return;
+ }
+ if (strncmp(argv[1], "dhcp", 4) == 0) {
+ if (elem == 2) {
+ printf("ip dhcp [on|off|renew]\n");
+ printf(" on: Turn on DHCP\n");
+ printf(" off: Turn off DHCP, current IP will be taken\n");
+ printf(" renew: renew IP-Address via DHCP (turns on DHCP too)\n");
+ }else {
+ password();
+ if (strncmp(argv[2], "on", 2) == 0) {
+ printError(gs105e_dhcpSettings(DHCP_ON));
+ } else if (strncmp(argv[2], "off", 3) == 0) {
+ printError(gs105e_dhcpSettings(DHCP_OFF));
+ } else if (strncmp(argv[2], "renew", 5) == 0) {
+ printError(gs105e_dhcpSettings(DHCP_RENEW));
+ }
+
+ }
+ }
+}
--- /dev/null
+#include "shell.h"
+
+void shell_port(char ** argv, int elem) {
+
+ int n;
+
+ if (elem == 1) {
+
+ return;
+ }
+ if (strncmp(argv[1], "show", 4) == 0) {
+ printf("Port\tSpeed\t\tBytes In\t\tBytes Out\n");
+ for (n = 0; n< 5; n++) {
+ printf("%i\t%s\t% 8lu\t\t% 8lu\n", n,
+ (settings.portStatistics[n].state == 0x05 ? "1000 Mbit/s" : (settings.portStatistics[n].state == 0x04 ? "100 Mbit/s" : (settings.portStatistics[n].state == 0x03 ? "10 Mbit/s": (settings.portStatistics[n].state == 0x00 ? "No Cable": "???")))),
+ settings.portStatistics[n].bytesIn,
+ settings.portStatistics[n].bytesOut
+ );
+ }
+ }
+}
--- /dev/null
+#include "shell.h"
+
+void shell_vlan(char ** argv, int elem) {
+
+ int n, m, o;
+
+ if (elem == 1) {
+
+ return;
+ }
+ if (strncmp(argv[1], "show", 4) == 0) {
+ struct vlan * vl = settings.vlans;
+
+ if (vl == NULL) {
+ printf("NO Vlans\n");
+ return;
+ } else
+ printf("Vlans\n");
+
+ while (vl != NULL) {
+ printf("%u\t", vl->id);
+ for (n = 0; n < 5; n++)
+ printf("%s\t", vl->members & (0x80 >> n) ? (vl->tag & (0x80 >> n) ? "\033[93mT\033[0m" : "\033[92mU\033[0m") : "\033[91m-\033[0m", (unsigned int) vl->members);
+ printf("\n");
+ vl = vl->next;
+ }
+
+ }else if (strncmp(argv[1], "add", 3) == 0) {
+ if (elem != 3) {
+ printf("You need to provide a vlan ID to add!\n");
+ return;
+ }
+ n = atoi(argv[2]);
+ if (n <= 0) {
+ printf("Invalid id!\n");
+ return;
+ }
+ password();
+ printError(gs105e_addVlan(n));
+ }else if (strncmp(argv[1], "del", 3) == 0) {
+
+ if (elem != 3) {
+ printf("You need to provide a vlan ID to add!\n");
+ return;
+ }
+ n = atoi(argv[2]);
+
+ struct vlan * vl = settings.vlans;
+
+ while (vl != NULL) {
+ if (vl->id == n)
+ break;
+ vl = vl->next;
+ }
+ if (vl == NULL)
+ n = 0;
+
+ if (n <= 0) {
+ printf("Invalid id!\n");
+ return;
+ }
+ password();
+ printError(gs105e_delVlan(n));
+ }else if (strncmp(argv[1], "assign", 6) == 0) {
+ if (elem != 5) {
+ printf("vlan assign [vlan ID] [port ID] [T|U]\n");
+ return;
+ }
+ int n = atoi(argv[2]);
+ struct vlan * vl = settings.vlans;
+
+ while (vl != NULL) {
+ if (vl->id == n)
+ break;
+ vl = vl->next;
+ }
+ if (vl == NULL)
+ n = 0;
+
+ if (n <= 0) {
+ printf("Invalid Vlan ID\n");
+ return;
+ }
+
+ m = atoi(argv[3]);
+
+ if (m < 1 | m > 5) {
+ printf("Invalid Port ID\n");
+ return;
+ }
+
+ m = (0x80 >> ((m & 0xFF) - 1)) | (int)vl->members;
+
+ if (strncmp(argv[4], "T", 1) == 0) {
+ o = (int)vl->tag | m;
+ }else if (strncmp(argv[4], "U", 1) == 0) {
+ o = (int)vl->tag &(~((char)m));
+ }
+ password();
+ printError(gs105e_setVlanMembers(n, m, o));
+
+ }else if (strncmp(argv[1], "revoke", 6) == 0) {
+ if (elem != 4) {
+ printf("vlan revoke [vlan ID] [port ID]\n");
+ return;
+ }
+ int n = atoi(argv[2]);
+ struct vlan * vl = settings.vlans;
+
+ while (vl != NULL) {
+ if (vl->id == n)
+ break;
+ vl = vl->next;
+ }
+ if (vl == NULL)
+ n = 0;
+
+ if (n <= 0) {
+ printf("Invalid Vlan ID\n");
+ return;
+ }
+
+ m = atoi(argv[3]);
+
+ if (m < 1 | m > 5) {
+ printf("Invalid Port ID\n");
+ return;
+ }
+
+ m = (~(0x80 >> ((m & 0xFF) - 1))) & (int)vl->members;
+
+
+ o = (int)vl->tag &(~((char)m));
+
+ password();
+ printError(gs105e_setVlanMembers(n, m, o));
+
+ }
+}
--- /dev/null
+#include <arpa/inet.h>
+#include <sys/socket.h>
+#include <stdlib.h>
+#include <string.h>
+#include <unistd.h>
+#include <stdio.h>
+#include <sys/ioctl.h>
+#include <netinet/in.h>
+#include <net/if.h>
+#include "socket.h"
+#include <sys/select.h>
+int sock;
+
+
+struct sockaddr_in sockAddr;
+
+unsigned char * get_mac(const char *intf) {
+ unsigned char * mac = (unsigned char *) malloc(sizeof(unsigned char *) * 6);
+ struct ifreq iface;
+ unsigned char i;
+
+ int tmpSock = socket(PF_INET, SOCK_DGRAM, IPPROTO_UDP);
+
+
+ //How to get the MAC of the Interface: http://www.geekpage.jp/en/programming/linux-network/get-macaddr.php
+ iface.ifr_addr.sa_family = AF_INET;
+ strncpy(iface.ifr_name, intf, IFNAMSIZ-1);
+ ioctl(tmpSock, SIOCGIFHWADDR, &iface);
+ close(tmpSock);
+
+ for (i = 0; i < 6; i++)
+ mac[i] = (unsigned char)iface.ifr_hwaddr.sa_data[i];
+
+ return mac;
+}
+
+void init_socket() {
+ sock = socket(PF_INET, SOCK_DGRAM, IPPROTO_UDP);
+
+ if (sock == -1) {
+ printf("Could not create Socket\n");
+ exit(1);
+ }
+
+
+
+ memset(&sockAddr, 0, sizeof(sockAddr));
+ sockAddr.sin_family = AF_INET;
+ sockAddr.sin_addr.s_addr = htonl(INADDR_ANY);
+ sockAddr.sin_port = htons(63321);
+
+ if (bind(sock, (struct sockaddr *) &sockAddr, sizeof(sockAddr)) < 0) {
+ printf("Could not bind to socket\n");
+ exit(1);
+ }
+
+
+}
+
+
+int sendBroadcast(char * data, unsigned int len) {
+
+ int bcp = 1;
+ if (setsockopt(sock, SOL_SOCKET, SO_BROADCAST, (void *) &bcp, sizeof(bcp)) < 0) {
+ printf("Could not broadcast data\n");
+ exit(1);
+ }
+
+ struct sockaddr_in bcAddr;
+
+ bcAddr.sin_family = AF_INET;
+ bcAddr.sin_addr.s_addr = inet_addr("255.255.255.255");
+ bcAddr.sin_port = htons(63322);
+
+ return sendto(sock, data, len, 0, (struct sockaddr *) &bcAddr, sizeof(bcAddr));
+
+
+}
+
+int recvBroadcast(char * data) {
+
+ struct sockaddr_in sa_in;
+ int sa_len = sizeof(sa_in);
+ struct timeval tout;
+ tout.tv_sec = 0;
+ tout.tv_usec = 500000;
+ fd_set fds;
+ FD_ZERO(&fds);
+ FD_SET(sock, &fds);
+ int s = select(sock + 1, &fds, NULL, NULL, &tout);
+ if (s <= 0)
+ return -1;
+ return recvfrom(sock, data, PACKET_BUFFER, 0,(struct sockaddr * )&sa_in, &sa_len);
+
+}
+
+
+int recvBroadcast_tout(char * data) {
+
+ struct sockaddr_in sa_in;
+ int sa_len = sizeof(sa_in);
+ struct timeval tout;
+ tout.tv_sec = 5;
+ tout.tv_usec = 0;
+ fd_set fds;
+ FD_ZERO(&fds);
+ FD_SET(sock, &fds);
+ int s = select(sock + 1, &fds, NULL, NULL, &tout);
+ if (s <= 0)
+ return -1;
+ return recvfrom(sock, data, PACKET_BUFFER, 0,(struct sockaddr * )&sa_in, &sa_len);
+
+}
+
+
--- /dev/null
+void init_socket();
+unsigned char * get_mac(const char *intf);
+
+unsigned char * myMac;
+
+#define PACKET_BUFFER 2500