You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdepim/kpilot/lib/pilotUser.h

129 lines
3.1 KiB

#ifndef _KPILOT_PILOTUSER_H
#define _KPILOT_PILOTUSER_H
/* pilotUser.h KPilot
**
** Copyright (C) 1998-2001 by Dan Pilone
**
** Wrapper for the PilotUser struct from pilot-link, which describes
** the user-data set in the Pilot.
*/
/*
** This program 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.1 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 this program in a file called COPYING; if not, write to
** the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
** MA 02110-1301, USA.
*/
/*
** Bug reports and questions can be sent to kde-pim@kde.org
*/
#include <stdlib.h>
#include <string.h>
#include <time.h>
#include <pi-dlp.h>
#include "pilot.h"
class KPilotUser
{
public:
/** Constructor. Create an empty PilotUser structure. */
KPilotUser()
{
::memset(&fUser,0,sizeof(struct PilotUser));
}
/** Constructor. Use the given PilotUser structure.
* This creates a copy; no ownership is transferred.
*/
KPilotUser(const PilotUser *user)
{
fUser = *user;
}
/** Accessor for the whole PilotUser structure. */
PilotUser *data()
{
return &fUser;
}
/** @return The username set on the handheld. */
TQString name() const
{
return Pilot::fromPilot( fUser.username );
}
/** Set the user name to the given @p name , truncated
* if necessary to the size of the field on the handheld.
*/
void setName( const TQString &name )
{
Pilot::toPilot( name, fUser.username, sizeof(fUser.username) );
}
/** @return The length of the password on the handheld,
* in bytes.
*/
const int passwordLength() const
{
return fUser.passwordLength;
}
/** @return the ID (4 bytes) of the last PC to sync this handheld.
* This is intended to help identify when the use has
* changed PCs and needs a new full sync.
*/
unsigned long getLastSyncPC() const
{
return fUser.lastSyncPC;
}
/** Set the ID of the PC syncing the handheld to @p pc . This
* should be unique in some way (perhaps IP addresses can be
* used this way, or hostnames).
*/
void setLastSyncPC(unsigned long pc)
{
fUser.lastSyncPC = pc;
}
/** @return the timestamp that the handheld was last synced
* successfully.
*/
time_t getLastSuccessfulSyncDate()
{
return fUser.successfulSyncDate;
}
/** Set the timestamp for a successful sync. */
void setLastSuccessfulSyncDate(time_t when)
{
fUser.successfulSyncDate = when;
}
/** @return the timestamp of the last sync attempt. */
time_t getLastSyncDate()
{
return fUser.lastSyncDate;
}
/** Set the timestamp of the sync attempt. */
void setLastSyncDate(time_t when)
{
fUser.lastSyncDate = when;
}
private:
struct PilotUser fUser;
};
#endif