TelnetServerTraffic

Package: inet.tutorials.queueing

TelnetServerTraffic

compound module

(no description)

cloner : PacketCloner

Connects one packet producer to one packet consumer.

Source:
cloner: PacketCloner {
    parameters:
        @display("p=300,225");
} responseProvider : like IPassivePacketSource

PassivePacketSource: A passive packet source which can be pulled for packets from the connected packet collector.

IPassivePacketSource: Interface for passive packet source modules.

Source:
responseProvider: <default("PassivePacketSource")> like IPassivePacketSource {
    parameters:
        @display("p=100,100");
} responseServer : like IPacketServer

TokenBasedServer: Repeatedly pulls packets from the connected packet provider and it pushes them into the connected...

IPacketServer: Interface for packet server modules.

Source:
responseServer: <default("TokenBasedServer")> like IPacketServer {
    parameters:
        @display("p=100,225");
} multiplexer : PacketMultiplexer

Connects multiple packet producers to one packet consumer.

Source:
multiplexer: PacketMultiplexer {
    parameters:
        @display("p=200,350");
} classifier : like IPacketClassifier

PacketClassifier: Connects one packet producer to multiple packet consumers.

IPacketClassifier: Interface for packet classifier modules.

Source:
classifier: <default("PacketClassifier")> like IPacketClassifier {
    parameters:
        classifierClass = default("inet::queueing::PacketCharacterOrEnterClassifier");
        @display("p=500,225");
} characterConsumer : like IPassivePacketSink

PassivePacketSink: A passive packet sink which is pushed with packets by the connected packet producer.

IPassivePacketSink: Interface for passive packet sink modules.

Source:
characterConsumer: <default("PassivePacketSink")> like IPassivePacketSink {
    parameters:
        @display("p=400,350");
} enterTokenGenerator : PacketBasedTokenGenerator

Generates tokens into the configured ~TokenBasedServer for each consumed packet.

Source:
enterTokenGenerator: PacketBasedTokenGenerator {
    parameters:
        storageModule = default("^.responseServer");
        @display("p=600,350");
}

Usage diagram

The following diagram shows usage relationships between types. Unresolved types are missing from the diagram.

Used in

Name Type Description
TelnetTutorialStep network (no description)

Properties

Name Value Description
display i=block/app

Gates

Name Direction Size Description
in input
out output

Unassigned submodule parameters

Name Type Default value Description
cloner.displayStringTextFormat string "processed %p pk (%l)"

Determines the text that is written on top of the submodule, supports displaying pars, watches, and module-specific information

multiplexer.displayStringTextFormat string "passed %p pk (%l)"

Determines the text that is written on top of the submodule, supports displaying pars, watches, and module-specific information

multiplexer.forwardServiceRegistration bool true
multiplexer.forwardProtocolRegistration bool true
enterTokenGenerator.displayStringTextFormat string "processed %p pk (%l)\ngenerated %t tk\nto %s"

Determines the text that is written on top of the submodule, supports displaying pars, watches, and module-specific information

enterTokenGenerator.storageModule string "^.responseServer"

Module path of the token storage where the tokens are generated via C++ method call

enterTokenGenerator.numTokensPerPacket double 1

Number of tokens per consumed packet

enterTokenGenerator.numTokensPerBit double 0

Number of tokens per consumed bit

Source code

module TelnetServerTraffic
{
    parameters:
        @display("i=block/app");
    gates:
        input in;
        output out;
    submodules:
        cloner: PacketCloner {
            parameters:
                @display("p=300,225");
        }
        responseProvider: <default("PassivePacketSource")> like IPassivePacketSource {
            parameters:
                @display("p=100,100");
        }
        responseServer: <default("TokenBasedServer")> like IPacketServer {
            parameters:
                @display("p=100,225");
        }
        multiplexer: PacketMultiplexer {
            parameters:
                @display("p=200,350");
        }
        classifier: <default("PacketClassifier")> like IPacketClassifier {
            parameters:
                classifierClass = default("inet::queueing::PacketCharacterOrEnterClassifier");
                @display("p=500,225");
        }
        characterConsumer: <default("PassivePacketSink")> like IPassivePacketSink {
            parameters:
                @display("p=400,350");
        }
        enterTokenGenerator: PacketBasedTokenGenerator {
            parameters:
                storageModule = default("^.responseServer");
                @display("p=600,350");
        }
    connections:
        in --> { @display("m=s"); } --> cloner.in;
        cloner.out++ --> classifier.in;
        cloner.out++ --> multiplexer.in++;
        responseProvider.out --> responseServer.in;
        responseServer.out --> multiplexer.in++;
        classifier.out++ --> characterConsumer.in;
        classifier.out++ --> enterTokenGenerator.in;
        multiplexer.out --> { @display("m=s"); } --> out;
}

//-------------------------------------------------


File: tutorials/queueing/QueueingTutorial.ned