Files
mediafire-fuse/mfapi/folder.c
2014-09-24 21:20:21 +02:00

167 lines
3.4 KiB
C

/*
* Copyright (C) 2013 Bryan Christ <bryan.christ@mediafire.com>
* 2014 Johannes Schauer <j.schauer@email.de>
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2, as published by
* the Free Software Foundation.
*
* 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., 51
* Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
*/
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
#include "folder.h"
struct mffolder {
char folderkey[20];
char name[41];
char parent[20];
uint64_t revision;
time_t created;
};
mffolder *folder_alloc(void)
{
mffolder *folder;
folder = (mffolder *) calloc(1, sizeof(mffolder));
return folder;
}
void folder_free(mffolder * folder)
{
if (folder == NULL)
return;
free(folder);
return;
}
int folder_set_key(mffolder * folder, const char *key)
{
if (folder == NULL)
return -1;
if (key == NULL) {
memset(folder->folderkey, 0, sizeof(folder->folderkey));
} else {
if (strlen(key) != 13)
return -1;
memset(folder->folderkey, 0, sizeof(folder->folderkey));
strncpy(folder->folderkey, key, sizeof(folder->folderkey) - 1);
}
return 0;
}
const char *folder_get_key(mffolder * folder)
{
if (folder == NULL)
return NULL;
if (folder->folderkey[0] == '\0') {
return NULL;
} else {
return folder->folderkey;
}
}
int folder_set_parent(mffolder * folder, const char *parent_key)
{
if (folder == NULL)
return -1;
if (parent_key == NULL) {
memset(folder->parent, 0, sizeof(folder->parent));
} else {
if (strlen(parent_key) != 13) {
return -1;
}
memset(folder->parent, 0, sizeof(folder->parent));
strncpy(folder->parent, parent_key, sizeof(folder->parent) - 1);
}
return 0;
}
const char *folder_get_parent(mffolder * folder)
{
if (folder == NULL)
return NULL;
return folder->parent;
}
int folder_set_name(mffolder * folder, const char *name)
{
if (folder == NULL)
return -1;
if (name == NULL)
return -1;
if (strlen(name) > 40)
return -1;
memset(folder->name, 0, sizeof(folder->name));
strncpy(folder->name, name, sizeof(folder->name) - 1);
return 0;
}
const char *folder_get_name(mffolder * folder)
{
if (folder == NULL)
return NULL;
return folder->name;
}
int folder_set_revision(mffolder * folder, uint64_t revision)
{
if (folder == NULL)
return -1;
folder->revision = revision;
return 0;
}
uint64_t folder_get_revision(mffolder * folder)
{
if (folder == NULL)
return -1;
return folder->revision;
}
int folder_set_created(mffolder * folder, time_t created)
{
if (folder == NULL)
return -1;
folder->created = created;
return 0;
}
time_t folder_get_created(mffolder * folder)
{
if (folder == NULL)
return -1;
return folder->created;
}