Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

1035 lines
27 KiB

/********************************************************************/
/** Copyright(c) 1989 Microsoft Corporation. **/
/********************************************************************/
//***
//
// Filename: cmd.c
//
// Description:
//
// History:
// Oct 1,1993. NarenG Created original version.
//
#include <client.h>
#include <stdio.h>
#include <stdlib.h>
#include "cmd.h"
CHAR * pszTRUE = "TRUE";
CHAR * pszFALSE = "FALSE";
CHAR * pszUnlimited = "UNLIMITED";
VOID
PrintMessageAndExit(
DWORD ids,
CHAR * pchInsertString
)
{
CHAR Error[10];
CHAR MsgBuf[1000];
DWORD cbMessage;
LPSTR pszMessage;
switch( ids )
{
case IDS_GENERAL_SYNTAX:
case IDS_VOLUME_SYNTAX:
case IDS_DIRECTORY_SYNTAX:
case IDS_SERVER_SYNTAX:
case IDS_FORKIZE_SYNTAX:
case IDS_VOLUME_TOO_BIG:
case IDS_SUCCESS:
cbMessage = FormatMessageA(
FORMAT_MESSAGE_ALLOCATE_BUFFER |
FORMAT_MESSAGE_FROM_HMODULE,
NULL,
(DWORD)ids,
LANG_NEUTRAL,
(LPSTR)&pszMessage,
128,
NULL );
break;
case IDS_AMBIGIOUS_SWITCH_ERROR:
case IDS_UNKNOWN_SWITCH_ERROR:
case IDS_DUPLICATE_SWITCH_ERROR:
cbMessage = FormatMessageA(
FORMAT_MESSAGE_ALLOCATE_BUFFER |
FORMAT_MESSAGE_FROM_HMODULE |
FORMAT_MESSAGE_IGNORE_INSERTS,
NULL,
(DWORD)ids,
LANG_NEUTRAL,
(LPSTR)&pszMessage,
128,
NULL );
if ( cbMessage > 0 )
{
sprintf( MsgBuf, pszMessage, pchInsertString );
CharToOem( MsgBuf, MsgBuf );
LocalFree( pszMessage );
fprintf( stdout, MsgBuf );
fprintf( stdout, "\n" );
}
exit( 0 );
break;
case IDS_API_ERROR:
_itoa( (int)((ULONG_PTR)pchInsertString), Error, 10 );
cbMessage = FormatMessageA(
FORMAT_MESSAGE_ALLOCATE_BUFFER |
FORMAT_MESSAGE_FROM_HMODULE |
FORMAT_MESSAGE_IGNORE_INSERTS,
NULL,
(DWORD)ids,
LANG_NEUTRAL,
(LPSTR)&pszMessage,
128,
NULL );
if ( cbMessage > 0 )
{
sprintf( MsgBuf, pszMessage, Error );
CharToOem( MsgBuf, MsgBuf );
fprintf( stdout, MsgBuf );
fprintf( stdout, "\n" );
LocalFree( pszMessage );
}
if ( ((LONG)((LONG_PTR)pchInsertString)) > 0 )
{
cbMessage = FormatMessageA(
FORMAT_MESSAGE_ALLOCATE_BUFFER |
FORMAT_MESSAGE_FROM_SYSTEM,
NULL,
(LONG)((LONG_PTR)pchInsertString),
LANG_NEUTRAL,
(LPSTR)&pszMessage,
128,
NULL );
}
if ( ((LONG)((LONG_PTR)pchInsertString)) < 0 )
{
cbMessage = FormatMessageA(
FORMAT_MESSAGE_ALLOCATE_BUFFER |
FORMAT_MESSAGE_FROM_HMODULE,
NULL,
AFPERR_TO_STRINGID( (LONG)((LONG_PTR)pchInsertString) ),
LANG_NEUTRAL,
(LPSTR)&pszMessage,
128,
NULL );
}
break;
default:
exit( 0 );
}
if ( cbMessage > 0 )
{
CharToOem( pszMessage, pszMessage );
fprintf( stdout, pszMessage );
fprintf( stdout, "\n" );
LocalFree( pszMessage );
}
exit(0);
}
VOID
DoVolumeAdd(
CHAR * pchServer,
CHAR * pchName,
CHAR * pchPath,
CHAR * pchPassword,
CHAR * pchReadOnly,
CHAR * pchGuestsAllowed,
CHAR * pchMaxUses
)
{
PAFP_DIRECTORY_INFO pAfpDirInfo;
AFP_VOLUME_INFO AfpVolInfo;
DWORD dwRetCode;
AFP_SERVER_HANDLE hServer;
WCHAR wchName[AFP_VOLNAME_LEN+1];
WCHAR wchPassword[AFP_VOLPASS_LEN+1];
WCHAR wchServer[CNLEN+3];
LPWSTR lpwsPath;
LPSTR lpDrivePath;
DWORD dwParmNum = AFP_DIR_PARMNUM_PERMS;
ZeroMemory( &AfpVolInfo, sizeof( AfpVolInfo ) );
//
// Check to see if the mandatory values are not supplied
//
if ( ( pchName == NULL ) || ( pchPath == NULL ) || ( *pchName == (CHAR)NULL)
|| ( *pchPath == (CHAR)NULL ) )
PrintMessageAndExit( IDS_VOLUME_SYNTAX, NULL );
mbstowcs(wchName, pchName, sizeof(wchName));
AfpVolInfo.afpvol_name = wchName;
lpwsPath = LocalAlloc(LPTR, (strlen(pchPath) + 1) * sizeof(WCHAR));
if (lpwsPath == NULL)
PrintMessageAndExit(IDS_API_ERROR, (CHAR*)ERROR_NOT_ENOUGH_MEMORY);
lpDrivePath = LocalAlloc(LPTR, (CNLEN + 6 + 1));
if (lpDrivePath == NULL)
PrintMessageAndExit(IDS_API_ERROR, (CHAR*)ERROR_NOT_ENOUGH_MEMORY);
mbstowcs(lpwsPath, pchPath, (strlen(pchPath)+1)*sizeof(WCHAR));
AfpVolInfo.afpvol_path = lpwsPath;
if ( pchServer )
{
if (*pchServer)
mbstowcs(wchServer, pchServer, sizeof(wchServer));
else
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
}
if ( (pchPassword) && ( strlen( pchPassword ) > 0 ) )
{
mbstowcs(wchPassword, pchPassword, sizeof(wchPassword));
AfpVolInfo.afpvol_password = wchPassword;
}
else
AfpVolInfo.afpvol_password = NULL;
if ( pchMaxUses )
{
if ( *pchMaxUses )
{
if (_strnicmp(pchMaxUses, pszUnlimited, strlen(pchMaxUses)) == 0)
AfpVolInfo.afpvol_max_uses = AFP_VOLUME_UNLIMITED_USES;
else if ( strspn(pchMaxUses, "1234567890") != strlen(pchMaxUses) )
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
else if ( strlen( pchMaxUses ) > strlen( "4294967295" ) )
AfpVolInfo.afpvol_max_uses = AFP_VOLUME_UNLIMITED_USES;
else if ( ( strlen( pchMaxUses ) == strlen( "4294967295" ) ) &&
( _stricmp( pchMaxUses, "4294967295" ) > 0 ) )
AfpVolInfo.afpvol_max_uses = AFP_VOLUME_UNLIMITED_USES;
else
AfpVolInfo.afpvol_max_uses = atoi(pchMaxUses);
if ( AfpVolInfo.afpvol_max_uses == 0 )
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
}
else
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
}
else
AfpVolInfo.afpvol_max_uses = AFP_VOLUME_UNLIMITED_USES;
AfpVolInfo.afpvol_props_mask = 0;
if (pchReadOnly != NULL)
{
if ( *pchReadOnly )
{
if (_strnicmp(pchReadOnly, pszTRUE, strlen(pchReadOnly) ) == 0)
AfpVolInfo.afpvol_props_mask |= AFP_VOLUME_READONLY;
else if (_strnicmp(pchReadOnly, pszFALSE, strlen(pchReadOnly))!=0)
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
}
else
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
}
if (pchGuestsAllowed != NULL)
{
if ( *pchGuestsAllowed )
{
if (_strnicmp(pchGuestsAllowed,pszTRUE,strlen(pchGuestsAllowed))==0)
AfpVolInfo.afpvol_props_mask |= AFP_VOLUME_GUESTACCESS;
else if(_strnicmp(pchGuestsAllowed,
pszFALSE,strlen(pchGuestsAllowed))!=0)
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
}
else
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
}
else
AfpVolInfo.afpvol_props_mask |= AFP_VOLUME_GUESTACCESS;
//
// Connect with the server
//
dwRetCode = AfpAdminConnect(pchServer ? wchServer : NULL, &hServer);
if (dwRetCode != NO_ERROR)
PrintMessageAndExit(IDS_API_ERROR, (CHAR *)((ULONG_PTR)dwRetCode));
//
// First get and set directory information.
//
dwRetCode = AfpAdminDirectoryGetInfo(hServer,
lpwsPath,
(LPBYTE*)&pAfpDirInfo);
if (dwRetCode == NO_ERROR)
{
pAfpDirInfo->afpdir_path = lpwsPath;
if ( pAfpDirInfo->afpdir_owner != (LPWSTR)NULL )
{
dwParmNum |= AFP_DIR_PARMNUM_OWNER;
}
if ( pAfpDirInfo->afpdir_group != (LPWSTR)NULL )
{
dwParmNum |= AFP_DIR_PARMNUM_GROUP;
}
dwRetCode = AfpAdminVolumeAdd(hServer, (LPBYTE)&AfpVolInfo);
// Directory permissions need not be changed here
#if 0
if (dwRetCode == NO_ERROR)
{
dwRetCode = AfpAdminDirectorySetInfo(hServer,
(LPBYTE)pAfpDirInfo,
dwParmNum);
}
#endif
if (dwRetCode != NO_ERROR)
{
printf ("AfpAdminVolumeAdd failed with error %ld\n",
dwRetCode);
}
AfpAdminBufferFree(pAfpDirInfo);
}
// we will get this if it's a CDROM. UI ignores this error: why not macfile?
else if (dwRetCode == AFPERR_SecurityNotSupported)
{
dwRetCode = AfpAdminVolumeAdd(hServer, (LPBYTE)&AfpVolInfo);
}
if (dwRetCode != NO_ERROR)
PrintMessageAndExit(IDS_API_ERROR, (CHAR *)((ULONG_PTR)dwRetCode));
AfpAdminDisconnect(hServer);
LocalFree(lpwsPath);
if (pchServer)
{
DWORD dwLen;
// using the server name, form a path like \\foobar\d$\
// (the +2 for the leading \\)
for (dwLen=0; dwLen < CNLEN+2; dwLen++ )
{
lpDrivePath[dwLen] = pchServer[dwLen];
if (pchServer[dwLen] == 0)
{
break;
}
}
lpDrivePath[CNLEN] = 0; // just to be sure
strcat(lpDrivePath,"\\");
dwLen = strlen(lpDrivePath);
lpDrivePath[dwLen] = pchPath[0];
lpDrivePath[dwLen+1] = 0;
strcat(lpDrivePath,"$\\");
}
else
{
strncpy(lpDrivePath, pchPath, 3);
lpDrivePath[2] = '\\';
lpDrivePath[3] = 0;
}
if (IsDriveGreaterThan2Gig(lpDrivePath))
{
LocalFree(lpDrivePath);
PrintMessageAndExit(IDS_VOLUME_TOO_BIG, NULL);
}
LocalFree(lpDrivePath);
if (dwRetCode != NO_ERROR)
PrintMessageAndExit(IDS_API_ERROR, (CHAR *)((ULONG_PTR)dwRetCode));
else
PrintMessageAndExit(IDS_SUCCESS, NULL);
}
VOID
DoVolumeDelete(
CHAR * pchServer,
CHAR * pchName
)
{
WCHAR wchName[AFP_VOLNAME_LEN+1];
DWORD dwRetCode;
AFP_SERVER_HANDLE hServer;
WCHAR wchServer[CNLEN+3];
PAFP_VOLUME_INFO pAfpVolumeInfo;
PAFP_CONNECTION_INFO pAfpConnections;
PAFP_CONNECTION_INFO pAfpConnInfoIter;
DWORD cEntriesRead;
DWORD cTotalAvail;
DWORD dwIndex;
if ( ( pchName == NULL ) || ( *pchName == (CHAR)NULL ) )
PrintMessageAndExit( IDS_VOLUME_SYNTAX, NULL );
mbstowcs(wchName, pchName, sizeof(wchName));
if (pchServer)
{
if (*pchServer)
mbstowcs(wchServer, pchServer, sizeof(wchServer));
else
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
}
dwRetCode = AfpAdminConnect(pchServer ? wchServer : NULL, &hServer);
if (dwRetCode != NO_ERROR)
PrintMessageAndExit(IDS_API_ERROR, (CHAR *)((ULONG_PTR)dwRetCode));
dwRetCode = AfpAdminVolumeGetInfo( hServer,
(LPWSTR)wchName,
(LPBYTE*)&pAfpVolumeInfo );
if (dwRetCode != NO_ERROR)
PrintMessageAndExit(IDS_API_ERROR, (CHAR *)((ULONG_PTR)dwRetCode));
//
// Check if there are any users connected to the volume
// by enumerating the connections to this volume.
//
dwRetCode = AfpAdminConnectionEnum( hServer,
(LPBYTE*)&pAfpConnections,
AFP_FILTER_ON_VOLUME_ID,
pAfpVolumeInfo->afpvol_id,
(DWORD)-1, // Get all conenctions
&cEntriesRead,
&cTotalAvail,
NULL );
AfpAdminBufferFree( pAfpVolumeInfo );
if (dwRetCode != NO_ERROR)
PrintMessageAndExit(IDS_API_ERROR, (CHAR *)((ULONG_PTR)dwRetCode));
for ( dwIndex = 0, pAfpConnInfoIter = pAfpConnections;
dwIndex < cEntriesRead;
dwIndex++, pAfpConnInfoIter++ )
{
dwRetCode = AfpAdminConnectionClose( hServer,
pAfpConnInfoIter->afpconn_id );
if ( dwRetCode != NO_ERROR )
PrintMessageAndExit( IDS_API_ERROR, (CHAR *)((ULONG_PTR)dwRetCode) );
}
AfpAdminBufferFree( pAfpConnections );
dwRetCode = AfpAdminVolumeDelete( hServer, wchName );
if (dwRetCode != NO_ERROR)
PrintMessageAndExit(IDS_API_ERROR, (CHAR *)((ULONG_PTR)dwRetCode));
AfpAdminDisconnect( hServer );
PrintMessageAndExit(IDS_SUCCESS, NULL);
}
VOID
DoVolumeSet(
CHAR * pchServer,
CHAR * pchName,
CHAR * pchPassword,
CHAR * pchReadOnly,
CHAR * pchGuestsAllowed,
CHAR * pchMaxUses
)
{
DWORD dwParmNum = 0;
AFP_VOLUME_INFO AfpVolInfo;
DWORD dwRetCode;
AFP_SERVER_HANDLE hServer;
WCHAR wchName[AFP_VOLNAME_LEN+1];
WCHAR wchPassword[AFP_VOLPASS_LEN+1];
WCHAR wchServer[CNLEN+3];
//
// Check to see if the mandatory values are not supplied
//
if ( ( pchName == NULL ) || ( *pchName == (CHAR)NULL ) )
PrintMessageAndExit( IDS_VOLUME_SYNTAX, NULL );
mbstowcs(wchName, pchName, sizeof(wchName));
AfpVolInfo.afpvol_name = wchName;
if (pchServer)
{
if (*pchServer)
mbstowcs(wchServer, pchServer, sizeof(wchServer));
else
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
}
if (pchPassword)
{
dwParmNum |= AFP_VOL_PARMNUM_PASSWORD;
if (*pchPassword)
{
mbstowcs(wchPassword, pchPassword, sizeof(wchPassword));
AfpVolInfo.afpvol_password = wchPassword;
}
else
AfpVolInfo.afpvol_password = NULL;
}
if (pchMaxUses)
{
if (*pchMaxUses)
{
dwParmNum |= AFP_VOL_PARMNUM_MAXUSES;
if (_strnicmp(pchMaxUses, pszUnlimited, strlen(pchMaxUses))== 0)
AfpVolInfo.afpvol_max_uses = AFP_VOLUME_UNLIMITED_USES;
else if ( strspn(pchMaxUses, "1234567890") != strlen(pchMaxUses) )
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
else if ( strlen( pchMaxUses ) > strlen( "4294967295" ) )
AfpVolInfo.afpvol_max_uses = AFP_VOLUME_UNLIMITED_USES;
else if ( ( strlen( pchMaxUses ) == strlen( "4294967295" ) ) &&
( _stricmp( pchMaxUses, "4294967295" ) > 0 ) )
AfpVolInfo.afpvol_max_uses = AFP_VOLUME_UNLIMITED_USES;
else
AfpVolInfo.afpvol_max_uses = atoi(pchMaxUses);
if ( AfpVolInfo.afpvol_max_uses == 0 )
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
}
else
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
}
else
AfpVolInfo.afpvol_max_uses = 0;
AfpVolInfo.afpvol_props_mask = 0;
if (pchReadOnly)
{
if (*pchReadOnly)
{
dwParmNum |= AFP_VOL_PARMNUM_PROPSMASK;
if (_strnicmp(pchReadOnly, pszTRUE, strlen(pchReadOnly) ) == 0)
AfpVolInfo.afpvol_props_mask |= AFP_VOLUME_READONLY;
else if (_strnicmp(pchReadOnly, pszFALSE, strlen(pchReadOnly))!=0)
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
}
else
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
}
if (pchGuestsAllowed)
{
if (*pchGuestsAllowed)
{
dwParmNum |= AFP_VOL_PARMNUM_PROPSMASK;
if (_strnicmp(pchGuestsAllowed, pszTRUE,
strlen(pchGuestsAllowed))==0)
AfpVolInfo.afpvol_props_mask |= AFP_VOLUME_GUESTACCESS;
else if (_strnicmp(pchGuestsAllowed,
pszFALSE,strlen(pchGuestsAllowed)) != 0)
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
}
else
PrintMessageAndExit(IDS_VOLUME_SYNTAX, NULL);
}
if (dwParmNum == 0)
PrintMessageAndExit( IDS_VOLUME_SYNTAX, NULL );
//
// Connect with the server
//
dwRetCode = AfpAdminConnect(pchServer ? wchServer : NULL, &hServer);
if (dwRetCode != NO_ERROR)
PrintMessageAndExit(IDS_API_ERROR, (CHAR *)((ULONG_PTR)dwRetCode));
dwRetCode = AfpAdminVolumeSetInfo( hServer,
(LPBYTE)&AfpVolInfo,
dwParmNum);
if (dwRetCode != NO_ERROR)
PrintMessageAndExit(IDS_API_ERROR, (CHAR *)((ULONG_PTR)dwRetCode));
AfpAdminDisconnect(hServer);
PrintMessageAndExit(IDS_SUCCESS, NULL);
}
VOID
DoServerSetInfo(
CHAR * pchServer,
CHAR * pchMaxSessions,
CHAR * pchLoginMessage,
CHAR * pchGuestsAllowed,
CHAR * pchUAMRequired,
CHAR * pchAllowSavedPasswords,
CHAR * pchMacServerName
)
{
DWORD dwRetCode;
AFP_SERVER_HANDLE hServer;
WCHAR wchServer[CNLEN+3];
DWORD dwParmNum = 0;
AFP_SERVER_INFO AfpServerInfo;
WCHAR wchLoginMsg[AFP_MESSAGE_LEN+1];
WCHAR wchMacServerName[AFP_SERVERNAME_LEN+1];
if (pchMaxSessions)
{
if (*pchMaxSessions)
{
dwParmNum |= AFP_SERVER_PARMNUM_MAX_SESSIONS;
if (_strnicmp(pchMaxSessions,
pszUnlimited,
strlen(pchMaxSessions)) == 0)
AfpServerInfo.afpsrv_max_sessions = AFP_MAXSESSIONS;
else if (strspn(pchMaxSessions, "1234567890")
!= strlen(pchMaxSessions))
PrintMessageAndExit(IDS_SERVER_SYNTAX, NULL);
else
AfpServerInfo.afpsrv_max_sessions = atoi(pchMaxSessions);
}
else
PrintMessageAndExit(IDS_SERVER_SYNTAX, NULL);
}
if (pchLoginMessage)
{
if (*pchLoginMessage)
{
dwParmNum |= AFP_SERVER_PARMNUM_LOGINMSG;
if (strlen(pchLoginMessage) > AFP_MESSAGE_LEN)
PrintMessageAndExit(IDS_SERVER_SYNTAX, NULL);
else
{
mbstowcs(wchLoginMsg, pchLoginMessage, sizeof(wchLoginMsg));
AfpServerInfo.afpsrv_login_msg = wchLoginMsg;
}
}
else
{
dwParmNum |= AFP_SERVER_PARMNUM_LOGINMSG;
AfpServerInfo.afpsrv_login_msg = NULL;
}
}
AfpServerInfo.afpsrv_options = 0;
#if 0
if (pchGuestsAllowed)
{
if (*pchGuestsAllowed)
{
dwParmNum |= AFP_SERVER_PARMNUM_OPTIONS;
if (_strnicmp(pchGuestsAllowed,
pszTRUE,
strlen(pchGuestsAllowed)) == 0)
AfpServerInfo.afpsrv_options |= AFP_SRVROPT_GUESTLOGONALLOWED;
else if (_strnicmp(pchGuestsAllowed,
pszFALSE,
strlen(pchGuestsAllowed)) != 0)
PrintMessageAndExit(IDS_SERVER_SYNTAX, NULL);
}
else
PrintMessageAndExit(IDS_SERVER_SYNTAX, NULL);
}
else
AfpServerInfo.afpsrv_options |= AFP_SRVROPT_GUESTLOGONALLOWED;
#endif
if (pchUAMRequired)
{
if (*pchUAMRequired)
{
dwParmNum |= AFP_SERVER_PARMNUM_OPTIONS;
if (_strnicmp(pchUAMRequired,
pszFALSE,
strlen(pchGuestsAllowed)) == 0)
AfpServerInfo.afpsrv_options|=AFP_SRVROPT_CLEARTEXTLOGONALLOWED;
else if (_strnicmp(pchUAMRequired,
pszTRUE,
strlen(pchUAMRequired)) != 0)
PrintMessageAndExit(IDS_SERVER_SYNTAX, NULL);
}
else
PrintMessageAndExit(IDS_SERVER_SYNTAX, NULL);
}
if (pchAllowSavedPasswords)
{
if (*pchAllowSavedPasswords)
{
dwParmNum |= AFP_SERVER_PARMNUM_OPTIONS;
if (_strnicmp(pchAllowSavedPasswords,
pszTRUE,
strlen(pchAllowSavedPasswords)) == 0)
AfpServerInfo.afpsrv_options|=AFP_SRVROPT_ALLOWSAVEDPASSWORD;
else if (_strnicmp(pchAllowSavedPasswords,
pszFALSE,
strlen(pchAllowSavedPasswords)) != 0)
PrintMessageAndExit(IDS_SERVER_SYNTAX, NULL);
}
else
PrintMessageAndExit(IDS_SERVER_SYNTAX, NULL);
}
if (pchMacServerName)
{
if (*pchMacServerName)
{
dwParmNum |= AFP_SERVER_PARMNUM_NAME;
if (strlen(pchMacServerName) > AFP_SERVERNAME_LEN)
PrintMessageAndExit(IDS_SERVER_SYNTAX, NULL);
else
{
mbstowcs(wchMacServerName,
pchMacServerName,
sizeof(wchMacServerName));
AfpServerInfo.afpsrv_name = wchMacServerName;
}
}
else
PrintMessageAndExit(IDS_SERVER_SYNTAX, NULL);
}
if (dwParmNum == 0)
PrintMessageAndExit(IDS_SERVER_SYNTAX, NULL);
if (pchServer)
{
if (*pchServer)
mbstowcs(wchServer, pchServer, sizeof(wchServer));
else
PrintMessageAndExit(IDS_SERVER_SYNTAX, NULL);
}
dwRetCode = AfpAdminConnect(pchServer ? wchServer : NULL, &hServer);
if (dwRetCode != NO_ERROR)
PrintMessageAndExit(IDS_API_ERROR, (CHAR *)((ULONG_PTR)dwRetCode));
dwRetCode = AfpAdminServerSetInfo( hServer,
(LPBYTE)&AfpServerInfo,
dwParmNum);
if (dwRetCode != NO_ERROR)
PrintMessageAndExit(IDS_API_ERROR, (CHAR *)((ULONG_PTR)dwRetCode));
AfpAdminDisconnect(hServer);
PrintMessageAndExit(IDS_SUCCESS, NULL);
}
VOID
DoDirectorySetInfo(
CHAR * pchServer,
CHAR * pchPath,
CHAR * pchOwnerName,
CHAR * pchGroupName,
CHAR * pchPermissions
)
{
DWORD dwRetCode;
AFP_SERVER_HANDLE hServer;
WCHAR wchServer[CNLEN+3];
LPWSTR lpwsPath;
WCHAR wchOwner[UNLEN+1];
WCHAR wchGroup[GNLEN+1];
DWORD dwPerms;
AFP_DIRECTORY_INFO AfpDirInfo;
DWORD dwParmNum = 0;
if ( ( pchPath == NULL ) || ( *pchPath == (CHAR)NULL ) )
PrintMessageAndExit( IDS_DIRECTORY_SYNTAX, NULL );
lpwsPath = LocalAlloc(LPTR, (strlen(pchPath) + 1) * sizeof(WCHAR));
if (lpwsPath == NULL)
PrintMessageAndExit(IDS_API_ERROR, (CHAR*)ERROR_NOT_ENOUGH_MEMORY);
mbstowcs(lpwsPath, pchPath, (strlen(pchPath)+1)*sizeof(WCHAR));
AfpDirInfo.afpdir_path = lpwsPath;
if (pchServer)
{
if (*pchServer)
mbstowcs(wchServer, pchServer, sizeof(wchServer));
else
PrintMessageAndExit(IDS_DIRECTORY_SYNTAX, NULL);
}
if (pchOwnerName)
{
if (*pchOwnerName)
{
if (strlen(pchOwnerName) > UNLEN)
PrintMessageAndExit(IDS_GENERAL_SYNTAX, NULL);
mbstowcs(wchOwner, pchOwnerName, sizeof(wchOwner));
AfpDirInfo.afpdir_owner = wchOwner;
dwParmNum |= AFP_DIR_PARMNUM_OWNER;
}
else
PrintMessageAndExit(IDS_DIRECTORY_SYNTAX, NULL);
}
if (pchGroupName)
{
if (*pchGroupName)
{
mbstowcs(wchGroup, pchGroupName, sizeof(wchGroup));
AfpDirInfo.afpdir_group = wchGroup;
dwParmNum |= AFP_DIR_PARMNUM_GROUP;
}
else
PrintMessageAndExit(IDS_DIRECTORY_SYNTAX, NULL);
}
if (pchPermissions)
{
if (*pchPermissions)
{
if (strspn(pchPermissions, "10") != strlen(pchPermissions))
PrintMessageAndExit(IDS_DIRECTORY_SYNTAX, NULL);
if (strlen(pchPermissions) != 11)
PrintMessageAndExit(IDS_DIRECTORY_SYNTAX, NULL);
dwPerms = 0;
if (pchPermissions[0] == '1')
dwPerms |= AFP_PERM_OWNER_SFI;
if (pchPermissions[1] == '1')
dwPerms |= AFP_PERM_OWNER_SFO;
if (pchPermissions[2] == '1')
dwPerms |= AFP_PERM_OWNER_MC;
if (pchPermissions[3] == '1')
dwPerms |= AFP_PERM_GROUP_SFI;
if (pchPermissions[4] == '1')
dwPerms |= AFP_PERM_GROUP_SFO;
if (pchPermissions[5] == '1')
dwPerms |= AFP_PERM_GROUP_MC;
if (pchPermissions[6] == '1')
dwPerms |= AFP_PERM_WORLD_SFI;
if (pchPermissions[7] == '1')
dwPerms |= AFP_PERM_WORLD_SFO;
if (pchPermissions[8] == '1')
dwPerms |= AFP_PERM_WORLD_MC;
if (pchPermissions[9] == '1')
dwPerms |= AFP_PERM_INHIBIT_MOVE_DELETE;
if (pchPermissions[10] == '1')
dwPerms |= AFP_PERM_SET_SUBDIRS;
AfpDirInfo.afpdir_perms = dwPerms;
dwParmNum |= AFP_DIR_PARMNUM_PERMS;
}
else
PrintMessageAndExit(IDS_DIRECTORY_SYNTAX, NULL);
}
dwRetCode = AfpAdminConnect(pchServer ? wchServer : NULL, &hServer);
if (dwRetCode != NO_ERROR)
PrintMessageAndExit(IDS_API_ERROR, (CHAR *)((ULONG_PTR)dwRetCode));
dwRetCode = AfpAdminDirectorySetInfo(hServer,
(LPBYTE)&AfpDirInfo,
dwParmNum);
if (dwRetCode != NO_ERROR)
PrintMessageAndExit(IDS_API_ERROR, (CHAR *)((ULONG_PTR)dwRetCode));
AfpAdminDisconnect(hServer);
LocalFree(lpwsPath);
PrintMessageAndExit(IDS_SUCCESS, NULL);
}
VOID
DoForkize(
CHAR * pchServer,
CHAR * pchType,
CHAR * pchCreator,
CHAR * pchDataFork,
CHAR * pchResourceFork,
CHAR * pchTargetFile
)
{
DWORD dwRetCode;
AFP_SERVER_HANDLE hServer;
WCHAR wchServer[CNLEN+3];
LPWSTR lpwsTarget;
LPWSTR lpwsResource;
LPWSTR lpwsData;
WCHAR wchType[AFP_TYPE_LEN+1];
WCHAR wchCreator[AFP_CREATOR_LEN+1];
DWORD dwParmNum = 0;
if ( ( pchTargetFile == NULL ) || ( *pchTargetFile == (CHAR)NULL ) )
PrintMessageAndExit( IDS_FORKIZE_SYNTAX, NULL );
lpwsTarget = LocalAlloc(LPTR, (strlen(pchTargetFile) + 1) * sizeof(WCHAR));
if (lpwsTarget == NULL)
PrintMessageAndExit(IDS_API_ERROR, (CHAR*)ERROR_NOT_ENOUGH_MEMORY);
mbstowcs(lpwsTarget,pchTargetFile,(strlen(pchTargetFile)+1)*sizeof(WCHAR));
if (pchServer)
{
if (*pchServer)
mbstowcs(wchServer, pchServer, sizeof(wchServer));
else
PrintMessageAndExit(IDS_FORKIZE_SYNTAX, NULL);
}
if (pchType != NULL)
{
if ( ( *pchType == (CHAR)NULL ) || ( strlen( pchType ) > AFP_TYPE_LEN ))
PrintMessageAndExit(IDS_API_ERROR,(LPSTR)AFPERR_InvalidTypeCreator);
else
mbstowcs(wchType, pchType, sizeof(wchType));
dwParmNum |= AFP_FD_PARMNUM_TYPE;
}
if (pchCreator != NULL)
{
if ((*pchCreator == (CHAR)NULL) || (strlen(pchCreator)>AFP_CREATOR_LEN))
PrintMessageAndExit(IDS_API_ERROR,(LPSTR)AFPERR_InvalidTypeCreator);
else
mbstowcs(wchCreator, pchCreator, sizeof(wchCreator));
dwParmNum |= AFP_FD_PARMNUM_CREATOR;
}
if (pchResourceFork != NULL)
{
if ( *pchResourceFork == (CHAR)NULL )
PrintMessageAndExit( IDS_FORKIZE_SYNTAX, NULL );
lpwsResource=LocalAlloc(LPTR,(strlen(pchResourceFork)+1)*sizeof(WCHAR));
if (lpwsResource == NULL)
PrintMessageAndExit(IDS_API_ERROR, (CHAR*)ERROR_NOT_ENOUGH_MEMORY);
mbstowcs(lpwsResource,pchResourceFork,
(strlen(pchResourceFork)+1)*sizeof(WCHAR));
}
else
lpwsResource = NULL;
if (pchDataFork != NULL)
{
if ( *pchDataFork == (CHAR)NULL )
PrintMessageAndExit( IDS_FORKIZE_SYNTAX, NULL );
lpwsData = LocalAlloc(LPTR,(strlen(pchDataFork)+1)*sizeof(WCHAR));
if (lpwsData == NULL)
PrintMessageAndExit(IDS_API_ERROR, (CHAR*)ERROR_NOT_ENOUGH_MEMORY);
mbstowcs(lpwsData,pchDataFork,
(strlen(pchDataFork)+1)*sizeof(WCHAR));
}
else
lpwsData = NULL;
if ((pchType == NULL) && (pchCreator == NULL) &&
(pchResourceFork == NULL) && (pchDataFork == NULL))
PrintMessageAndExit(IDS_FORKIZE_SYNTAX, NULL);
dwRetCode = AfpAdminConnect(pchServer ? wchServer : NULL, &hServer);
if (dwRetCode != NO_ERROR)
PrintMessageAndExit(IDS_API_ERROR, (CHAR *)((ULONG_PTR)dwRetCode));
dwRetCode = AfpAdminFinderSetInfo( hServer,
wchType,
wchCreator,
lpwsData,
lpwsResource,
lpwsTarget,
dwParmNum);
if (dwRetCode != NO_ERROR)
PrintMessageAndExit(IDS_API_ERROR, (CHAR *)((ULONG_PTR)dwRetCode));
AfpAdminDisconnect(hServer);
PrintMessageAndExit(IDS_SUCCESS, NULL);
}