blob: f81548f6f21a141dce3c916797f8781413461190 [file] [log] [blame]
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -08001/* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
2/*
3 * Copyright (c) 2011-2012 University of California, Los Angeles
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation;
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 *
18 * Author: Alexander Afanasyev <alexander.afanasyev@ucla.edu>
19 */
20
21// dumb-requester.cc
22
Alexander Afanasyev0c395372014-12-20 15:54:02 -080023#include "dumb-requester.hpp"
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080024#include "ns3/ptr.h"
25#include "ns3/log.h"
26#include "ns3/simulator.h"
27#include "ns3/packet.h"
28#include "ns3/random-variable.h"
29#include "ns3/string.h"
30
Alexander Afanasyev0c395372014-12-20 15:54:02 -080031#include "ns3/ndn-app-face.hpp"
32#include "ns3/ndn-interest.hpp"
33#include "ns3/ndn-data.hpp"
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080034
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080035NS_LOG_COMPONENT_DEFINE("DumbRequester");
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080036
37namespace ns3 {
38
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080039NS_OBJECT_ENSURE_REGISTERED(DumbRequester);
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080040
41// register NS-3 type
42TypeId
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080043DumbRequester::GetTypeId()
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080044{
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080045 static TypeId tid =
46 TypeId("DumbRequester")
47 .SetParent<ndn::App>()
48 .AddConstructor<DumbRequester>()
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080049
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080050 .AddAttribute("Prefix", "Requested name", StringValue("/dumb-interest"),
51 ndn::MakeNameAccessor(&DumbRequester::m_name), ndn::MakeNameChecker());
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080052 return tid;
53}
54
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080055DumbRequester::DumbRequester()
56 : m_isRunning(false)
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080057{
58}
59
60// Processing upon start of the application
61void
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080062DumbRequester::StartApplication()
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080063{
64 // initialize ndn::App
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080065 ndn::App::StartApplication();
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080066
67 m_isRunning = true;
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080068 Simulator::ScheduleNow(&DumbRequester::SendInterest, this);
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080069}
70
71// Processing when application is stopped
72void
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080073DumbRequester::StopApplication()
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080074{
75 m_isRunning = false;
76 // cleanup ndn::App
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080077 ndn::App::StopApplication();
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080078}
79
80void
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080081DumbRequester::SendInterest()
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080082{
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080083 if (!m_isRunning)
84 return;
85
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080086 /////////////////////////////////////
87 // Sending one Interest packet out //
88 /////////////////////////////////////
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080089
90 Ptr<ndn::Name> prefix = Create<ndn::Name>(m_name); // another way to create name
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080091
Alexander Afanasyeveae83ee2013-03-15 15:01:10 -070092 // Create and configure ndn::Interest
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080093 Ptr<ndn::Interest> interest = Create<ndn::Interest>();
94 UniformVariable rand(0, std::numeric_limits<uint32_t>::max());
95 interest->SetNonce(rand.GetValue());
96 interest->SetName(prefix);
97 interest->SetInterestLifetime(Seconds(1.0));
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -080098
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080099 NS_LOG_DEBUG("Sending Interest packet for " << *prefix);
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -0800100
101 // Call trace (for logging purposes)
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800102 m_transmittedInterests(interest, this, m_face);
Alexander Afanasyevfaa01f92013-07-10 18:34:31 -0700103
104 // Forward packet to lower (network) layer
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800105 m_face->ReceiveInterest(interest);
Alexander Afanasyevfaa01f92013-07-10 18:34:31 -0700106
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800107 Simulator::Schedule(Seconds(1.0), &DumbRequester::SendInterest, this);
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -0800108}
109
110void
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800111DumbRequester::OnData(Ptr<const ndn::Data> contentObject)
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -0800112{
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800113 NS_LOG_DEBUG("Receiving Data packet for " << contentObject->GetName());
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -0800114}
115
Alexander Afanasyevc3cc0b32012-12-12 18:41:20 -0800116} // namespace ns3