Slon/Api/V1/Statuses: Refactor /api/v1/statues/:id/context
This commit is contained in:
parent
da6998c637
commit
e223273300
1 changed files with 53 additions and 51 deletions
|
@ -17,6 +17,30 @@ JsonObject* @slon_api_v1_statuses_lookup_by_id(U8* id, JsonArray* statuses)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
JsonObject* @slon_api_v1_statuses_find_by_id(U8* id, U8* account_id)
|
||||||
|
{
|
||||||
|
if (!id || !account_id) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
JsonObject* status = NULL;
|
||||||
|
// Lookup in public timeline
|
||||||
|
status = @slon_api_v1_statuses_lookup_by_id(id, db->o("timelines")->a("public"));
|
||||||
|
if (status) {
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
// Then, lookup in home timeline
|
||||||
|
status = @slon_api_v1_statuses_lookup_by_id(id, db->o("timelines")->o("home")->a(account_id));
|
||||||
|
if (status) {
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
// Finally, lookup in account's statuses
|
||||||
|
status = @slon_api_v1_statuses_lookup_by_id(id, db->o("statuses")->a(account_id));
|
||||||
|
if (status) {
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
U0 @slon_api_v1_statuses_query(SlonHttpSession* session, JsonArray* status_array)
|
U0 @slon_api_v1_statuses_query(SlonHttpSession* session, JsonArray* status_array)
|
||||||
{
|
{
|
||||||
SLON_SCRATCH_BUFFER_AND_REQUEST_JSON
|
SLON_SCRATCH_BUFFER_AND_REQUEST_JSON
|
||||||
|
@ -140,65 +164,43 @@ U0 @slon_api_v1_statuses_get(SlonHttpSession* session)
|
||||||
session->status(400);
|
session->status(400);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (session->path_count() > 4 && !StrICmp("history", session->path(4))) {
|
||||||
|
// NOTE: We probably won't support this any time soon
|
||||||
|
session->send(SLON_EMPTY_JSON_ARRAY);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
U8* id = session->path(3);
|
U8* id = session->path(3);
|
||||||
JsonArray* statuses_in_context = NULL;
|
JsonObject* status = NULL;
|
||||||
Bool context = FALSE;
|
|
||||||
|
|
||||||
if (session->path_count() > 4 && !StrICmp("context", session->path(4))) {
|
if (session->path_count() > 4 && !StrICmp("context", session->path(4))) {
|
||||||
statuses_in_context = Json.CreateArray();
|
JsonObject* context = Json.CreateObject();
|
||||||
context = TRUE;
|
context->set("ancestors", Json.CreateArray(), JSON_ARRAY);
|
||||||
|
context->set("descendants", Json.CreateArray(), JSON_ARRAY);
|
||||||
|
|
||||||
|
// Get ancestors
|
||||||
|
id = session->path(3);
|
||||||
|
status = @slon_api_v1_statuses_find_by_id(id, account_id);
|
||||||
|
while (status && status->@("in_reply_to_id")) {
|
||||||
|
id = status->@("in_reply_to_id");
|
||||||
|
status = @slon_api_v1_statuses_find_by_id(id, account_id);
|
||||||
|
if (status) {
|
||||||
|
context->a("ancestors")->append(Json.CreateItem(status, JSON_OBJECT));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
slon_api_v1_statuses_context_loop:
|
// FIXME: Get descendants
|
||||||
// FIXME: Unify statuses in database, until then, we do the following:
|
|
||||||
JsonObject* status = NULL;
|
session->send(context);
|
||||||
// Lookup in public timeline
|
|
||||||
status = @slon_api_v1_statuses_lookup_by_id(id, db->o("timelines")->a("public"));
|
|
||||||
if (status) {
|
|
||||||
switch (context) {
|
|
||||||
case TRUE:
|
|
||||||
statuses_in_context->append(Json.CreateItem(status, JSON_OBJECT));
|
|
||||||
goto slon_api_v1_statuses_context_continue;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
session->send(status);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
// Then, lookup in home timeline
|
status = @slon_api_v1_statuses_find_by_id(id, account_id);
|
||||||
status = @slon_api_v1_statuses_lookup_by_id(id, db->o("timelines")->o("home")->a(account_id));
|
|
||||||
if (status) {
|
if (status) {
|
||||||
switch (context) {
|
|
||||||
case TRUE:
|
|
||||||
statuses_in_context->append(Json.CreateItem(status, JSON_OBJECT));
|
|
||||||
goto slon_api_v1_statuses_context_continue;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
session->send(status);
|
session->send(status);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
// Finally, lookup in our statuses
|
|
||||||
status = @slon_api_v1_statuses_lookup_by_id(id, db->o("statuses")->a(account_id));
|
|
||||||
if (status) {
|
|
||||||
switch (context) {
|
|
||||||
case TRUE:
|
|
||||||
statuses_in_context->append(Json.CreateItem(status, JSON_OBJECT));
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
session->send(status);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
slon_api_v1_statuses_context_continue:
|
|
||||||
if (status && context && status->@("in_reply_to_id")) {
|
|
||||||
id = status->@("in_reply_to_id");
|
|
||||||
goto slon_api_v1_statuses_context_loop;
|
|
||||||
}
|
|
||||||
if (statuses_in_context) {
|
|
||||||
session->send(statuses_in_context);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
session->status(404);
|
session->status(404);
|
||||||
} else {
|
} else {
|
||||||
session->status(401);
|
session->status(401);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue