Improvements to the photoservice & underlying GS test service.

- added PublishTS and AuthorID to GropuMetaData.
	- added Mod & Set Flags to PhotoData. (mainly for the GUI).
	- added "isNew" parameter to sumbitPhoto/Album calls.
	- support modifications to Photos.
	- improved Photo Thumbnail handling. (still not right).
	- added LATEST msg search in GxsService.
	- added ATTRIB flags to rsphoto.h



git-svn-id: http://svn.code.sf.net/p/retroshare/code/branches/v0.5-new_cache_system@5238 b45a01b8-16f6-495d-af2f-9b41ad6348cc
This commit is contained in:
drbob 2012-06-21 15:50:27 +00:00
parent 7a22d4fe69
commit 8af268e8c8
5 changed files with 198 additions and 32 deletions

View File

@ -64,6 +64,7 @@
#define RSGXS_MSG_STATUS_MASK 0x000f #define RSGXS_MSG_STATUS_MASK 0x000f
#define RSGXS_MSG_STATUS_READ 0x0001 #define RSGXS_MSG_STATUS_READ 0x0001
#define RSGXS_MSG_STATUS_UNREAD_BY_USER 0x0002 #define RSGXS_MSG_STATUS_UNREAD_BY_USER 0x0002
#define RSGXS_MSG_STATUS_PROCESSED 0x0004 // By the Service.
@ -94,12 +95,17 @@ class RsGroupMetaData
mMsgCount = 0; mMsgCount = 0;
mLastPost = 0; mLastPost = 0;
mGroupStatus = 0; mGroupStatus = 0;
//mPublishTs = 0;
} }
std::string mGroupId; std::string mGroupId;
std::string mGroupName; std::string mGroupName;
uint32_t mGroupFlags; uint32_t mGroupFlags;
time_t mPublishTs; // Mandatory.
std::string mAuthorId; // Optional.
// BELOW HERE IS LOCAL DATA, THAT IS NOT FROM MSG. // BELOW HERE IS LOCAL DATA, THAT IS NOT FROM MSG.
uint32_t mSubscribeFlags; uint32_t mSubscribeFlags;

View File

@ -47,6 +47,7 @@ class RsPhotoThumbnail
RsPhotoThumbnail() RsPhotoThumbnail()
:data(NULL), size(0), type("N/A") { return; } :data(NULL), size(0), type("N/A") { return; }
bool deleteImage();
bool copyFrom(const RsPhotoThumbnail &nail); bool copyFrom(const RsPhotoThumbnail &nail);
// Holds Thumbnail image. // Holds Thumbnail image.
@ -55,17 +56,38 @@ class RsPhotoThumbnail
std::string type; std::string type;
}; };
/* If these flags are no set - the Photo inherits values from the Album
*/
#define RSPHOTO_FLAGS_ATTRIB_TITLE 0x0001
#define RSPHOTO_FLAGS_ATTRIB_CAPTION 0x0002
#define RSPHOTO_FLAGS_ATTRIB_DESC 0x0004
#define RSPHOTO_FLAGS_ATTRIB_PHOTOGRAPHER 0x0008
#define RSPHOTO_FLAGS_ATTRIB_WHERE 0x0010
#define RSPHOTO_FLAGS_ATTRIB_WHEN 0x0020
#define RSPHOTO_FLAGS_ATTRIB_OTHER 0x0040
#define RSPHOTO_FLAGS_ATTRIB_CATEGORY 0x0080
#define RSPHOTO_FLAGS_ATTRIB_HASHTAGS 0x0100
#define RSPHOTO_FLAGS_ATTRIB_ORDER 0x0200
#define RSPHOTO_FLAGS_ATTRIB_THUMBNAIL 0x0400
#define RSPHOTO_FLAGS_ATTRIB_MODE 0x0800
#define RSPHOTO_FLAGS_ATTRIB_AUTHOR 0x1000 // PUSH UP ORDER
#define RSPHOTO_FLAGS_ATTRIB_PHOTO 0x2000 // PUSH UP ORDER.
class RsPhotoPhoto class RsPhotoPhoto
{ {
public: public:
RsMsgMetaData mMeta; RsMsgMetaData mMeta;
RsPhotoPhoto();
// THESE ARE IN THE META DATA. // THESE ARE IN THE META DATA.
//std::string mAlbumId; //std::string mAlbumId;
//std::string mId; //std::string mId;
//std::string mTitle; // only used by Album. //std::string mTitle; // only used by Album.
std::string mCaption; std::string mCaption;
std::string mDescription; std::string mDescription;
std::string mPhotographer; std::string mPhotographer;
@ -76,12 +98,17 @@ class RsPhotoPhoto
std::string mHashTags; std::string mHashTags;
uint32_t mSetFlags;
int mOrder; int mOrder;
RsPhotoThumbnail mThumbnail; RsPhotoThumbnail mThumbnail;
int mMode; int mMode;
// These are not saved.
std::string path; // if in Mode NEW. std::string path; // if in Mode NEW.
uint32_t mModFlags;
}; };
class RsPhotoAlbumShare class RsPhotoAlbumShare
@ -98,6 +125,7 @@ class RsPhotoAlbumShare
class RsPhotoAlbum class RsPhotoAlbum
{ {
public: public:
RsPhotoAlbum();
RsGroupMetaData mMeta; RsGroupMetaData mMeta;
@ -121,8 +149,15 @@ class RsPhotoAlbum
std::string mPhotoPath; std::string mPhotoPath;
RsPhotoAlbumShare mShareOptions; RsPhotoAlbumShare mShareOptions;
// These aren't saved.
uint32_t mSetFlags;
uint32_t mModFlags;
}; };
std::ostream &operator<<(std::ostream &out, const RsPhotoPhoto &photo);
std::ostream &operator<<(std::ostream &out, const RsPhotoAlbum &album);
class RsPhoto: public RsTokenService class RsPhoto: public RsTokenService
{ {
@ -177,8 +212,8 @@ virtual bool getAlbum(const uint32_t &token, RsPhotoAlbum &album) = 0;
virtual bool getPhoto(const uint32_t &token, RsPhotoPhoto &photo) = 0; virtual bool getPhoto(const uint32_t &token, RsPhotoPhoto &photo) = 0;
/* details are updated in album - to choose Album ID, and storage path */ /* details are updated in album - to choose Album ID, and storage path */
virtual bool submitAlbumDetails(RsPhotoAlbum &album) = 0; virtual bool submitAlbumDetails(RsPhotoAlbum &album, bool isNew) = 0;
virtual bool submitPhoto(RsPhotoPhoto &photo) = 0; virtual bool submitPhoto(RsPhotoPhoto &photo, bool isNew) = 0;
}; };

View File

@ -379,43 +379,104 @@ bool GxsDataProxy::getMsgList( uint32_t &token, const RsTokReqOptions &opt
* 1) No Flags => All Messages in those Groups. * 1) No Flags => All Messages in those Groups.
* *
*/ */
std::cerr << "GxsDataProxy::getMsgList()";
std::cerr << std::endl;
bool onlyOrigMsgs = false; bool onlyOrigMsgs = false;
bool onlyLatestMsgs = false;
// Can only choose one of these two.
if (opts.mOptions & RS_TOKREQOPT_MSG_ORIGMSG) if (opts.mOptions & RS_TOKREQOPT_MSG_ORIGMSG)
{ {
onlyOrigMsgs = true; onlyOrigMsgs = true;
} }
else if (opts.mOptions & RS_TOKREQOPT_MSG_LATEST)
{
std::cerr << "GxsDataProxy::getMsgList() REQUESTED LATEST!!!";
std::cerr << std::endl;
std::cerr << "GxsDataProxy::getMsgList()"; onlyLatestMsgs = true;
std::cerr << std::endl; }
std::list<std::string>::const_iterator it; std::list<std::string>::const_iterator it;
std::map<std::string, RsMsgMetaData>::iterator mit; std::map<std::string, RsMsgMetaData>::iterator mit;
for(it = groupIds.begin(); it != groupIds.end(); it++) for(it = groupIds.begin(); it != groupIds.end(); it++)
{ {
for(mit = mMsgMetaData.begin(); mit != mMsgMetaData.end(); mit++) if (onlyLatestMsgs) // THIS ONE IS HARD -> LOTS OF COMP.
{ {
if (mit->second.mGroupId == *it) // RUN THROUGH ALL MSGS... in map origId -> TS.
std::map<std::string, std::pair<std::string, uint32_t> > origMsgTs;
std::map<std::string, std::pair<std::string, uint32_t> >::iterator oit;
for(mit = mMsgMetaData.begin(); mit != mMsgMetaData.end(); mit++)
{ {
bool add = false; if (mit->second.mGroupId != *it)
if (onlyOrigMsgs)
{ {
if (mit->second.mMsgId == mit->second.mOrigMsgId) continue;
}
oit = origMsgTs.find(mit->second.mOrigMsgId);
bool addMsg = false;
if (oit == origMsgTs.end())
{
std::cerr << "GxsDataProxy::getMsgList() Found New OrigMsgId: ";
std::cerr << mit->second.mOrigMsgId;
std::cerr << " MsgId: " << mit->second.mMsgId;
std::cerr << " TS: " << mit->second.mPublishTs;
std::cerr << std::endl;
addMsg = true;
}
// check timestamps.
else if (oit->second.second < mit->second.mPublishTs)
{
std::cerr << "GxsDataProxy::getMsgList() Found Later Msg. OrigMsgId: ";
std::cerr << mit->second.mOrigMsgId;
std::cerr << " MsgId: " << mit->second.mMsgId;
std::cerr << " TS: " << mit->second.mPublishTs;
addMsg = true;
}
if (addMsg)
{
// add as latest. (overwriting if necessary)
origMsgTs[mit->second.mOrigMsgId] = std::make_pair(mit->second.mMsgId, mit->second.mPublishTs);
}
}
// Add the discovered Latest Msgs.
for(oit = origMsgTs.begin(); oit != origMsgTs.end(); oit++)
{
outMsgIds.push_back(oit->second.first);
}
}
else // ALL OTHER CASES.
{
for(mit = mMsgMetaData.begin(); mit != mMsgMetaData.end(); mit++)
{
if (mit->second.mGroupId == *it)
{
bool add = false;
if (onlyOrigMsgs)
{
if (mit->second.mMsgId == mit->second.mOrigMsgId)
{
add = true;
}
}
else
{ {
add = true; add = true;
} }
}
else
{
add = true;
}
if (add) if (add)
{ {
outMsgIds.push_back(mit->first); outMsgIds.push_back(mit->first);
}
} }
} }
} }

View File

@ -384,7 +384,7 @@ bool p3PhotoService::groupShareKeys(const std::string &groupId, std::list<std::s
/* details are updated in album - to choose Album ID, and storage path */ /* details are updated in album - to choose Album ID, and storage path */
bool p3PhotoService::submitAlbumDetails(RsPhotoAlbum &album) bool p3PhotoService::submitAlbumDetails(RsPhotoAlbum &album, bool isNew)
{ {
/* check if its a modification or a new album */ /* check if its a modification or a new album */
@ -397,8 +397,15 @@ bool p3PhotoService::submitAlbumDetails(RsPhotoAlbum &album)
/* generate a temp id */ /* generate a temp id */
album.mMeta.mGroupId = genRandomId(); album.mMeta.mGroupId = genRandomId();
// TODO.
//album.mMeta.mPublishTs = time(NULL);
std::cerr << "p3PhotoService::submitAlbumDetails() Generated New GroupID: " << album.mMeta.mGroupId;
std::cerr << std::endl;
} }
album.mModFlags = 0; // These are always cleared.
RsStackMutex stack(mPhotoMtx); /********** STACK LOCKED MTX ******/ RsStackMutex stack(mPhotoMtx); /********** STACK LOCKED MTX ******/
mUpdated = true; mUpdated = true;
@ -410,7 +417,7 @@ bool p3PhotoService::submitAlbumDetails(RsPhotoAlbum &album)
} }
bool p3PhotoService::submitPhoto(RsPhotoPhoto &photo) bool p3PhotoService::submitPhoto(RsPhotoPhoto &photo, bool isNew)
{ {
if (photo.mMeta.mGroupId.empty()) if (photo.mMeta.mGroupId.empty())
{ {
@ -420,14 +427,28 @@ bool p3PhotoService::submitPhoto(RsPhotoPhoto &photo)
return false; return false;
} }
/* check if its a mod or new photo */ /* generate a new id */
if (photo.mMeta.mMsgId.empty()) photo.mMeta.mMsgId = genRandomId();
{ photo.mMeta.mPublishTs = time(NULL);
/* new photo */
/* generate a temp id */ if (isNew)
photo.mMeta.mMsgId = genRandomId(); {
/* new (Original Msg) photo */
photo.mMeta.mOrigMsgId = photo.mMeta.mMsgId;
std::cerr << "p3PhotoService::submitPhoto() New Msg";
std::cerr << std::endl;
} }
else
{
std::cerr << "p3PhotoService::submitPhoto() Updated Msg";
std::cerr << std::endl;
}
photo.mModFlags = 0; // These are always cleared.
std::cerr << "p3PhotoService::submitPhoto() OrigMsgId: " << photo.mMeta.mOrigMsgId;
std::cerr << " MsgId: " << photo.mMeta.mMsgId;
std::cerr << std::endl;
RsStackMutex stack(mPhotoMtx); /********** STACK LOCKED MTX ******/ RsStackMutex stack(mPhotoMtx); /********** STACK LOCKED MTX ******/
@ -567,8 +588,7 @@ bool RsPhotoThumbnail::copyFrom(const RsPhotoThumbnail &nail)
{ {
if (data) if (data)
{ {
free(data); deleteImage();
size = 0;
} }
if ((!nail.data) || (nail.size == 0)) if ((!nail.data) || (nail.size == 0))
@ -584,3 +604,47 @@ bool RsPhotoThumbnail::copyFrom(const RsPhotoThumbnail &nail)
return true; return true;
} }
bool RsPhotoThumbnail::deleteImage()
{
if (data)
{
free(data);
data = NULL;
size = 0;
}
}
/********************************************************************************************/
RsPhotoPhoto::RsPhotoPhoto()
:mSetFlags(0), mOrder(0), mMode(0), mModFlags(0)
{
return;
}
RsPhotoAlbum::RsPhotoAlbum()
:mMode(0), mSetFlags(0), mModFlags(0)
{
return;
}
std::ostream &operator<<(std::ostream &out, const RsPhotoPhoto &photo)
{
out << "RsPhotoPhoto [ ";
out << "Title: " << photo.mMeta.mMsgName;
out << "]";
return out;
}
std::ostream &operator<<(std::ostream &out, const RsPhotoAlbum &album)
{
out << "RsPhotoAlbum [ ";
out << "Title: " << album.mMeta.mGroupName;
out << "]";
return out;
}

View File

@ -120,8 +120,8 @@ virtual bool groupShareKeys(const std::string &groupId, std::list<std::string>&
/* details are updated in album - to choose Album ID, and storage path */ /* details are updated in album - to choose Album ID, and storage path */
virtual bool submitAlbumDetails(RsPhotoAlbum &album); virtual bool submitAlbumDetails(RsPhotoAlbum &album, bool isNew);
virtual bool submitPhoto(RsPhotoPhoto &photo); virtual bool submitPhoto(RsPhotoPhoto &photo, bool isNew);