-
Notifications
You must be signed in to change notification settings - Fork 38
/
Copy pathssfs.c
105 lines (85 loc) · 3.68 KB
/
ssfs.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
/**
* Simple & Stupid Filesystem.
*
* Mohammed Q. Hussain - http://www.maastaar.net
*
* This is an example of using FUSE to build a simple filesystem. It is a part of a tutorial in MQH Blog with the title "Writing a Simple Filesystem Using FUSE in C": http://www.maastaar.net/fuse/linux/filesystem/c/2016/05/21/writing-a-simple-filesystem-using-fuse/
*
* License: GNU GPL
*/
#define FUSE_USE_VERSION 30
#include <fuse.h>
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <time.h>
#include <string.h>
#include <stdlib.h>
static int do_getattr( const char *path, struct stat *st )
{
printf( "[getattr] Called\n" );
printf( "\tAttributes of %s requested\n", path );
// GNU's definitions of the attributes (http://www.gnu.org/software/libc/manual/html_node/Attribute-Meanings.html):
// st_uid: The user ID of the file’s owner.
// st_gid: The group ID of the file.
// st_atime: This is the last access time for the file.
// st_mtime: This is the time of the last modification to the contents of the file.
// st_mode: Specifies the mode of the file. This includes file type information (see Testing File Type) and the file permission bits (see Permission Bits).
// st_nlink: The number of hard links to the file. This count keeps track of how many directories have entries for this file. If the count is ever decremented to zero, then the file itself is discarded as soon
// as no process still holds it open. Symbolic links are not counted in the total.
// st_size: This specifies the size of a regular file in bytes. For files that are really devices this field isn’t usually meaningful. For symbolic links this specifies the length of the file name the link refers to.
st->st_uid = getuid(); // The owner of the file/directory is the user who mounted the filesystem
st->st_gid = getgid(); // The group of the file/directory is the same as the group of the user who mounted the filesystem
st->st_atime = time( NULL ); // The last "a"ccess of the file/directory is right now
st->st_mtime = time( NULL ); // The last "m"odification of the file/directory is right now
if ( strcmp( path, "/" ) == 0 )
{
st->st_mode = S_IFDIR | 0755;
st->st_nlink = 2; // Why "two" hardlinks instead of "one"? The answer is here: http://unix.stackexchange.com/a/101536
}
else
{
st->st_mode = S_IFREG | 0644;
st->st_nlink = 1;
st->st_size = 1024;
}
return 0;
}
static int do_readdir( const char *path, void *buffer, fuse_fill_dir_t filler, off_t offset, struct fuse_file_info *fi )
{
printf( "--> Getting The List of Files of %s\n", path );
filler( buffer, ".", NULL, 0 ); // Current Directory
filler( buffer, "..", NULL, 0 ); // Parent Directory
if ( strcmp( path, "/" ) == 0 ) // If the user is trying to show the files/directories of the root directory show the following
{
filler( buffer, "file54", NULL, 0 );
filler( buffer, "file349", NULL, 0 );
}
return 0;
}
static int do_read( const char *path, char *buffer, size_t size, off_t offset, struct fuse_file_info *fi )
{
printf( "--> Trying to read %s, %u, %u\n", path, offset, size );
char file54Text[] = "Hello World From File54!";
char file349Text[] = "Hello World From File349!";
char *selectedText = NULL;
// ... //
if ( strcmp( path, "/file54" ) == 0 )
selectedText = file54Text;
else if ( strcmp( path, "/file349" ) == 0 )
selectedText = file349Text;
else
return -1;
// ... //
memcpy( buffer, selectedText + offset, size );
return strlen( selectedText ) - offset;
}
static struct fuse_operations operations = {
.getattr = do_getattr,
.readdir = do_readdir,
.read = do_read,
};
int main( int argc, char *argv[] )
{
return fuse_main( argc, argv, &operations, NULL );
}