src/dbfs/link.c
author Tero Marttila <terom@fixme.fi>
Tue, 21 Oct 2008 21:54:20 +0300
changeset 37 c3880f3b4de8
parent 36 56427f22e969
child 38 1fd4da071575
permissions -rw-r--r--
update fuse_db.sql, just use dbfs_unlink for rmdir (no special handling)
32
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     1
#include "dbfs.h"
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     2
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     3
#include "../lib/log.h"
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     4
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     5
void _dbfs_readlink_res (const struct evsql_result_info *res, void *arg) {
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     6
    struct fuse_req *req = arg;
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     7
    int err = 0;
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     8
    
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     9
    uint32_t ino;
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    10
    const char *type, *link;
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    11
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    12
    // check the results
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    13
    if ((err = _dbfs_check_res(res, 1, 3)))
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    14
        SERROR(err = (err ==  1 ? ENOENT : EIO));
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    15
        
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    16
    // get our data
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    17
    if (0
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    18
        ||  evsql_result_uint32(res, 0, 0, &ino,        0 ) // inodes.ino
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    19
        ||  evsql_result_string(res, 0, 1, &type,       0 ) // inodes.type
33
c71f3053c714 working symlink
Tero Marttila <terom@fixme.fi>
parents: 32
diff changeset
    20
        ||  evsql_result_string(res, 0, 2, &link,       1 ) // inodes.link_path
32
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    21
    )
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    22
        EERROR(err = EIO, "invalid db data");
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    23
    
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    24
    // is it a symlink?
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    25
    if (_dbfs_mode(type) != S_IFLNK)
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    26
        EERROR(err = EINVAL, "wrong type: %s", type);
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    27
    
36
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    28
    INFO("\t[dbfs.readlink %p] -> ino=%lu, type=%s, link=%s", req, (unsigned long int) ino, type, link);
32
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    29
    
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    30
    // reply
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    31
    if ((err = fuse_reply_readlink(req, link)))
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    32
        EERROR(err, "fuse_reply_readlink");
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    33
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    34
error:
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    35
    if (err && (err = fuse_reply_err(req, err)))
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    36
        EWARNING(err, "fuse_reply_err");
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    37
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    38
    // free
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    39
    evsql_result_free(res);
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    40
}
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    41
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    42
void dbfs_readlink (struct fuse_req *req, fuse_ino_t ino) {
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    43
    struct dbfs *ctx = fuse_req_userdata(req);
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    44
    int err;
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    45
    
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    46
    INFO("[dbfs.readlink %p] ino=%lu", req, ino);
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    47
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    48
    const char *sql =
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    49
        "SELECT"
33
c71f3053c714 working symlink
Tero Marttila <terom@fixme.fi>
parents: 32
diff changeset
    50
        " inodes.ino, inodes.type, inodes.link_path"
32
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    51
        " FROM inodes"
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    52
        " WHERE inodes.ino = $1::int4";
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    53
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    54
    static struct evsql_query_params params = EVSQL_PARAMS(EVSQL_FMT_BINARY) {
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    55
        EVSQL_PARAM ( UINT32 ),
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    56
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    57
        EVSQL_PARAMS_END
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    58
    };
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    59
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    60
    // build params
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    61
    if (0
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    62
        ||  evsql_param_uint32(&params, 0, ino)
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    63
    )
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    64
        SERROR(err = EIO);
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    65
        
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    66
    // query
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    67
    if (evsql_query_params(ctx->db, NULL, sql, &params, _dbfs_readlink_res, req) == NULL)
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    68
        SERROR(err = EIO);
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    69
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    70
    // XXX: handle interrupts
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    71
    
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    72
    // wait
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    73
    return;
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    74
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    75
error:
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    76
    if ((err = fuse_reply_err(req, err)))
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    77
        EWARNING(err, "fuse_reply_err");
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    78
90e14e0df133 working readlink
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    79
}
33
c71f3053c714 working symlink
Tero Marttila <terom@fixme.fi>
parents: 32
diff changeset
    80
36
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    81
#define SETERR(err_var, err_val, bool_val) ((err_var) = bool_val ? (err_val) : 0)
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    82
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    83
void dbfs_unlink_res (const struct evsql_result_info *res, void *arg) {
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    84
    struct fuse_req *req = arg;
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    85
    int err = 0;
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    86
    
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    87
    // check the results
37
c3880f3b4de8 update fuse_db.sql, just use dbfs_unlink for rmdir (no special handling)
Tero Marttila <terom@fixme.fi>
parents: 36
diff changeset
    88
    // XXX: reply with ENOTEMPTY if it fails due to this inode being a dir
36
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    89
    if ((err = dbfs_check_result(res, 1, 0)))
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    90
        goto error;
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    91
        
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    92
    INFO("\t[dbfs.unlink %p] -> OK", req);
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    93
    
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    94
    // reply
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    95
    if ((err = fuse_reply_err(req, 0)))
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    96
        EERROR(err, "fuse_reply_readlink");
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    97
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    98
error:
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
    99
    if (err && (err = fuse_reply_err(req, err)))
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   100
        EWARNING(err, "fuse_reply_err");
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   101
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   102
    // free
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   103
    evsql_result_free(res);
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   104
}
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   105
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   106
void dbfs_unlink (struct fuse_req *req, fuse_ino_t parent, const char *name) {
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   107
    struct dbfs *ctx = fuse_req_userdata(req);
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   108
    int err;
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   109
    
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   110
    INFO("[dbfs.unlink %p] parent=%lu, name=%s", req, parent, name);
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   111
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   112
    const char *sql =
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   113
        "DELETE"
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   114
        " FROM file_tree"
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   115
        " WHERE parent = $1::int4 AND name = $2::varchar";
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   116
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   117
    static struct evsql_query_params params = EVSQL_PARAMS(EVSQL_FMT_BINARY) {
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   118
        EVSQL_PARAM ( UINT32 ),
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   119
        EVSQL_PARAM ( STRING ),
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   120
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   121
        EVSQL_PARAMS_END
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   122
    };
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   123
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   124
    // build params
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   125
    if (SETERR(err, (0
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   126
        ||  evsql_param_uint32(&params, 0, parent)
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   127
        ||  evsql_param_string(&params, 1, name)
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   128
    ), EIO))
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   129
        goto error;
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   130
        
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   131
    // query
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   132
    if (SETERR(err, evsql_query_params(ctx->db, NULL, sql, &params, dbfs_unlink_res, req) == NULL, EIO))
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   133
        goto error;
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   134
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   135
    // XXX: handle interrupts
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   136
    
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   137
    // wait
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   138
    return;
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   139
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   140
error:
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   141
    if ((err = fuse_reply_err(req, err)))
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   142
        EWARNING(err, "fuse_reply_err");
56427f22e969 tweak debug/info output, implement dbfs_unlink with slightly improved error macros handling
Tero Marttila <terom@fixme.fi>
parents: 35
diff changeset
   143
}
37
c3880f3b4de8 update fuse_db.sql, just use dbfs_unlink for rmdir (no special handling)
Tero Marttila <terom@fixme.fi>
parents: 36
diff changeset
   144