ObexFTP 0.24
Macros | Functions
client.c File Reference

ObexFTP client API implementation. More...

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <errno.h>
#include <sys/types.h>
#include <time.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <netinet/in.h>
#include <openobex/obex.h>
#include <multicobex/multi_cobex.h>
#include "obexftp.h"
#include "client.h"
#include "object.h"
#include "obexftp_io.h"
#include "uuid.h"
#include "cache.h"
#include <common.h>

Macros

#define _GNU_SOURCE
 
#define O_BINARY   (0)
 
#define CREATE_MODE_FILE   (S_IRUSR|S_IWUSR|S_IRGRP|S_IROTH)
 
#define ESOCKTNOSUPPORT   WSAESOCKTNOSUPPORT
 

Functions

obexftp_client_tobexftp_open (int transport, obex_ctrans_t *ctrans, obexftp_info_cb_t infocb, void *infocb_data)
 Create an obexftp client.
 
void obexftp_close (obexftp_client_t *cli)
 Close an obexftp client and free the resources.
 
int obexftp_connect_uuid (obexftp_client_t *cli, const char *device, int port, const uint8_t uuid[], uint32_t uuid_len)
 Do simple connect as client.
 
int obexftp_connect_service (obexftp_client_t *cli, const char *src, const char *device, int port, int service)
 
int obexftp_connect_src (obexftp_client_t *cli, const char *src, const char *device, int port, const uint8_t uuid[], uint32_t uuid_len)
 Connect this ObexFTP client using a given source address by sending an OBEX CONNECT request.
 
int obexftp_disconnect (obexftp_client_t *cli)
 Disconnect this ObexFTP client by sending an OBEX DISCONNECT request.
 
int obexftp_info (obexftp_client_t *cli, uint8_t opcode)
 Send a custom Siemens OBEX app info opcode.
 
int obexftp_get_type (obexftp_client_t *cli, const char *type, const char *localname, const char *remotename)
 Send an OBEX GET with optional TYPE.
 
int obexftp_rename (obexftp_client_t *cli, const char *sourcename, const char *targetname)
 Send an custom Siemens OBEX rename request.
 
int obexftp_del (obexftp_client_t *cli, const char *name)
 Send an OBEX PUT with empty file name (delete).
 
int obexftp_setpath (obexftp_client_t *cli, const char *name, int create)
 Send OBEX SETPATH request (multiple requests if split path flag is set).
 
int obexftp_put_file (obexftp_client_t *cli, const char *filename, const char *remotename)
 Send an OBEX PUT, optionally with (some) SETPATHs for a local file.
 
int obexftp_put_data (obexftp_client_t *cli, const uint8_t *data, int size, const char *remotename)
 Send memory data by OBEX PUT, optionally with (some) SETPATHs.
 
char ** obexftp_discover_bt_src (const char *src)
 
char * obexftp_bt_name_src (const char *addr, const char *src)
 
int obexftp_browse_bt_src (const char *src, const char *addr, int svclass)
 
int obexftp_sdp_register (int svclass, int channel)
 
int obexftp_sdp_unregister (int svclass)
 
char ** obexftp_discover (int transport)
 Device discovery wrapper for a named transport.
 

Detailed Description

ObexFTP client API implementation.

ObexFTP library - language bindings for OBEX file transfer.

Copyright (c) 2002-2007 Christian W. Zuckschwerdt zany@.nosp@m.triq.nosp@m..net

ObexFTP is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser 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 Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public License along with ObexFTP. If not, see http://www.gnu.org/.

Macro Definition Documentation

◆ _GNU_SOURCE

#define _GNU_SOURCE

◆ CREATE_MODE_FILE

#define CREATE_MODE_FILE   (S_IRUSR|S_IWUSR|S_IRGRP|S_IROTH)

◆ ESOCKTNOSUPPORT

#define ESOCKTNOSUPPORT   WSAESOCKTNOSUPPORT

◆ O_BINARY

#define O_BINARY   (0)

Function Documentation

◆ obexftp_browse_bt_src()

int obexftp_browse_bt_src ( const char *  src,
const char *  addr,
int  svclass 
)

◆ obexftp_bt_name_src()

char * obexftp_bt_name_src ( const char *  addr,
const char *  src 
)

◆ obexftp_close()

void obexftp_close ( obexftp_client_t cli)

Close an obexftp client and free the resources.

Parameters
clithe obexftp_client_t to be shut done and free'd. It's save to pass NULL here.

Closes the given obexftp client and frees the resources. It's recommended to set the client reference to NULL afterwards.

◆ obexftp_connect_service()

int obexftp_connect_service ( obexftp_client_t cli,
const char *  src,
const char *  device,
int  port,
int  service 
)

◆ obexftp_connect_src()

int obexftp_connect_src ( obexftp_client_t cli,
const char *  src,
const char *  device,
int  port,
const uint8_t  uuid[],
uint32_t  uuid_len 
)

Connect this ObexFTP client using a given source address by sending an OBEX CONNECT request.

Parameters
clian obexftp_client_t created by obexftp_open().
srcoptional local source interface address (transport specific)
devicethe device address to connect to (transport specific)
portthe port/channel for the device address
uuidUUID string for CONNECT (no default)
uuid_lenlength of the UUID string (excluding terminating zero)
Returns
the result of the CONNECT request, -1 on error
Note
Always use a UUID (except for OBEX PUSH)

◆ obexftp_connect_uuid()

int obexftp_connect_uuid ( obexftp_client_t cli,
const char *  device,
int  port,
const uint8_t  uuid[],
uint32_t  uuid_len 
)

Do simple connect as client.

Parameters
clian obexftp_client_t created by obexftp_open().
devicethe device address to connect to (transport specific)
portthe port/channel for the device address
uuidUUID string for CONNECT (no default)
uuid_lenlength of the UUID string (excluding terminating zero)
Returns
the result of the CONNECT request, -1 on error
Note
Wrapper function for obexftp_connect_src()
Warning
Always use a UUID (except for OBEX PUSH)

◆ obexftp_del()

int obexftp_del ( obexftp_client_t cli,
const char *  name 
)

Send an OBEX PUT with empty file name (delete).

Parameters
clian obexftp_client_t created by obexftp_open().
namethe remote filename/foldername to be removed.
Returns
the result of the empty OBEX PUT request

◆ obexftp_disconnect()

int obexftp_disconnect ( obexftp_client_t cli)

Disconnect this ObexFTP client by sending an OBEX DISCONNECT request.

Parameters
clian obexftp_client_t created by obexftp_open().
Returns
the result of the DISCONNECT request

◆ obexftp_discover()

char ** obexftp_discover ( int  transport)

Device discovery wrapper for a named transport.

Parameters
transporta transport from the OBEX_TRANS_x enum.
Returns
the discovery results as array of strings.
Note
USB and BT only for now.

◆ obexftp_discover_bt_src()

char ** obexftp_discover_bt_src ( const char *  src)

◆ obexftp_get_type()

int obexftp_get_type ( obexftp_client_t cli,
const char *  type,
const char *  localname,
const char *  remotename 
)

Send an OBEX GET with optional TYPE.

Directories will be changed into first if split path quirk is set.

Parameters
clian obexftp_client_t created by obexftp_open().
typeOBEX TYPE of the request
localnameoptional file to write
remotenameOBEX NAME to request
Returns
the result of GET request
Note
localname and remotename may be null.

◆ obexftp_info()

int obexftp_info ( obexftp_client_t cli,
uint8_t  opcode 
)

Send a custom Siemens OBEX app info opcode.

Parameters
clian obexftp_client_t created by obexftp_open().
opcodethe info opcode, 0x01 to inquire installed memory, 0x02 to get free memory
Returns
the result of the app info request

◆ obexftp_open()

obexftp_client_t * obexftp_open ( int  transport,
obex_ctrans_t *  ctrans,
obexftp_info_cb_t  infocb,
void *  infocb_data 
)

Create an obexftp client.

Parameters
transportthe transport type that will be used
ctransoptional custom transport (don't use)
infocboptional info callback
infocb_dataoptional info callback data
Returns
a new allocated ObexFTP client instance, NULL on error

◆ obexftp_put_data()

int obexftp_put_data ( obexftp_client_t cli,
const uint8_t *  data,
int  size,
const char *  remotename 
)

Send memory data by OBEX PUT, optionally with (some) SETPATHs.

Parameters
clian obexftp_client_t created by obexftp_open().
datadata to send
sizelength of the data
remotenameremote name to write
Returns
the result of the OBEX PUT (and SETPATH) request(s).
Note
A remotename must be given always.

◆ obexftp_put_file()

int obexftp_put_file ( obexftp_client_t cli,
const char *  filename,
const char *  remotename 
)

Send an OBEX PUT, optionally with (some) SETPATHs for a local file.

Parameters
clian obexftp_client_t created by obexftp_open().
filenamelocal file to send
remotenameremote name to write
Returns
the result of the OBEX PUT (and SETPATH) request(s).
Note
Puts to filename's basename if remotename is NULL or ends with a slash.

◆ obexftp_rename()

int obexftp_rename ( obexftp_client_t cli,
const char *  sourcename,
const char *  targetname 
)

Send an custom Siemens OBEX rename request.

Parameters
clian obexftp_client_t created by obexftp_open().
sourcenameremote filename to be renamed
targetnameremote target filename
Returns
the result of Siemens rename request

◆ obexftp_sdp_register()

int obexftp_sdp_register ( int  svclass,
int  channel 
)

◆ obexftp_sdp_unregister()

int obexftp_sdp_unregister ( int  svclass)

◆ obexftp_setpath()

int obexftp_setpath ( obexftp_client_t cli,
const char *  name,
int  create 
)

Send OBEX SETPATH request (multiple requests if split path flag is set).

Parameters
clian obexftp_client_t created by obexftp_open().
namepath to change into
createflag whether to create missing folders or fail
Returns
the result of the OBEX SETPATH request(s).
Note
handles NULL, "", "/" and everything else correctly.