2018-05-28 16:28:51 -04:00
|
|
|
/*******************************************************************************
|
|
|
|
* libretroshare/src/retroshare: rsidentity.h *
|
|
|
|
* *
|
|
|
|
* libretroshare: retroshare core library *
|
|
|
|
* *
|
|
|
|
* Copyright (C) 2012 Robert Fernie <retroshare@lunamutt.com> *
|
2019-02-13 15:08:38 -05:00
|
|
|
* Copyright (C) 2019 Gioacchino Mazzurco <gio@eigenlab.org> *
|
2018-05-28 16:28:51 -04:00
|
|
|
* *
|
|
|
|
* 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 3 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. If not, see <https://www.gnu.org/licenses/>. *
|
|
|
|
* *
|
|
|
|
*******************************************************************************/
|
2019-02-13 15:08:38 -05:00
|
|
|
#pragma once
|
2012-02-13 13:22:35 -05:00
|
|
|
|
2019-02-13 15:08:38 -05:00
|
|
|
#include <cstdint>
|
2012-02-13 13:22:35 -05:00
|
|
|
#include <string>
|
|
|
|
#include <list>
|
2019-02-13 15:08:38 -05:00
|
|
|
#include <vector>
|
2012-10-21 11:48:18 -04:00
|
|
|
|
2013-03-06 18:33:23 -05:00
|
|
|
#include "retroshare/rstokenservice.h"
|
2013-02-28 16:58:38 -05:00
|
|
|
#include "retroshare/rsgxsifacehelper.h"
|
2015-10-11 21:41:35 -04:00
|
|
|
#include "retroshare/rsreputations.h"
|
2014-03-17 16:56:06 -04:00
|
|
|
#include "retroshare/rsids.h"
|
2015-01-25 17:09:12 -05:00
|
|
|
#include "serialiser/rstlvimage.h"
|
|
|
|
#include "retroshare/rsgxscommon.h"
|
2018-01-15 21:31:03 -05:00
|
|
|
#include "serialiser/rsserializable.h"
|
|
|
|
#include "serialiser/rstypeserializer.h"
|
|
|
|
#include "util/rsdeprecate.h"
|
2012-06-08 09:52:32 -04:00
|
|
|
|
2020-03-31 19:30:57 -04:00
|
|
|
class RsIdentity;
|
2019-02-13 15:08:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Pointer to global instance of RsIdentity service implementation
|
|
|
|
* @jsonapi{development}
|
|
|
|
*/
|
|
|
|
extern RsIdentity* rsIdentity;
|
2012-02-13 13:22:35 -05:00
|
|
|
|
2012-11-05 17:28:08 -05:00
|
|
|
|
|
|
|
// GroupFlags: Only one so far:
|
2017-02-07 14:15:55 -05:00
|
|
|
|
|
|
|
// The deprecated flag overlaps the privacy flags for mGroupFlags. This is an error that should be fixed. For the sake of keeping some
|
|
|
|
// backward compatibility, we need to make the change step by step.
|
|
|
|
|
2017-02-07 16:04:07 -05:00
|
|
|
#define RSGXSID_GROUPFLAG_REALID_kept_for_compatibility 0x0001
|
|
|
|
#define RSGXSID_GROUPFLAG_REALID 0x0100
|
2012-11-05 17:28:08 -05:00
|
|
|
|
|
|
|
// THESE ARE FLAGS FOR INTERFACE.
|
2012-02-13 13:22:35 -05:00
|
|
|
#define RSID_TYPE_MASK 0xff00
|
|
|
|
#define RSID_RELATION_MASK 0x00ff
|
|
|
|
|
|
|
|
#define RSID_TYPE_REALID 0x0100
|
|
|
|
#define RSID_TYPE_PSEUDONYM 0x0200
|
|
|
|
|
|
|
|
#define RSID_RELATION_YOURSELF 0x0001
|
|
|
|
#define RSID_RELATION_FRIEND 0x0002
|
|
|
|
#define RSID_RELATION_FOF 0x0004
|
|
|
|
#define RSID_RELATION_OTHER 0x0008
|
|
|
|
#define RSID_RELATION_UNKNOWN 0x0010
|
|
|
|
|
2018-01-15 21:31:03 -05:00
|
|
|
/// @deprecated remove toghether with RsGxsIdGroup::mRecognTags
|
2013-10-20 05:43:30 -04:00
|
|
|
#define RSRECOGN_MAX_TAGINFO 5
|
|
|
|
|
2015-05-02 03:57:59 -04:00
|
|
|
// Unicode symbols. NOT utf-8 bytes, because of multi byte characters
|
2015-04-09 15:53:01 -04:00
|
|
|
#define RSID_MAXIMUM_NICKNAME_SIZE 30
|
2016-08-06 11:15:56 -04:00
|
|
|
#define RSID_MINIMUM_NICKNAME_SIZE 2
|
2015-04-09 15:53:01 -04:00
|
|
|
|
2012-02-13 13:22:35 -05:00
|
|
|
std::string rsIdTypeToString(uint32_t idtype);
|
|
|
|
|
2015-11-19 21:14:32 -05:00
|
|
|
static const uint32_t RS_IDENTITY_FLAGS_IS_A_CONTACT = 0x0001;
|
|
|
|
static const uint32_t RS_IDENTITY_FLAGS_PGP_LINKED = 0x0002;
|
|
|
|
static const uint32_t RS_IDENTITY_FLAGS_PGP_KNOWN = 0x0004;
|
|
|
|
static const uint32_t RS_IDENTITY_FLAGS_IS_OWN_ID = 0x0008;
|
2016-06-17 22:21:06 -04:00
|
|
|
static const uint32_t RS_IDENTITY_FLAGS_IS_DEPRECATED= 0x0010; // used to denote keys with deprecated fingerprint format.
|
2015-11-19 21:14:32 -05:00
|
|
|
|
2018-01-15 21:31:03 -05:00
|
|
|
struct GxsReputation : RsSerializable
|
2014-02-19 06:08:37 -05:00
|
|
|
{
|
2018-01-15 21:31:03 -05:00
|
|
|
GxsReputation();
|
|
|
|
|
|
|
|
bool updateIdScore(bool pgpLinked, bool pgpKnown);
|
|
|
|
bool update(); /// checks ranges and calculates overall score.
|
|
|
|
|
|
|
|
int32_t mOverallScore;
|
|
|
|
int32_t mIdScore; /// PGP, Known, etc.
|
|
|
|
int32_t mOwnOpinion;
|
|
|
|
int32_t mPeerOpinion;
|
|
|
|
|
|
|
|
/// @see RsSerializable
|
2019-10-29 04:29:11 -04:00
|
|
|
void serial_process(
|
|
|
|
RsGenericSerializer::SerializeJob j,
|
|
|
|
RsGenericSerializer::SerializeContext& ctx ) override
|
2018-01-15 21:31:03 -05:00
|
|
|
{
|
2018-01-25 05:37:16 -05:00
|
|
|
RS_SERIAL_PROCESS(mOverallScore);
|
|
|
|
RS_SERIAL_PROCESS(mIdScore);
|
|
|
|
RS_SERIAL_PROCESS(mOwnOpinion);
|
|
|
|
RS_SERIAL_PROCESS(mPeerOpinion);
|
2018-01-15 21:31:03 -05:00
|
|
|
}
|
2019-10-29 04:29:11 -04:00
|
|
|
|
|
|
|
~GxsReputation() override;
|
2014-02-19 06:08:37 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2018-01-15 21:31:03 -05:00
|
|
|
struct RsGxsIdGroup : RsSerializable
|
2012-02-13 13:22:35 -05:00
|
|
|
{
|
2017-03-24 07:02:13 -04:00
|
|
|
RsGxsIdGroup() :
|
|
|
|
mLastUsageTS(0), mPgpKnown(false), mIsAContact(false) {}
|
2012-02-13 13:22:35 -05:00
|
|
|
|
2012-06-13 20:27:28 -04:00
|
|
|
RsGroupMetaData mMeta;
|
|
|
|
|
|
|
|
// In GroupMetaData.
|
|
|
|
//std::string mNickname; (mGroupName)
|
|
|
|
//std::string mKeyId; (mGroupId)
|
2012-11-05 17:28:08 -05:00
|
|
|
//uint32_t mIdType; (mGroupFlags)
|
2012-02-13 13:22:35 -05:00
|
|
|
|
2012-10-14 14:32:33 -04:00
|
|
|
// SHA(KeyId + Gpg Fingerprint) -> can only be IDed if GPG known.
|
|
|
|
// The length of the input must be long enough to make brute force search implausible.
|
|
|
|
|
|
|
|
// Easy to do 1e9 SHA-1 hash computations per second on a GPU.
|
|
|
|
// We will need a minimum of 256 bits, ideally 1024 bits or 2048 bits.
|
|
|
|
|
2012-11-05 17:28:08 -05:00
|
|
|
// Actually PgpIdHash is SHA1(.mMeta.mGroupId + PGPHandler->GpgFingerprint(ownId))
|
|
|
|
// ??? 160 bits.
|
2012-02-13 13:22:35 -05:00
|
|
|
|
2014-04-01 04:00:20 -04:00
|
|
|
Sha1CheckSum mPgpIdHash;
|
|
|
|
// Need a signature as proof - otherwise anyone could add others Hashes.
|
|
|
|
// This is a string, as the length is variable.
|
|
|
|
std::string mPgpIdSign;
|
2012-11-06 14:18:11 -05:00
|
|
|
|
2013-10-20 05:43:30 -04:00
|
|
|
// Recognition Strings. MAX# defined above.
|
2018-01-15 21:31:03 -05:00
|
|
|
RS_DEPRECATED std::list<std::string> mRecognTags;
|
2013-10-20 05:43:30 -04:00
|
|
|
|
2015-01-25 17:09:12 -05:00
|
|
|
// Avatar
|
|
|
|
RsGxsImage mImage ;
|
2018-10-06 19:34:05 -04:00
|
|
|
rstime_t mLastUsageTS ;
|
2015-01-25 17:09:12 -05:00
|
|
|
|
|
|
|
// Not Serialised - for GUI's benefit.
|
2015-12-23 12:08:20 -05:00
|
|
|
bool mPgpKnown;
|
|
|
|
bool mIsAContact; // change that into flags one day
|
|
|
|
RsPgpId mPgpId;
|
2015-01-25 17:09:12 -05:00
|
|
|
GxsReputation mReputation;
|
2012-07-29 09:09:36 -04:00
|
|
|
|
2018-01-15 21:31:03 -05:00
|
|
|
/// @see RsSerializable
|
|
|
|
void serial_process( RsGenericSerializer::SerializeJob j,
|
2019-02-13 15:08:38 -05:00
|
|
|
RsGenericSerializer::SerializeContext& ctx ) override;
|
2019-10-29 04:29:11 -04:00
|
|
|
|
|
|
|
~RsGxsIdGroup() override;
|
2018-01-15 21:31:03 -05:00
|
|
|
};
|
2012-07-29 09:09:36 -04:00
|
|
|
|
2012-10-21 11:48:18 -04:00
|
|
|
// DATA TYPE FOR EXTERNAL INTERFACE.
|
|
|
|
|
2019-04-23 09:46:39 -04:00
|
|
|
struct RS_DEPRECATED RsRecognTag
|
2013-10-20 05:43:30 -04:00
|
|
|
{
|
2019-02-13 15:08:38 -05:00
|
|
|
RsRecognTag(uint16_t tc, uint16_t tt, bool v) :
|
|
|
|
tag_class(tc), tag_type(tt), valid(v) {}
|
|
|
|
|
2013-10-20 05:43:30 -04:00
|
|
|
uint16_t tag_class;
|
|
|
|
uint16_t tag_type;
|
|
|
|
bool valid;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2019-04-23 09:46:39 -04:00
|
|
|
struct RS_DEPRECATED RsRecognTagDetails
|
2013-10-20 05:43:30 -04:00
|
|
|
{
|
2018-01-15 21:31:03 -05:00
|
|
|
RsRecognTagDetails() :
|
|
|
|
valid_from(0), valid_to(0), tag_class(0), tag_type(0), is_valid(false),
|
|
|
|
is_pending(false) {}
|
2013-10-20 05:43:30 -04:00
|
|
|
|
2018-10-06 19:34:05 -04:00
|
|
|
rstime_t valid_from;
|
|
|
|
rstime_t valid_to;
|
2013-10-20 05:43:30 -04:00
|
|
|
uint16_t tag_class;
|
|
|
|
uint16_t tag_type;
|
|
|
|
|
|
|
|
std::string signer;
|
|
|
|
|
|
|
|
bool is_valid;
|
|
|
|
bool is_pending;
|
|
|
|
};
|
|
|
|
|
2012-10-21 11:48:18 -04:00
|
|
|
|
2018-01-15 21:31:03 -05:00
|
|
|
struct RsIdentityParameters
|
2012-10-21 11:48:18 -04:00
|
|
|
{
|
2018-01-15 21:31:03 -05:00
|
|
|
RsIdentityParameters() :
|
|
|
|
isPgpLinked(false) {}
|
|
|
|
|
2012-11-07 16:38:43 -05:00
|
|
|
bool isPgpLinked;
|
2018-01-15 21:31:03 -05:00
|
|
|
std::string nickname;
|
|
|
|
RsGxsImage mImage;
|
2012-10-21 11:48:18 -04:00
|
|
|
};
|
|
|
|
|
2018-01-15 21:31:03 -05:00
|
|
|
struct RsIdentityUsage : RsSerializable
|
2017-01-02 09:58:37 -05:00
|
|
|
{
|
2018-01-15 21:31:03 -05:00
|
|
|
enum UsageCode : uint8_t
|
|
|
|
{
|
|
|
|
UNKNOWN_USAGE = 0x00,
|
|
|
|
|
|
|
|
/** These 2 are normally not normal GXS identities, but nothing prevents
|
|
|
|
* it to happen either. */
|
|
|
|
GROUP_ADMIN_SIGNATURE_CREATION = 0x01,
|
|
|
|
GROUP_ADMIN_SIGNATURE_VALIDATION = 0x02,
|
|
|
|
|
|
|
|
/** Not typically used, since most services do not require group author
|
|
|
|
* signatures */
|
|
|
|
GROUP_AUTHOR_SIGNATURE_CREATION = 0x03,
|
|
|
|
GROUP_AUTHOR_SIGNATURE_VALIDATION = 0x04,
|
|
|
|
|
|
|
|
/// most common use case. Messages are signed by authors in e.g. forums.
|
|
|
|
MESSAGE_AUTHOR_SIGNATURE_CREATION = 0x05,
|
|
|
|
MESSAGE_AUTHOR_SIGNATURE_VALIDATION = 0x06,
|
|
|
|
|
|
|
|
/** Identities are stamped regularly by crawlign the set of messages for
|
|
|
|
* all groups. That helps keepign the useful identities in hand. */
|
|
|
|
GROUP_AUTHOR_KEEP_ALIVE = 0x07,
|
|
|
|
MESSAGE_AUTHOR_KEEP_ALIVE = 0x08,
|
|
|
|
|
|
|
|
/** Chat lobby msgs are signed, so each time one comes, or a chat lobby
|
|
|
|
* event comes, a signature verificaiton happens. */
|
|
|
|
CHAT_LOBBY_MSG_VALIDATION = 0x09,
|
|
|
|
|
|
|
|
/// Global router message validation
|
|
|
|
GLOBAL_ROUTER_SIGNATURE_CHECK = 0x0a,
|
|
|
|
|
|
|
|
/// Global router message signature
|
|
|
|
GLOBAL_ROUTER_SIGNATURE_CREATION = 0x0b,
|
|
|
|
|
|
|
|
GXS_TUNNEL_DH_SIGNATURE_CHECK = 0x0c,
|
|
|
|
GXS_TUNNEL_DH_SIGNATURE_CREATION = 0x0d,
|
|
|
|
|
|
|
|
/// Group update on that identity data. Can be avatar, name, etc.
|
|
|
|
IDENTITY_DATA_UPDATE = 0x0e,
|
|
|
|
|
|
|
|
/// Any signature verified for that identity
|
|
|
|
IDENTITY_GENERIC_SIGNATURE_CHECK = 0x0f,
|
|
|
|
|
|
|
|
/// Any signature made by that identity
|
|
|
|
IDENTITY_GENERIC_SIGNATURE_CREATION = 0x10,
|
|
|
|
|
|
|
|
IDENTITY_GENERIC_ENCRYPTION = 0x11,
|
|
|
|
IDENTITY_GENERIC_DECRYPTION = 0x12,
|
|
|
|
CIRCLE_MEMBERSHIP_CHECK = 0x13
|
|
|
|
} ;
|
|
|
|
|
2019-06-12 13:01:19 -04:00
|
|
|
RS_DEPRECATED
|
2018-01-15 21:31:03 -05:00
|
|
|
RsIdentityUsage( uint16_t service, const RsIdentityUsage::UsageCode& code,
|
|
|
|
const RsGxsGroupId& gid = RsGxsGroupId(),
|
|
|
|
const RsGxsMessageId& mid = RsGxsMessageId(),
|
|
|
|
uint64_t additional_id=0,
|
|
|
|
const std::string& comment = std::string() );
|
|
|
|
|
2019-06-12 13:01:19 -04:00
|
|
|
RsIdentityUsage( RsServiceType service,
|
|
|
|
RsIdentityUsage::UsageCode code,
|
|
|
|
const RsGxsGroupId& gid = RsGxsGroupId(),
|
|
|
|
const RsGxsMessageId& mid = RsGxsMessageId(),
|
|
|
|
uint64_t additional_id=0,
|
|
|
|
const std::string& comment = std::string() );
|
|
|
|
|
2018-01-15 21:31:03 -05:00
|
|
|
/// Id of the service using that identity, as understood by rsServiceControl
|
2019-06-12 13:01:19 -04:00
|
|
|
RsServiceType mServiceId;
|
2018-01-15 21:31:03 -05:00
|
|
|
|
|
|
|
/** Specific code to use. Will allow forming the correct translated message
|
|
|
|
* in the GUI if necessary. */
|
|
|
|
UsageCode mUsageCode;
|
|
|
|
|
|
|
|
/// Group ID using the identity
|
|
|
|
RsGxsGroupId mGrpId;
|
|
|
|
|
|
|
|
/// Message ID using the identity
|
|
|
|
RsGxsMessageId mMsgId;
|
|
|
|
|
|
|
|
/// Some additional ID. Can be used for e.g. chat lobbies.
|
|
|
|
uint64_t mAdditionalId;
|
|
|
|
|
|
|
|
/// additional comment to be used mainly for debugging, but not GUI display
|
|
|
|
std::string mComment;
|
|
|
|
|
|
|
|
bool operator<(const RsIdentityUsage& u) const { return mHash < u.mHash; }
|
2019-02-13 15:08:38 -05:00
|
|
|
RsFileHash mHash;
|
2018-01-15 21:31:03 -05:00
|
|
|
|
|
|
|
/// @see RsSerializable
|
|
|
|
void serial_process( RsGenericSerializer::SerializeJob j,
|
2019-02-13 15:08:38 -05:00
|
|
|
RsGenericSerializer::SerializeContext& ctx ) override
|
2018-01-15 21:31:03 -05:00
|
|
|
{
|
2018-01-25 05:37:16 -05:00
|
|
|
RS_SERIAL_PROCESS(mServiceId);
|
|
|
|
RS_SERIAL_PROCESS(mUsageCode);
|
|
|
|
RS_SERIAL_PROCESS(mGrpId);
|
|
|
|
RS_SERIAL_PROCESS(mMsgId);
|
|
|
|
RS_SERIAL_PROCESS(mAdditionalId);
|
|
|
|
RS_SERIAL_PROCESS(mComment);
|
|
|
|
RS_SERIAL_PROCESS(mHash);
|
2018-01-15 21:31:03 -05:00
|
|
|
}
|
|
|
|
|
2018-01-22 08:50:07 -05:00
|
|
|
friend struct RsTypeSerializer;
|
2018-01-15 21:31:03 -05:00
|
|
|
private:
|
|
|
|
/** Accessible only to friend class RsTypeSerializer needed for
|
|
|
|
* deserialization */
|
|
|
|
RsIdentityUsage();
|
2017-01-02 09:58:37 -05:00
|
|
|
};
|
|
|
|
|
2020-01-27 17:02:04 -05:00
|
|
|
enum class RsGxsIdentityEventCode: uint8_t
|
|
|
|
{
|
|
|
|
UNKNOWN = 0x00,
|
|
|
|
NEW_IDENTITY = 0x01,
|
|
|
|
DELETED_IDENTITY = 0x02,
|
2020-02-06 13:57:23 -05:00
|
|
|
UPDATED_IDENTITY = 0x03,
|
2020-01-27 17:02:04 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
struct RsGxsIdentityEvent: public RsEvent
|
|
|
|
{
|
|
|
|
RsGxsIdentityEvent()
|
|
|
|
: RsEvent(RsEventType::GXS_IDENTITY),
|
|
|
|
mIdentityEventCode(RsGxsIdentityEventCode::UNKNOWN) {}
|
|
|
|
|
|
|
|
RsGxsIdentityEventCode mIdentityEventCode;
|
|
|
|
RsGxsGroupId mIdentityId;
|
|
|
|
|
|
|
|
///* @see RsEvent @see RsSerializable
|
|
|
|
void serial_process( RsGenericSerializer::SerializeJob j, RsGenericSerializer::SerializeContext& ctx ) override
|
|
|
|
{
|
|
|
|
RsEvent::serial_process(j, ctx);
|
|
|
|
RS_SERIAL_PROCESS(mIdentityEventCode);
|
|
|
|
RS_SERIAL_PROCESS(mIdentityId);
|
|
|
|
}
|
|
|
|
|
|
|
|
~RsGxsIdentityEvent() override = default;
|
|
|
|
};
|
2018-01-15 21:31:03 -05:00
|
|
|
|
|
|
|
struct RsIdentityDetails : RsSerializable
|
2017-01-02 17:53:39 -05:00
|
|
|
{
|
2018-01-15 21:31:03 -05:00
|
|
|
RsIdentityDetails() : mFlags(0), mLastUsageTS(0) {}
|
2017-01-02 17:53:39 -05:00
|
|
|
|
|
|
|
RsGxsId mId;
|
|
|
|
|
|
|
|
std::string mNickname;
|
|
|
|
|
2018-01-15 21:31:03 -05:00
|
|
|
uint32_t mFlags;
|
2017-01-02 17:53:39 -05:00
|
|
|
|
2018-01-15 21:31:03 -05:00
|
|
|
RsPgpId mPgpId;
|
2017-01-02 17:53:39 -05:00
|
|
|
|
2018-01-15 21:31:03 -05:00
|
|
|
/// @deprecated Recogn details.
|
|
|
|
RS_DEPRECATED std::list<RsRecognTag> mRecognTags;
|
2017-01-02 17:53:39 -05:00
|
|
|
|
2018-01-15 21:31:03 -05:00
|
|
|
/** Cyril: Reputation details. At some point we might want to merge
|
|
|
|
* information between the two into a single global score. Since the old
|
|
|
|
* reputation system is not finished yet, I leave this in place. We should
|
|
|
|
* decide what to do with it.
|
|
|
|
*/
|
2019-02-15 13:29:36 -05:00
|
|
|
RsReputationInfo mReputation;
|
2017-01-02 17:53:39 -05:00
|
|
|
|
2018-01-15 21:31:03 -05:00
|
|
|
RsGxsImage mAvatar;
|
2017-01-02 17:53:39 -05:00
|
|
|
|
2019-01-19 09:54:07 -05:00
|
|
|
rstime_t mPublishTS;
|
2018-10-06 19:34:05 -04:00
|
|
|
rstime_t mLastUsageTS;
|
2017-01-02 17:53:39 -05:00
|
|
|
|
2018-10-06 19:34:05 -04:00
|
|
|
std::map<RsIdentityUsage,rstime_t> mUseCases;
|
2017-01-02 17:53:39 -05:00
|
|
|
|
2018-01-15 21:31:03 -05:00
|
|
|
/// @see RsSerializable
|
2019-10-29 04:29:11 -04:00
|
|
|
virtual void serial_process(
|
|
|
|
RsGenericSerializer::SerializeJob j,
|
|
|
|
RsGenericSerializer::SerializeContext& ctx ) override
|
2018-01-15 21:31:03 -05:00
|
|
|
{
|
2018-01-25 05:37:16 -05:00
|
|
|
RS_SERIAL_PROCESS(mId);
|
|
|
|
RS_SERIAL_PROCESS(mNickname);
|
|
|
|
RS_SERIAL_PROCESS(mFlags);
|
|
|
|
RS_SERIAL_PROCESS(mPgpId);
|
2019-09-26 17:12:26 -04:00
|
|
|
RS_SERIAL_PROCESS(mReputation);
|
2019-02-13 15:08:38 -05:00
|
|
|
RS_SERIAL_PROCESS(mAvatar);
|
2019-01-19 09:54:07 -05:00
|
|
|
RS_SERIAL_PROCESS(mPublishTS);
|
2018-01-25 05:37:16 -05:00
|
|
|
RS_SERIAL_PROCESS(mLastUsageTS);
|
|
|
|
RS_SERIAL_PROCESS(mUseCases);
|
2018-01-15 21:31:03 -05:00
|
|
|
}
|
2019-10-29 04:29:11 -04:00
|
|
|
|
|
|
|
~RsIdentityDetails() override;
|
2018-01-15 21:31:03 -05:00
|
|
|
};
|
2017-01-02 09:58:37 -05:00
|
|
|
|
2012-10-21 11:48:18 -04:00
|
|
|
|
2012-06-13 20:27:28 -04:00
|
|
|
|
2019-02-13 15:08:38 -05:00
|
|
|
/** The Main Interface Class for GXS people identities */
|
2020-03-16 19:13:29 -04:00
|
|
|
class RsIdentity: public RsGxsIfaceHelper
|
2018-01-15 21:31:03 -05:00
|
|
|
{
|
2020-03-16 19:13:29 -04:00
|
|
|
public:
|
2019-02-13 15:08:38 -05:00
|
|
|
explicit RsIdentity(RsGxsIface& gxs) : RsGxsIfaceHelper(gxs) {}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Create a new identity
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @param[out] id storage for the created identity Id
|
|
|
|
* @param[in] name Name of the identity
|
|
|
|
* @param[in] avatar Image associated to the identity
|
|
|
|
* @param[in] pseudonimous true for unsigned identity, false otherwise
|
|
|
|
* @param[in] pgpPassword password to unlock PGP to sign identity,
|
|
|
|
* not implemented yet
|
|
|
|
* @return false on error, true otherwise
|
|
|
|
*/
|
|
|
|
virtual bool createIdentity(
|
|
|
|
RsGxsId& id,
|
|
|
|
const std::string& name, const RsGxsImage& avatar = RsGxsImage(),
|
|
|
|
bool pseudonimous = true, const std::string& pgpPassword = "" ) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Locally delete given identity
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @param[in] id Id of the identity
|
|
|
|
* @return false on error, true otherwise
|
|
|
|
*/
|
|
|
|
virtual bool deleteIdentity(RsGxsId& id) = 0;
|
2012-10-14 14:32:33 -04:00
|
|
|
|
2019-02-13 15:08:38 -05:00
|
|
|
/**
|
|
|
|
* @brief Update identity data (name, avatar...)
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @param[in] identityData updated identiy data
|
|
|
|
* @return false on error, true otherwise
|
|
|
|
*/
|
|
|
|
virtual bool updateIdentity(RsGxsIdGroup& identityData) = 0;
|
2016-07-03 18:59:30 -04:00
|
|
|
|
2019-02-13 15:08:38 -05:00
|
|
|
/**
|
|
|
|
* @brief Get identity details, from the cache
|
2019-07-19 07:54:46 -04:00
|
|
|
* @jsonapi{development}
|
2019-02-13 15:08:38 -05:00
|
|
|
* @param[in] id Id of the identity
|
|
|
|
* @param[out] details Storage for the identity details
|
|
|
|
* @return false on error, true otherwise
|
|
|
|
*/
|
|
|
|
virtual bool getIdDetails(const RsGxsId& id, RsIdentityDetails& details) = 0;
|
2012-10-14 14:32:33 -04:00
|
|
|
|
2019-02-13 15:08:38 -05:00
|
|
|
/**
|
|
|
|
* @brief Get last seen usage time of given identity
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @param[in] id Id of the identity
|
|
|
|
* @return timestamp of last seen usage
|
|
|
|
*/
|
|
|
|
virtual rstime_t getLastUsageTS(const RsGxsId& id) = 0;
|
2012-10-14 14:32:33 -04:00
|
|
|
|
2019-02-13 15:08:38 -05:00
|
|
|
/**
|
|
|
|
* @brief Get own signed ids
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @param[out] ids storage for the ids
|
|
|
|
* @return false on error, true otherwise
|
|
|
|
*/
|
2019-07-19 07:54:46 -04:00
|
|
|
virtual bool getOwnSignedIds(std::vector<RsGxsId>& ids) = 0;
|
2015-04-18 15:59:27 -04:00
|
|
|
|
2019-02-13 15:08:38 -05:00
|
|
|
/**
|
|
|
|
* @brief Get own pseudonimous (unsigned) ids
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @param[out] ids storage for the ids
|
|
|
|
* @return false on error, true otherwise
|
|
|
|
*/
|
2019-07-19 07:54:46 -04:00
|
|
|
virtual bool getOwnPseudonimousIds(std::vector<RsGxsId>& ids) = 0;
|
2012-10-14 14:32:33 -04:00
|
|
|
|
2019-09-26 17:12:26 -04:00
|
|
|
/**
|
|
|
|
* @brief Check if an id is known
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @param[in] id Id to check
|
|
|
|
* @return true if the id is known, false otherwise
|
|
|
|
*/
|
|
|
|
virtual bool isKnownId(const RsGxsId& id) = 0;
|
|
|
|
|
2019-02-13 15:08:38 -05:00
|
|
|
/**
|
|
|
|
* @brief Check if an id is own
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @param[in] id Id to check
|
|
|
|
* @return true if the id is own, false otherwise
|
|
|
|
*/
|
|
|
|
virtual bool isOwnId(const RsGxsId& id) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get identities summaries list.
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @param[out] ids list where to store the identities
|
|
|
|
* @return false if something failed, true otherwhise
|
|
|
|
*/
|
|
|
|
virtual bool getIdentitiesSummaries(std::list<RsGroupMetaData>& ids) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get identities information (name, avatar...).
|
|
|
|
* Blocking API.
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @param[in] ids ids of the channels of which to get the informations
|
|
|
|
* @param[out] idsInfo storage for the identities informations
|
|
|
|
* @return false if something failed, true otherwhise
|
|
|
|
*/
|
|
|
|
virtual bool getIdentitiesInfo(
|
|
|
|
const std::set<RsGxsId>& ids,
|
|
|
|
std::vector<RsGxsIdGroup>& idsInfo ) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Check if an identity is contact
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @param[in] id Id of the identity
|
|
|
|
* @return true if it is a conctact, false otherwise
|
|
|
|
*/
|
|
|
|
virtual bool isARegularContact(const RsGxsId& id) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set/unset identity as contact
|
2019-08-20 06:45:40 -04:00
|
|
|
* @jsonapi{development}
|
2019-02-13 15:08:38 -05:00
|
|
|
* @param[in] id Id of the identity
|
|
|
|
* @param[in] isContact true to set, false to unset
|
|
|
|
* @return false on error, true otherwise
|
|
|
|
*/
|
|
|
|
virtual bool setAsRegularContact(const RsGxsId& id, bool isContact) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Toggle automatic flagging signed by friends identity as contact
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @param[in] enabled true to enable, false to disable
|
|
|
|
*/
|
|
|
|
virtual void setAutoAddFriendIdsAsContact(bool enabled) = 0;
|
2012-10-14 14:32:33 -04:00
|
|
|
|
2019-02-13 15:08:38 -05:00
|
|
|
/**
|
|
|
|
* @brief Check if automatic signed by friend identity contact flagging is
|
|
|
|
* enabled
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @return true if enabled, false otherwise
|
|
|
|
*/
|
|
|
|
virtual bool autoAddFriendIdsAsContact() = 0;
|
2013-10-20 05:43:30 -04:00
|
|
|
|
2019-02-13 15:08:38 -05:00
|
|
|
/**
|
|
|
|
* @brief Get number of days after which delete a banned identities
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @return number of days
|
|
|
|
*/
|
|
|
|
virtual uint32_t deleteBannedNodesThreshold() = 0;
|
2017-01-12 14:39:49 -05:00
|
|
|
|
2019-02-13 15:08:38 -05:00
|
|
|
/**
|
|
|
|
* @brief Set number of days after which delete a banned identities
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @param[in] days number of days
|
|
|
|
*/
|
|
|
|
virtual void setDeleteBannedNodesThreshold(uint32_t days) = 0;
|
2013-10-20 05:43:30 -04:00
|
|
|
|
2019-06-12 13:01:19 -04:00
|
|
|
/**
|
|
|
|
* @brief request details of a not yet known identity to the network
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @param[in] id id of the identity to request
|
2020-01-04 14:34:35 -05:00
|
|
|
* @param[in] peers optional list of the peers to ask for the key, if empty
|
|
|
|
* all online peers are asked.
|
2019-06-12 13:01:19 -04:00
|
|
|
* @return false on error, true otherwise
|
|
|
|
*/
|
2020-01-04 14:34:35 -05:00
|
|
|
virtual bool requestIdentity(
|
|
|
|
const RsGxsId& id,
|
|
|
|
const std::vector<RsPeerId>& peers = std::vector<RsPeerId>() ) = 0;
|
2019-06-12 13:01:19 -04:00
|
|
|
|
2019-10-29 04:29:11 -04:00
|
|
|
/// default base URL used for indentity links @see exportIdentityLink
|
|
|
|
static const std::string DEFAULT_IDENTITY_BASE_URL;
|
2019-02-13 15:08:38 -05:00
|
|
|
|
2019-10-29 04:29:11 -04:00
|
|
|
/// Link query field used to store indentity name @see exportIdentityLink
|
|
|
|
static const std::string IDENTITY_URL_NAME_FIELD;
|
|
|
|
|
|
|
|
/// Link query field used to store indentity id @see exportIdentityLink
|
|
|
|
static const std::string IDENTITY_URL_ID_FIELD;
|
|
|
|
|
|
|
|
/// Link query field used to store indentity data @see exportIdentityLink
|
|
|
|
static const std::string IDENTITY_URL_DATA_FIELD;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get link to a identity
|
|
|
|
* @jsonapi{development}
|
|
|
|
* @param[out] link storage for the generated link
|
|
|
|
* @param[in] id Id of the identity of which you want to generate a link
|
|
|
|
* @param[in] includeGxsData if true include the identity GXS group data so
|
|
|
|
* the receiver can make use of the identity even if she hasn't received it
|
|
|
|
* through GXS yet
|
|
|
|
* @param[in] baseUrl URL into which to sneak in the RetroShare link
|
|
|
|
* radix, this is primarly useful to induce applications into making the
|
|
|
|
* link clickable, or to disguise the RetroShare link into a
|
|
|
|
* "normal" looking web link. If empty the GXS data link will be outputted
|
|
|
|
* in plain base64 format.
|
|
|
|
* @param[out] errMsg optional storage for error message, meaningful only in
|
|
|
|
* case of failure
|
|
|
|
* @return false if something failed, true otherwhise
|
|
|
|
*/
|
|
|
|
virtual bool exportIdentityLink(
|
|
|
|
std::string& link, const RsGxsId& id,
|
|
|
|
bool includeGxsData = true,
|
|
|
|
const std::string& baseUrl = RsIdentity::DEFAULT_IDENTITY_BASE_URL,
|
|
|
|
std::string& errMsg = RS_DEFAULT_STORAGE_PARAM(std::string) ) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Import identity from full link
|
|
|
|
* @param[in] link identity link either in radix or link format
|
|
|
|
* @param[out] id optional storage for parsed identity
|
|
|
|
* @param[out] errMsg optional storage for error message, meaningful only in
|
|
|
|
* case of failure
|
|
|
|
* @return false if some error occurred, true otherwise
|
|
|
|
*/
|
|
|
|
virtual bool importIdentityLink(
|
|
|
|
const std::string& link,
|
|
|
|
RsGxsId& id = RS_DEFAULT_STORAGE_PARAM(RsGxsId),
|
|
|
|
std::string& errMsg = RS_DEFAULT_STORAGE_PARAM(std::string) ) = 0;
|
|
|
|
|
|
|
|
RS_DEPRECATED_FOR(exportIdentityLink)
|
2019-02-13 15:08:38 -05:00
|
|
|
virtual bool getGroupSerializedData(
|
|
|
|
const uint32_t& token,
|
|
|
|
std::map<RsGxsId,std::string>& serialized_groups ) = 0;
|
|
|
|
|
|
|
|
RS_DEPRECATED
|
|
|
|
virtual bool parseRecognTag(
|
|
|
|
const RsGxsId &id, const std::string& nickname,
|
|
|
|
const std::string& tag, RsRecognTagDetails& details) = 0;
|
|
|
|
|
|
|
|
RS_DEPRECATED
|
|
|
|
virtual bool getRecognTagRequest(
|
|
|
|
const RsGxsId& id, const std::string& comment, uint16_t tag_class,
|
|
|
|
uint16_t tag_type, std::string& tag) = 0;
|
|
|
|
|
|
|
|
RS_DEPRECATED
|
2018-10-03 09:25:53 -04:00
|
|
|
virtual uint32_t nbRegularContacts() =0;
|
2016-12-23 11:52:02 -05:00
|
|
|
|
2019-10-29 04:29:11 -04:00
|
|
|
RS_DEPRECATED_FOR(exportIdentityLink)
|
2017-04-19 17:48:25 -04:00
|
|
|
virtual bool serialiseIdentityToMemory( const RsGxsId& id,
|
|
|
|
std::string& radix_string ) = 0;
|
2019-10-29 04:29:11 -04:00
|
|
|
RS_DEPRECATED_FOR(importIdentityLink)
|
2017-04-19 17:48:25 -04:00
|
|
|
virtual bool deserialiseIdentityFromMemory( const std::string& radix_string,
|
|
|
|
RsGxsId* id = nullptr ) = 0;
|
2017-04-08 13:07:33 -04:00
|
|
|
|
2019-02-13 15:08:38 -05:00
|
|
|
/// Fills up list of all own ids. Returns false if ids are not yet loaded.
|
|
|
|
RS_DEPRECATED_FOR("getOwnSignedIds getOwnPseudonimousIds")
|
|
|
|
virtual bool getOwnIds( std::list<RsGxsId> &ownIds,
|
|
|
|
bool only_signed_ids = false ) = 0;
|
2016-07-03 18:59:30 -04:00
|
|
|
|
2019-02-13 15:08:38 -05:00
|
|
|
RS_DEPRECATED
|
|
|
|
virtual bool createIdentity(uint32_t& token, RsIdentityParameters ¶ms) = 0;
|
2012-02-13 13:22:35 -05:00
|
|
|
|
2019-02-13 15:08:38 -05:00
|
|
|
RS_DEPRECATED_FOR(RsReputations)
|
|
|
|
virtual bool submitOpinion(uint32_t& token, const RsGxsId &id,
|
|
|
|
bool absOpinion, int score) = 0;
|
2012-06-13 20:27:28 -04:00
|
|
|
|
2019-02-13 15:08:38 -05:00
|
|
|
RS_DEPRECATED
|
|
|
|
virtual bool updateIdentity(uint32_t& token, RsGxsIdGroup &group) = 0;
|
|
|
|
|
|
|
|
RS_DEPRECATED
|
|
|
|
virtual bool deleteIdentity(uint32_t& token, RsGxsIdGroup &group) = 0;
|
2012-02-13 13:22:35 -05:00
|
|
|
|
2019-02-13 15:08:38 -05:00
|
|
|
RS_DEPRECATED_FOR("getIdentitiesSummaries getIdentitiesInfo")
|
|
|
|
virtual bool getGroupData( const uint32_t& token,
|
|
|
|
std::vector<RsGxsIdGroup>& groups) = 0;
|
2019-09-26 17:12:26 -04:00
|
|
|
|
|
|
|
virtual ~RsIdentity();
|
2019-02-13 15:08:38 -05:00
|
|
|
};
|