throw CccnxOperationException
diff --git a/model/sync-ccnx-wrapper.cc b/model/sync-ccnx-wrapper.cc
index d995e81..0684cea 100644
--- a/model/sync-ccnx-wrapper.cc
+++ b/model/sync-ccnx-wrapper.cc
@@ -22,6 +22,8 @@
#include "sync-ccnx-wrapper.h"
#include <poll.h>
+#include <boost/throw_exception.hpp>
+typedef boost::error_info<struct tag_errmsg, std::string> errmsg_info_str;
using namespace std;
using namespace boost;
@@ -35,7 +37,9 @@
, m_running (true)
{
m_handle = ccn_create();
- ccn_connect(m_handle, NULL);
+ if (ccn_connect(m_handle, NULL) < 0)
+ BOOST_THROW_EXCEPTION (CcnxOperationException()
+ << errmsg_info_str("connection to ccnd failed"));
initKeyStore();
createKeyLocator();
m_thread = thread (&CcnxWrapper::ccnLoop, this);
@@ -90,8 +94,9 @@
{
ccn_charbuf *temp = ccn_charbuf_create ();
m_keyStore = ccn_keystore_create ();
- ccn_charbuf_putf (temp, "%s/.ccnx/.ccnx_keystore", getenv("HOME"));
- ccn_keystore_init (m_keyStore, ccn_charbuf_as_string(temp), (char*)"Th1s1sn0t8g00dp8ssw0rd.");
+ string keyStoreFile = string(getenv("HOME")) + string("/.ccnx/.ccnx_keystore");
+ if (ccn_keystore_init (m_keyStore, (char *)keyStoreFile.c_str(), (char*)"Th1s1sn0t8g00dp8ssw0rd.") < 0)
+ BOOST_THROW_EXCEPTION(CcnxOperationException() << errmsg_info_str(keyStoreFile.c_str()));
ccn_charbuf_destroy (&temp);
}
@@ -136,11 +141,14 @@
freshness,
NULL,
m_keyLoactor);
- ccn_encode_ContentObject(content, pname, signed_info,
+ if(ccn_encode_ContentObject(content, pname, signed_info,
dataBuffer.c_str(), dataBuffer.length (),
- NULL, getPrivateKey());
+ NULL, getPrivateKey()) < 0)
+ BOOST_THROW_EXCEPTION(CcnxOperationException() << errmsg_info_str("encode content failed"));
+
recursive_mutex::scoped_lock lock(m_mutex);
- ccn_put(m_handle, content->buf, content->length);
+ if (ccn_put(m_handle, content->buf, content->length) < 0)
+ BOOST_THROW_EXCEPTION(CcnxOperationException() << errmsg_info_str("ccnput failed"));
ccn_charbuf_destroy (&pname);
ccn_charbuf_destroy (&signed_info);
@@ -205,7 +213,9 @@
char *pcontent;
size_t len;
- ccn_content_get_value(info->content_ccnb, info->pco->offset[CCN_PCO_E], info->pco, (const unsigned char **)&pcontent, &len);
+ if (ccn_content_get_value(info->content_ccnb, info->pco->offset[CCN_PCO_E], info->pco, (const unsigned char **)&pcontent, &len) < 0)
+ BOOST_THROW_EXCEPTION(CcnxOperationException() << errmsg_info_str("decode ContentObject failed"));
+
string name;
for (int i = 0; i < info->content_comps->n - 1; i++)
{
@@ -213,7 +223,7 @@
size_t size;
name += "/";
ccn_name_comp_get(info->content_ccnb, info->content_comps, i, (const unsigned char **)&comp, &size);
- name += comp; // this will also crash if name doesn't have \0 ending
+ name += comp;
}
// this will crash when content doesn't have \0 ending
(*f) (name, (string)pcontent);
@@ -230,7 +240,8 @@
dataClosure->p = &incomingData;
recursive_mutex::scoped_lock lock(m_mutex);
- ccn_express_interest (m_handle, pname, dataClosure, NULL);
+ if (ccn_express_interest (m_handle, pname, dataClosure, NULL) < 0)
+ BOOST_THROW_EXCEPTION(CcnxOperationException() << errmsg_info_str("express interest failed"));
ccn_charbuf_destroy (&pname);
}
@@ -243,7 +254,8 @@
ccn_name_from_uri (pname, prefix.c_str());
interestClosure->data = new InterestCallback (interestCallback); // should be removed when closure is removed
interestClosure->p = &incomingInterest;
- ccn_set_interest_filter (m_handle, pname, interestClosure);
+ if(ccn_set_interest_filter (m_handle, pname, interestClosure) < 0)
+ BOOST_THROW_EXCEPTION(CcnxOperationException() << errmsg_info_str("set interest filter failed"));
ccn_charbuf_destroy(&pname);
}
diff --git a/model/sync-ccnx-wrapper.h b/model/sync-ccnx-wrapper.h
index 84893d8..fc7afb1 100644
--- a/model/sync-ccnx-wrapper.h
+++ b/model/sync-ccnx-wrapper.h
@@ -32,6 +32,7 @@
#include <ccn/signing.h>
}
+#include <boost/exception/all.hpp>
#include <boost/thread/recursive_mutex.hpp>
#include <boost/thread/thread.hpp>
#include <boost/function.hpp>
@@ -44,6 +45,7 @@
*/
namespace Sync {
+struct CcnxOperationException : virtual boost::exception, virtual std::exception { };
/**
* \ingroup sync
* @brief A wrapper for ccnx library; clients of this code do not need to deal