#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#define CSV_LINE_MAX 128 /** maximum charactors per line **/
#define MAX_LINES 66 /** maximum lines of CSV file(1..66) **/
#define COLUMUN_DATE 28
#define COLUMUN_VERSION 55
#define FILTER_RULE_FILE_NAME "/export/http/import/iPASOLINK-filter.csv"
const char ccMTYPE[ ] = "iPASOLINK UX" ;
const char ccKIND[ ] = "Filtering Rule" ;
const char ccLINE2[ ] = "Rule ID" ;
typedef struct { /** CSVファイルから読み込んだFilter Rule **/
unsigned char ucExportTime[ 26 ] ;
unsigned char ucFVersion[ 8 ] ;
struct {
int iRuleID;
int iSourcePort;
int iAction;
int iFilterType;
int iTagMask;
int iVlanID;
int iMacAddressMask;
unsigned char cMacAddress[ 17 ] ; /** xx:xx:xx:xx:xx:xx **/
unsigned char dummy;
} stFilterRules[ MAX_LINES- 2 ] ; /** 64record maximum **/
} FilterDataFmt;
FilterDataFmt FilterRule;
/**************************************************************************
*
* read from CSV file (Filter Rules defined)
*
* return: 0:OK,
* -1:NG(no file, file format error)
*
**************************************************************************/
int LoadFilterRuleFile( FilterDataFmt * Save_p )
{
char * cRet;
int iRet, iLine;
int i;
FILE * File_h; /** file handle **/
char ucBuff[ CSV_LINE_MAX] ; /** temporary data buffer from CSV file **/
char * ary[ 8 ] ; /** for after 3line CSV **/
const int dTbl[ ] = { 2 , 5 , 8 , 11 , 14 } ; /** ":"/"-"charactor offset within MAC address **/
const int nTbl[ ] = { 0 , 3 , 6 , 9 , 12 , 15 } ; /** Hex data of octet **/
File_h
= fopen ( FILTER_RULE_FILE_NAME
, "r" ) ; /** Open CSV file **/ if ( File_h == NULL ) {
/** file not found */
return - 1 ;
}
iRet = 0 ;
for ( iLine = 0 ; iLine < MAX_LINES; iLine++ ) {
cRet
= fgets ( ucBuff
, CSV_LINE_MAX
, File_h
) ; /** read 1 line from CSV file **/ if ( cRet == NULL) { /** EOF **/
if ( iLine < 3 ) {
iRet = - 1 ; /** CSV file format error **/
}
else {
iRet = 0 ; /** read from CSV file complete **/
}
iLine = MAX_LINES; /** end of "for loop" **/
}
switch ( iLine ) {
case 0 : /** 1st line **/
/** check ',' charactor **/
if ( ( strncmp ( ucBuff
, ccMTYPE
, strlen ( ccMTYPE
) ) != 0 ) || ( ucBuff
[ 12 ] != ',' ) || ( strncmp ( & ucBuff
[ 13 ] , ccKIND
, strlen ( ccKIND
) ) != 0 ) || ( ucBuff
[ 27 ] != ',' ) || ( ucBuff
[ 54 ] != ',' ) ) { iLine = MAX_LINES;
iRet = - 1 ; /** NG - CSV file format error **/
}
else { /** format ok **/
/** copy last export date & time **/
memcpy ( Save_p
-> ucExportTime
, & ucBuff
[ COLUMUN_DATE
] , sizeof ( Save_p
-> ucExportTime
) ) ; memcpy ( Save_p
-> ucFVersion
, & ucBuff
[ COLUMUN_VERSION
] , sizeof ( Save_p
-> ucFVersion
) ) ; }
break ;
case 1 : /** 2nd line **/
if ( strncmp ( ucBuff
, ccLINE2
, strlen ( ccLINE2
) ) != 0 ) { /** NG - format error **/ iLine = MAX_LINES;
iRet = - 1 ;
}
break ;
case MAX_LINES: /** error or EOF **/
break ;
default : /** from 3rd to last line **/
ary
[ 0 ] = strtok ( ucBuff
, "," ) ; /** Rule ID(「1~100」であること) **/ Save_p
-> stFilterRules
[ iLine
] .
iRuleID = atoi ( ary
[ 0 ] ) ; if ( ( Save_p-> stFilterRules[ iLine] .iRuleID < 1 ) || ( Save_p-> stFilterRules[ iLine] .iRuleID > 100 ) ) {
iLine = MAX_LINES;
iRet = - 1 ;
break ;
}
ary
[ 1 ] = strtok ( NULL
, "," ) ; /** Source Port(「1~4」であること) **/ Save_p
-> stFilterRules
[ iLine
] .
iSourcePort = atoi ( ary
[ 1 ] ) ; if ( ( Save_p-> stFilterRules[ iLine] .iSourcePort < 1 ) || ( Save_p-> stFilterRules[ iLine] .iSourcePort > 4 ) ) {
iLine = MAX_LINES;
iRet = - 1 ;
break ;
}
ary
[ 2 ] = strtok ( NULL
, "," ) ; /** Action(「1~2」であること) **/ Save_p
-> stFilterRules
[ iLine
] .
iAction = atoi ( ary
[ 2 ] ) ; if ( ( Save_p-> stFilterRules[ iLine] .iAction < 1 ) || ( Save_p-> stFilterRules[ iLine] .iAction > 2 ) ) {
iLine = MAX_LINES;
iRet = - 1 ;
break ;
}
ary
[ 3 ] = strtok ( NULL
, "," ) ; /** Filter Type(「1」であること) **/ Save_p
-> stFilterRules
[ iLine
] .
iFilterType = atoi ( ary
[ 3 ] ) ; if ( Save_p-> stFilterRules[ iLine] .iFilterType != 1 ) {
iLine = MAX_LINES;
iRet = - 1 ;
break ;
}
ary
[ 4 ] = strtok ( NULL
, "," ) ; /** VLAN Tag Mask(「1~3」であること) **/ Save_p
-> stFilterRules
[ iLine
] .
iTagMask = atoi ( ary
[ 4 ] ) ; if ( ( Save_p-> stFilterRules[ iLine] .iTagMask < 1 ) || ( Save_p-> stFilterRules[ iLine] .iTagMask > 3 ) ) {
iLine = MAX_LINES;
iRet = - 1 ;
break ;
}
ary
[ 5 ] = strtok ( NULL
, "," ) ; /** VLAN ID(「1~4094」であること) **/ Save_p
-> stFilterRules
[ iLine
] .
iVlanID = atoi ( ary
[ 5 ] ) ; if ( ( Save_p-> stFilterRules[ iLine] .iVlanID < 1 ) || ( Save_p-> stFilterRules[ iLine] .iVlanID > 4094 ) ) {
iLine = MAX_LINES;
iRet = - 1 ;
break ;
}
ary
[ 6 ] = strtok ( NULL
, "," ) ; /** Source MAC Address Mask(「1~2」であること)**/ Save_p
-> stFilterRules
[ iLine
] .
iMacAddressMask = atoi ( ary
[ 6 ] ) ; if ( ( Save_p-> stFilterRules[ iLine] .iMacAddressMask < 1 ) || ( Save_p-> stFilterRules[ iLine] .iMacAddressMask > 2 ) ) {
iLine = MAX_LINES;
iRet = - 1 ;
break ;
}
ary
[ 7 ] = strtok ( NULL
, "," ) ; /** Source MAC Address(MAC Address形式であること)**/ strcpy ( Save_p
-> stFilterRules
[ iLine
] .
cMacAddress , ary
[ 7 ] ) ; for ( i = 0 ; i < sizeof ( dTbl) ; i++ ) {
if ( ( isxdigit ( ( int ) Save_p
-> stFilterRules
[ iLine
] .
cMacAddress [ nTbl
[ i
] ] ) != 0 ) || ( isxdigit ( ( int ) Save_p
-> stFilterRules
[ iLine
] .
cMacAddress [ nTbl
[ i
+ 1 ] ] ) != 0 ) ) { /** charactor is not hexdecimal digit **/
iLine = MAX_LINES;
iRet = - 1 ;
break ;
}
if ( ( Save_p-> stFilterRules[ iLine] .cMacAddress [ dTbl[ i] ] != ":" ) &&
( Save_p-> stFilterRules[ iLine] .cMacAddress [ dTbl[ i] ] != "-" ) ) {
/** delimitter is not MAC address format **/
iLine = MAX_LINES;
iRet = - 1 ;
break ;
}
}
break ;
} /** end of switch **/
} /** enf of for loop **/
return iRet;
}
#include <stdio.h>
#include <stdlib.h>
#include <string.h> 
#include <ctype.h>

#define CSV_LINE_MAX	128												/** maximum charactors per line					**/
#define MAX_LINES		66												/** maximum lines of CSV file(1..66)			**/
#define COLUMUN_DATE	28
#define COLUMUN_VERSION	55
#define FILTER_RULE_FILE_NAME "/export/http/import/iPASOLINK-filter.csv"

const char ccMTYPE[] = "iPASOLINK UX";
const char ccKIND[] = "Filtering Rule";
const char ccLINE2[] = "Rule ID";

typedef struct {																/** CSVファイルから読み込んだFilter Rule		**/
	unsigned char ucExportTime[26];
	unsigned char ucFVersion[8];
	struct {
		int iRuleID;
		int iSourcePort;
		int iAction;
		int iFilterType;
		int iTagMask;
		int iVlanID;
		int iMacAddressMask;
		unsigned char cMacAddress[17];									/** xx:xx:xx:xx:xx:xx							**/
		unsigned char dummy;
	} stFilterRules[MAX_LINES-2];										/** 64record maximum							**/
} FilterDataFmt;

FilterDataFmt FilterRule;

/**************************************************************************
*
*	read from CSV file (Filter Rules defined)
*
*	return:	 0:OK,
*			-1:NG(no file, file format error)
*
**************************************************************************/
int LoadFilterRuleFile( FilterDataFmt *Save_p )
{
char *cRet;
int iRet,iLine;
int i;
FILE *File_h;															/** file handle									**/
char ucBuff[CSV_LINE_MAX];												/** temporary data buffer from CSV file			**/
char *ary[8];															/** for after 3line CSV							**/
const int dTbl[] = { 2,5,8,11,14 };										/** ":"/"-"charactor offset within MAC address	**/
const int nTbl[] = { 0,3,6,9,12,15 };									/** Hex data of octet							**/

	File_h = fopen( FILTER_RULE_FILE_NAME, "r" );						/** Open CSV file								**/
	if( File_h == NULL ) {
		/** file not found			*/
		return -1;
	}

	iRet = 0;
	for( iLine = 0; iLine < MAX_LINES; iLine++ ) {
		cRet = fgets( ucBuff, CSV_LINE_MAX, File_h );					/** read 1 line from CSV file					**/
		if(cRet == NULL)	{											/** EOF											**/
			if( iLine < 3 ) {
				iRet = -1;												/** CSV file format error						**/
			}
			else {
				iRet = 0;												/** read from CSV file complete					**/
			}
			iLine = MAX_LINES;											/** end of "for loop"							**/
		}
		switch( iLine ) {
			case 0:		/** 1st line				**/
				/** check ',' charactor				**/
				if(( strncmp( ucBuff, ccMTYPE, strlen(ccMTYPE) ) != 0 ) || ( ucBuff[12] != ',') ||
				   ( strncmp( &ucBuff[13], ccKIND, strlen(ccKIND) ) != 0 ) || ( ucBuff[27] != ',' ) || ( ucBuff[54] != ',' )) {
					iLine = MAX_LINES;
					iRet = -1;											/** NG - CSV file format error					**/
				}
				else {													/** format ok									**/
					/** copy last export date & time		**/
					memcpy( Save_p->ucExportTime, &ucBuff[COLUMUN_DATE], sizeof(Save_p->ucExportTime) );
					memcpy( Save_p->ucFVersion, &ucBuff[COLUMUN_VERSION], sizeof(Save_p->ucFVersion) );
				}
				break;
			case 1:		/** 2nd line				**/
				if( strncmp( ucBuff, ccLINE2, strlen(ccLINE2) ) != 0 ) {/** NG - format error							**/
					iLine = MAX_LINES;
					iRet = -1;
				}
				break;
			case MAX_LINES:												/** error or EOF								**/
				break;
			default:	/** from 3rd to last line	**/
				ary[0] = strtok( ucBuff, "," );							/** Rule ID（「1～100」であること）				**/
				Save_p->stFilterRules[iLine].iRuleID = atoi( ary[0] );
				if(( Save_p->stFilterRules[iLine].iRuleID < 1 ) || ( Save_p->stFilterRules[iLine].iRuleID > 100 )) {
					iLine = MAX_LINES;
					iRet = -1;
					break;
				}
				ary[1] = strtok( NULL, "," );							/** Source Port（「1～4」であること）			**/
				Save_p->stFilterRules[iLine].iSourcePort = atoi( ary[1] );
				if(( Save_p->stFilterRules[iLine].iSourcePort < 1 ) || ( Save_p->stFilterRules[iLine].iSourcePort > 4 )) {
					iLine = MAX_LINES;
					iRet = -1;
					break;
				}
				ary[2] = strtok( NULL, "," );							/** Action（「1～2」であること）				**/
				Save_p->stFilterRules[iLine].iAction = atoi( ary[2] );
				if(( Save_p->stFilterRules[iLine].iAction < 1 ) || ( Save_p->stFilterRules[iLine].iAction > 2 )) {
					iLine = MAX_LINES;
					iRet = -1;
					break;
				}
				ary[3] = strtok( NULL, "," );							/** Filter Type（「1」であること）				**/
				Save_p->stFilterRules[iLine].iFilterType = atoi( ary[3] );
				if( Save_p->stFilterRules[iLine].iFilterType != 1 ) {
					iLine = MAX_LINES;
					iRet = -1;
					break;
				}
				ary[4] = strtok( NULL, "," );							/** VLAN Tag Mask（「1～3」であること）			**/
				Save_p->stFilterRules[iLine].iTagMask = atoi( ary[4] );
				if(( Save_p->stFilterRules[iLine].iTagMask < 1 ) || ( Save_p->stFilterRules[iLine].iTagMask > 3 )) {
					iLine = MAX_LINES;
					iRet = -1;
					break;
				}
				ary[5] = strtok( NULL, "," );							/** VLAN ID（「1～4094」であること）			**/
				Save_p->stFilterRules[iLine].iVlanID = atoi( ary[5] );
				if(( Save_p->stFilterRules[iLine].iVlanID < 1 ) || ( Save_p->stFilterRules[iLine].iVlanID > 4094 )) {
					iLine = MAX_LINES;
					iRet = -1;
					break;
				}
				ary[6] = strtok( NULL, "," );							/** Source MAC Address Mask（「1～2」であること）**/
				Save_p->stFilterRules[iLine].iMacAddressMask = atoi( ary[6] );
				if(( Save_p->stFilterRules[iLine].iMacAddressMask < 1 ) || ( Save_p->stFilterRules[iLine].iMacAddressMask > 2 )) {
					iLine = MAX_LINES;
					iRet = -1;
					break;
				}
				ary[7] = strtok( NULL, "," );							/** Source MAC Address（MAC Address形式であること）**/
				strcpy( Save_p->stFilterRules[iLine].cMacAddress, ary[7] );
				for( i = 0; i < sizeof(dTbl); i++ ) {
					if(( isxdigit( (int)Save_p->stFilterRules[iLine].cMacAddress[nTbl[i]]) != 0 ) ||
					   ( isxdigit( (int)Save_p->stFilterRules[iLine].cMacAddress[nTbl[i+1]]) != 0 )) {
						/** charactor is not hexdecimal digit				**/
						iLine = MAX_LINES;
						iRet = -1;
						break;
					}
					if(( Save_p->stFilterRules[iLine].cMacAddress[dTbl[i]] != ":" ) &&
					   ( Save_p->stFilterRules[iLine].cMacAddress[dTbl[i]] != "-" )) {
						/** delimitter is not MAC address format			**/
						iLine = MAX_LINES;
						iRet = -1;
						break;
					}
				}
				break;
		} /** end of switch		**/
	}/** enf of for loop	**/

	fclose( File_h );
	return iRet;

}
