blob: 839988ca9dd42b744e4af5b9ebd6066802fdf33a [file] [log] [blame]
Yingdi Yu53b8a9c2013-10-14 09:36:31 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil -*- */
2/*
3 * Copyright (c) 2013, Regents of the University of California
4 * Yingdi Yu
5 *
6 * BSD license, See the LICENSE file for more information
7 *
8 * Author: Yingdi Yu <yingdi@cs.ucla.edu>
9 */
10
11#include "contact-item.h"
12#include "exception.h"
13
14#include <ndn.cxx/fields/signature-sha256-with-rsa.h>
15
Yingdi Yu79c25a22013-10-21 13:38:38 -070016#include "logging.h"
17
Yingdi Yu53b8a9c2013-10-14 09:36:31 -070018using namespace std;
19using namespace ndn;
20using namespace ndn::security;
21
Yingdi Yu79c25a22013-10-21 13:38:38 -070022INIT_LOGGER("ContactItem");
23
Yingdi Yu53b8a9c2013-10-14 09:36:31 -070024ContactItem::ContactItem(const EndorseCertificate& selfEndorseCertificate,
Yingdi Yu813d4e92013-11-03 16:22:05 -080025 bool isIntroducer,
Yingdi Yu53b8a9c2013-10-14 09:36:31 -070026 const string& alias)
27 : m_selfEndorseCertificate(selfEndorseCertificate)
Yingdi Yu813d4e92013-11-03 16:22:05 -080028 , m_isIntroducer(isIntroducer)
Yingdi Yu53b8a9c2013-10-14 09:36:31 -070029{
30 Name endorsedkeyName = selfEndorseCertificate.getPublicKeyName();
Yingdi Yu8dacdf22013-11-05 23:06:43 -080031 // Ptr<const signature::Sha256WithRsa> endorseSig = boost::dynamic_pointer_cast<const signature::Sha256WithRsa>(selfEndorseCertificate.getSignature());
32 // const Name& signingKeyName = endorseSig->getKeyLocator().getKeyName();
Yingdi Yu79c25a22013-10-21 13:38:38 -070033
Yingdi Yu8dacdf22013-11-05 23:06:43 -080034 // int i = 0;
35 // int j = -1;
36 // string keyString("KEY");
37 // string idString("ID-CERT");
38 // for(; i < signingKeyName.size(); i++)
39 // {
40 // if(keyString == signingKeyName.get(i).toUri())
41 // j = i;
42 // if(idString == signingKeyName.get(i).toUri())
43 // break;
44 // }
Yingdi Yu53b8a9c2013-10-14 09:36:31 -070045
Yingdi Yu8dacdf22013-11-05 23:06:43 -080046 // if(i >= signingKeyName.size() || j < 0)
47 // throw LnException("Wrong name!");
Yingdi Yu79c25a22013-10-21 13:38:38 -070048
Yingdi Yu8dacdf22013-11-05 23:06:43 -080049 // Name subName = signingKeyName.getSubName(0, j);
50 // subName.append(signingKeyName.getSubName(j+1, i-j-1));
Yingdi Yu79c25a22013-10-21 13:38:38 -070051
52
53
Yingdi Yu8dacdf22013-11-05 23:06:43 -080054 // // _LOG_DEBUG("endorsedkeyName " << endorsedkeyName.toUri());
55 // // _LOG_DEBUG("subKeyName " << subName.toUri());
Yingdi Yu79c25a22013-10-21 13:38:38 -070056
Yingdi Yu8dacdf22013-11-05 23:06:43 -080057 // if(endorsedkeyName != subName)
58 // throw LnException("not a self-claimed");
Yingdi Yu53b8a9c2013-10-14 09:36:31 -070059
60 m_namespace = endorsedkeyName.getSubName(0, endorsedkeyName.size() - 1);
61 m_alias = alias.empty() ? m_namespace.toUri() : alias;
62
63 Ptr<ProfileData> profileData = selfEndorseCertificate.getProfileData();
64 Ptr<const Blob> nameBlob = profileData->getProfile().getProfileEntry("name");
65 m_name = string(nameBlob->buf(), nameBlob->size());
66 Ptr<const Blob> institutionBlob = profileData->getProfile().getProfileEntry("institution");
67 m_institution = string(institutionBlob->buf(), institutionBlob->size());
68}
69
Yingdi Yua50c3252013-11-03 15:05:26 -080070ContactItem::ContactItem(const ContactItem& contactItem)
71 : m_selfEndorseCertificate(contactItem.m_selfEndorseCertificate)
72 , m_namespace(contactItem.m_namespace)
73 , m_alias(contactItem.m_alias)
74 , m_name(contactItem.m_name)
75 , m_institution(contactItem.m_institution)
Yingdi Yu813d4e92013-11-03 16:22:05 -080076 , m_isIntroducer(contactItem.m_isIntroducer)
77 , m_trustScope(contactItem.m_trustScope)
78 , m_trustScopeName(contactItem.m_trustScopeName)
Yingdi Yua50c3252013-11-03 15:05:26 -080079{}
80
Yingdi Yu813d4e92013-11-03 16:22:05 -080081bool
82ContactItem::canBeTrustedFor(const Name& name)
83{
84 vector<Ptr<Regex> >::iterator it = m_trustScope.begin();
85
86 for(; it != m_trustScope.end(); it++)
87 if((*it)->match(name))
88 return true;
89 return false;
90}