1998-12-08 02:22:56 +00:00
/*
2002-01-30 06:08:46 +00:00
Unix SMB / CIFS implementation .
1998-12-08 02:22:56 +00:00
SMB parameters and setup
Copyright ( C ) Andrew Tridgell 1992 - 1998
Copyright ( C ) John H Terpstra 1996 - 1998
Copyright ( C ) Luke Kenneth Casson Leighton 1996 - 1998
Copyright ( C ) Paul Ashton 1998
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 . , 675 Mass Ave , Cambridge , MA 0213 9 , USA .
*/
# ifndef _MAC_EXTENSIONS_H
# define _MAC_EXTENSIONS_H
/* Folder that holds the stream info */
# define STREAM_FOLDER ".streams"
# define STREAM_FOLDER_SLASH ".streams / "
/* Common Streams Names*/
# define DefaultStreamTestLen 6
# define DefaultStreamTest ":$DATA"
# define AFPDATA_STREAM "::$DATA"
# define AFPINFO_STREAM ":AFP_AfpInfo:$DATA"
# define AFPRESOURCE_STREAM ":AFP_Resource:$DATA"
# define AFPCOMMENTS_STREAM ":Comments:$DATA"
# define AFPDESKTOP_STREAM ":AFP_DeskTop:$DATA"
# define AFPIDINDEX_STREAM ":AFP_IdIndex:$DATA"
/*
* * NT ' s AFP_AfpInfo stream structure
*/
# define APF_INFO_SIZE 0x3c
# define AFP_Signature 0x41465000
# define AFP_Version 0x00000100
# define AFP_BackupTime 0x00000080
# define AFP_FinderSize 32
/*
* * Orginal AFP_AfpInfo stream used by NT
* * We needed a way to store the create date so SAMBA
* * AFP_AfpInfo adds for bytes to this structrure
* * and call ' s it _SambaAfpInfo
*/
typedef struct _AfpInfo
{
uint32 afpi_Signature ; /* Must be *(PDWORD)"AFP" */
uint32 afpi_Version ; /* Must be 0x00010000 */
uint32 afpi_Reserved1 ;
uint32 afpi_BackupTime ; /* Backup time for the file/dir */
unsigned char afpi_FinderInfo [ AFP_FinderSize ] ; /* Finder Info (32 bytes) */
unsigned char afpi_ProDosInfo [ 6 ] ; /* ProDos Info (6 bytes) # */
unsigned char afpi_Reserved2 [ 6 ] ;
} AfpInfo ;
typedef struct _SambaAfpInfo
{
AfpInfo afp ;
unsigned long createtime ;
} SambaAfpInfo ;
/*
* * On SAMBA this structrue is followed by 4 bytes that store the create
* * date of the file or folder asociated with it .
*/
/*
* * These extentions are only supported with the NT LM 0.12 Dialect . These extentions
* * will be process on a share by share bases .
*/
/*
* * Trans2_Query_FS_Information Call is used by the MacCIFS extentions for three reasons .
* * First to see if the remote server share supports the basic Macintosh CIFS extentions .
* * Second to return some basic need information about the share to the Macintosh .
* * Third to see if this share support any other Macintosh extentions .
* *
* * We will be using infromation levels that are betwwen 0x300 and 0x399 for all Macintosh
* * extentions calls . The first of these will be the SMB_MAC_QUERY_FS_INFO level which
2002-04-04 20:38:10 +00:00
* * will allow the server to return the MacQueryFSInfo structure . All fields are Little
1998-12-08 02:22:56 +00:00
* * Endian unless other wise specified .
*/
# define SMB_MAC_QUERY_FS_INFO 0x301
/*
* * The server will return folder access control in the Trans2_Find_First2
* * and Trans2_Find_Next2 message described later in this document .
*/
# define SUPPORT_MAC_ACCESS_CNTRL 0x0010
/*
* * The server supports setting / getting comments using the mechanism in this
* * document instead of using the NTFS format described in the Introduction .
*/
# define SUPPORT_MAC_GETSETCOMMENTS 0x0020
/*
* * The Server supports setting and getting Macintosh desktop database information
* * using the mechanism in this document .
*/
# define SUPPORT_MAC_DESKTOPDB_CALLS 0x0040
/*
* * The server will return a unique id for files and directories in the
* * Trans2_Find_First2 and Trans2_Find_Next2 message described later in this document .
*/
# define SUPPORT_MAC_UNIQUE_IDS 0x0080
/*
* * The server will return this flag telling the client that the server does
* * not support streams or the Macintosh extensions . The rest of this message
* * will be ignored by the client .
*/
# define NO_STREAMS_OR_MAC_SUPPORT 0x0100
/*
* * We will be adding a new info level to the Trans2_Find_First2 and Trans2_Find_Next2 .
* * This info level will be SMB_MAC_FIND_BOTH_HFS_INFO and will support the server
* * return additional information need by the Macintosh . All fields are Little
* * Endian unless other wise specified .
*/
# define SMB_MAC_FIND_BOTH_HFS_INFO 0x302
enum {
ownerRead = 0x0400 ,
ownerWrite = 0x0200 ,
ownerSearch = 0x0100 ,
groupRead = 0x0040 ,
groupWrite = 0x0020 ,
groupSearch = 0x0010 ,
otherRead = 0x0004 ,
otherWrite = 0x0002 ,
otherSearch = 0x0001 ,
Owner = 0x0800
} ;
/*
* * We will be adding a new info level to the Trans2_Set_Path_Information .
* * This info level will be SMB_MAC_SET_FINDER_INFO and will support the client
* * setting information on the server need by the Macintosh . All fields are Little
* * Endian unless other wise specified .
*/
# define SMB_MAC_SET_FINDER_INFO 0x303
enum {
SetCreateDate = 0x01 , /* If this is set then set the create date of the file/folder */
SetModDate = 0x02 , /* If this is set then set the modify date of the file/folder */
SetFLAttrib = 0x04 , /* If this is set then set the Macintosh lock bit of the file/folder */
FndrInfo1 = 0x08 , /* If this is set then set the first 16 bytes of finder info */
FndrInfo2 = 0x10 , /* If this is set then set the second 16 bytes of finder info */
SetHidden = 0x20 /* We are either setting or unsetting the hidden bit */
} ;
/*
* * We will be adding some new info level to the Trans2_Set_Path_Information and Trans2_Query_Path_Information .
* * These info levels will allow the client to add , get , and remove desktop inforamtion from the
* * server . How the server stores this information is up to them .
*/
/*
* * We need to be able to store an application name and its creator in a database . We send a
* * Trans2_Set_Path_Information call with the full path of the application in the path field .
* * We will send an info level that represents adding an application name and creator to the database .
* * We will pass the File Creator in the data message .
* *
* * The server should just respond with no error or an error .
*/
# define SMB_MAC_DT_ADD_APPL 0x304
/*
* * We need to be able to remove an application name and its creator from a database . We send a
* * Trans2_Set_Path_Information call with the full path of the application in the path field .
* * We will send an info level that represents removing an application name and creator from the database .
* * We will pass the File Creator in the data message .
* *
* * The server should just respond with no error or an error .
*/
# define SMB_MAC_DT_REMOVE_APPL 0x305
/*
* * We need to be able to get an application name and its creator from a database . We send a
* * Trans2_Query_Path_Information call in which the name field is just ignore .
* * We will send an info level that represents getting an application name with a structure that
* * contains the File Creator and index . Were index has the following meaning .
* * Index = 0 ; Get the application path from the database with the most current date .
* * Index > 0 ; Use the index to find the application path from the database .
* * e . g . index of 5 means get the fifth entry of this application name in the database .
* * if not entry return an error .
* *
* * The server returns with a structure that contains the full path to the appication and
* * its creator ' s date .
*/
# define SMB_MAC_DT_GET_APPL 0x306
/*
* * We need to be able to get an icon from a database . We send a Trans2_Query_Path_Information call in
* * which the path name is ignore . We will send an info level that represents getting an icon with a structure
* * that contains the Requested size of the icon , the Icon type , File Creator , and File Type .
* *
* * The server returns with a structure that contains the actual size of the icon
* * ( must be less than requested length ) and the icon bit map .
*/
# define SMB_MAC_DT_GET_ICON 0x307
/*
* * We need to be able to get an icon from a database . We send a Trans2_Query_Path_Information call in
* * which the path name is ignore . We will send an info level that represents getting an icon with a structure
* * that contains the index and File Creator . The index allows the client to make repeated calls to the server
* * gathering all icon stored by this file creator .
* *
* *
* * The server returns with a structure that contains the actual size of the icon
* * ( must be less than requested length ) and the icon bit map , File Type , and Icon Type .
*/
# define SMB_MAC_DT_GET_ICON_INFO 0x308
/*
* * We need to be able to add an icon to a database . We send a Trans2_Set_Path_Information call in
* * which the path name is ignore . We will send an info level that represents setting an icon with a structure
* * that contains the icon data , icon size , icon type , the file type , and file creator .
* *
* *
* * The server returns only that the call was succesfull or not .
*/
# define SMB_MAC_DT_ADD_ICON 0x309
# endif /* _MAC_EXTENSIONS_H */
/* _MAC_EXTENSIONS_H */