struct _atom_backend
{
- AtomEntry * (*retrieve_entry) (AtomCtx *, IRI *);
- void (*enumerate_entries) (AtomCtx *, AtomEntry ***, size_t *);
+ AtomEntry * (*retrieve_entry) (AtomCtx *, AtomID *);
+ void (*enumerate_entries) (AtomCtx *, char ***, AtomEntry ***, size_t *);
+ int (*is_feed) (AtomCtx *, AtomID *);
};
AtomBackend *
void
atom_backend_retrieve_entry_set (AtomBackend *backend,
AtomEntry *retrieve_entry (AtomCtx *,
- IRI *))
+ AtomID *))
{
backend->retrieve_entry = retrieve_entry;
}
void
atom_backend_enumerate_entries_set (AtomBackend *backend,
void enumerate_entries (AtomCtx *,
- AtomEntry ***, size_t*))
+ char ***,
+ AtomEntry ***,
+ size_t *))
{
backend->enumerate_entries = enumerate_entries;
}
+void
+atom_backend_is_feed_set (AtomBackend *backend,
+ int is_feed (AtomCtx *, AtomID *))
+{
+ backend->is_feed = is_feed;
+}
+
AtomEntry *
-atom_retrieve_entry (AtomCtx *ctx, IRI *iri)
+atom_retrieve_entry (AtomCtx *ctx, AtomID *id)
{
AtomBackend *backend;
backend = atom_backend (ctx);
if (backend && backend->retrieve_entry)
- return backend->retrieve_entry (ctx, iri);
+ return backend->retrieve_entry (ctx, id);
return NULL;
}
void
-atom_backend_enumerate_entries (AtomCtx *ctx, AtomEntry *** entries, size_t *len)
+atom_backend_enumerate_entries (AtomCtx *ctx, char *** reqs,
+ AtomEntry *** entries, size_t *len)
{
AtomBackend *backend;
+ char **rreqs = NULL;
+ AtomEntry **rentries = NULL;
+ size_t rlen = 0;
+ int i;
backend = atom_backend (ctx);
if (backend && backend->enumerate_entries)
{
- backend->enumerate_entries (ctx, entries, len);
- return;
+ backend->enumerate_entries (ctx, &rreqs, &rentries, &rlen);
+ }
+ if (reqs)
+ {
+ *reqs = rreqs;
+ }
+ else
+ {
+ for (i = 0; i < rlen; i++)
+ g_free (rreqs[i]);
+ g_free (rreqs);
}
if (entries)
- *entries = NULL;
+ {
+ *entries = rentries;
+ }
+ else
+ {
+ for (i = 0; i < rlen; i++)
+ atom_entry_delete (rentries[i]);
+ g_free (rentries);
+ }
if (len)
- *len = 0;
+ *len = rlen;
+}
+
+int
+atom_is_feed (AtomCtx *ctx, AtomID *id)
+{
+ AtomBackend *backend;
+ AtomError *aerr;
+ backend = atom_backend (ctx);
+ if (backend && backend->is_feed)
+ {
+ return backend->is_feed (ctx, id);
+ }
+ /* Frontend may make the decision of whether the requested resource is
+ * a feed or not. If it is not able to do so and backend isn't either,
+ * it is an error.
+ */
+ aerr = atom_error_new ();
+ atom_error_code_set (aerr, 404);
+ atom_error_message_set (aerr, "Not Found");
+ atom_error_set (ctx, aerr);
+ return 0;
}
AtomFeed *
AtomFeed *feed;
AtomEntry **entries;
size_t len;
- atom_backend_enumerate_entries (ctx, &entries, &len);
+ atom_backend_enumerate_entries (ctx, NULL, &entries, &len);
+ if (atom_error_get (ctx) != NULL)
+ return NULL;
feed = atom_feed_new ();
atom_feed_entry_append_array (feed, entries, len);
+ g_free (entries);
return feed;
}
AtomResource *
-atom_retrieve_resource (AtomCtx *ctx, IRI *iri)
+atom_retrieve_resource (AtomCtx *ctx, AtomID *id)
{
AtomResource *res;
- char * path;
- path = iri_get_path (iri);
- if (!strcmp (path, "/"))
+ res = NULL;
+ if (atom_is_feed (ctx, id))
{
AtomFeed *feed;
feed = atom_retrieve_feed (ctx);
res = atom_resource_new_from_feed (feed);
atom_feed_delete (feed);
}
- else
+ else if (atom_error_get (ctx) == NULL)
{
AtomEntry *entry;
- entry = atom_retrieve_entry (ctx, iri);
+ entry = atom_retrieve_entry (ctx, id);
if (entry == NULL)
return NULL;
res = atom_resource_new_from_entry (entry);