Thursday, 1 December 2011

How to create virus in 20 seconds?


Classes in C++


class is an expanded concept of a data structure: instead of holding only data, it can hold both data and functions.

An object is an instantiation of a class. In terms of variables, a class would be the type, and an object would be the variable.

Classes are generally declared using the keyword class, with the following format:

class class_name {
  access_specifier_1:
    member1;
  access_specifier_2:
    member2;
  ...
  } object_names;

Where class_name is a valid identifier for the class, object_names is an optional list of names for objects of this class. The body of the declaration can contain members, that can be either data or function declarations, and optionally access specifiers.

All is very similar to the declaration on data structures, except that we can now include also functions and members, but also this new thing called access specifier. An access specifier is one of the following three keywords: privatepublic or protected. These specifiers modify the access rights that the members following them acquire:

  • private members of a class are accessible only from within other members of the same class or from their friends.
  • protected members are accessible from members of their same class and from their friends, but also from members of their derived classes.
  • Finally, public members are accessible from anywhere where the object is visible.

By default, all members of a class declared with the class keyword have private access for all its members. Therefore, any member that is declared before one other class specifier automatically has private access. For example:

1
2
3
4
5
6
class CRectangle {
    int x, y;
  public:
    void set_values (int,int);
    int area (void);
  } rect;


Declares a class (i.e., a type) called CRectangle and an object (i.e., a variable) of this class called rect. This class contains four members: two data members of type int (member x and member y) with private access (because private is the default access level) and two member functions with public access: set_values() and area(), of which for now we have only included their declaration, not their definition.

Notice the difference between the class name and the object name: In the previous example, CRectangle was the class name (i.e., the type), whereas rect was an object of typeCRectangle. It is the same relationship int and a have in the following declaration:

 
int a;


where int is the type name (the class) and a is the variable name (the object).

After the previous declarations of CRectangle and rect, we can refer within the body of the program to any of the public members of the object rect as if they were normal functions or normal variables, just by putting the object's name followed by a dot (.) and then the name of the member. All very similar to what we did with plain data structures before. For example:

1
2
rect.set_values (3,4);
myarea = rect.area(); 


The only members of rect that we cannot access from the body of our program outside the class are x and y, since they have private access and they can only be referred from within other members of that same class.

Here is the complete example of class CRectangle:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
// classes example
#include <iostream>
using namespace std;

class CRectangle {
    int x, y;
  public:
    void set_values (int,int);
    int area () {return (x*y);}
};

void CRectangle::set_values (int a, int b) {
  x = a;
  y = b;
}

int main () {
  CRectangle rect;
  rect.set_values (3,4);
  cout << "area: " << rect.area();
  return 0;
}
area: 12


The most important new thing in this code is the operator of scope (::, two colons) included in the definition of set_values(). It is used to define a member of a class from outside the class definition itself.

You may notice that the definition of the member function area() has been included directly within the definition of the CRectangle class given its extreme simplicity, whereasset_values() has only its prototype declared within the class, but its definition is outside it. In this outside definition, we must use the operator of scope (::) to specify that we are defining a function that is a member of the class CRectangle and not a regular global function.

The scope operator (::) specifies the class to which the member being declared belongs, granting exactly the same scope properties as if this function definition was directly included within the class definition. For example, in the function set_values() of the previous code, we have been able to use the variables x and y, which are private members of classCRectangle, which means they are only accessible from other members of their class.

The only difference between defining a class member function completely within its class or to include only the prototype and later its definition, is that in the first case the function will automatically be considered an inline member function by the compiler, while in the second it will be a normal (not-inline) class member function, which in fact supposes no difference in behavior.

Members x and y have private access (remember that if nothing else is said, all members of a class defined with keyword class have private access). By declaring them private we deny access to them from anywhere outside the class. This makes sense, since we have already defined a member function to set values for those members within the object: the member function set_values(). Therefore, the rest of the program does not need to have direct access to them. Perhaps in a so simple example as this, it is difficult to see any utility in protecting those two variables, but in greater projects it may be very important that values cannot be modified in an unexpected way (unexpected from the point of view of the object).

One of the greater advantages of a class is that, as any other type, we can declare several objects of it. For example, following with the previous example of class CRectangle, we could have declared the object rectb in addition to the object rect:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
// example: one class, two objects
#include <iostream>
using namespace std;

class CRectangle {
    int x, y;
  public:
    void set_values (int,int);
    int area () {return (x*y);}
};

void CRectangle::set_values (int a, int b) {
  x = a;
  y = b;
}

int main () {
  CRectangle rect, rectb;
  rect.set_values (3,4);
  rectb.set_values (5,6);
  cout << "rect area: " << rect.area() << endl;
  cout << "rectb area: " << rectb.area() << endl;
  return 0;
}
rect area: 12
rectb area: 30  


In this concrete case, the class (type of the objects) to which we are talking about is CRectangle, of which there are two instances or objects: rect and rectb. Each one of them has its own member variables and member functions.

Notice that the call to rect.area() does not give the same result as the call to rectb.area(). This is because each object of class CRectangle has its own variables x and y, as they, in some way, have also their own function members set_value() and area() that each uses its object's own variables to operate.

That is the basic concept of object-oriented programming: Data and functions are both members of the object. We no longer use sets of global variables that we pass from one function to another as parameters, but instead we handle objects that have their own data and functions embedded as members. Notice that we have not had to give any parameters in any of the calls to rect.area or rectb.area. Those member functions directly used the data members of their respective objects rect and rectb.

Constructors and destructors

Objects generally need to initialize variables or assign dynamic memory during their process of creation to become operative and to avoid returning unexpected values during their execution. For example, what would happen if in the previous example we called the member function area() before having called function set_values()? Probably we would have gotten an undetermined result since the members x and y would have never been assigned a value.

In order to avoid that, a class can include a special function called constructor, which is automatically called whenever a new object of this class is created. This constructor function must have the same name as the class, and cannot have any return type; not even void.

We are going to implement CRectangle including a constructor:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
// example: class constructor
#include <iostream>
using namespace std;

class CRectangle {
    int width, height;
  public:
    CRectangle (int,int);
    int area () {return (width*height);}
};

CRectangle::CRectangle (int a, int b) {
  width = a;
  height = b;
}

int main () {
  CRectangle rect (3,4);
  CRectangle rectb (5,6);
  cout << "rect area: " << rect.area() << endl;
  cout << "rectb area: " << rectb.area() << endl;
  return 0;
}
rect area: 12
rectb area: 30  


As you can see, the result of this example is identical to the previous one. But now we have removed the member function set_values(), and have included instead a constructor that performs a similar action: it initializes the values of width and height with the parameters that are passed to it.

Notice how these arguments are passed to the constructor at the moment at which the objects of this class are created:

1
2
CRectangle rect (3,4);
CRectangle rectb (5,6);


Constructors cannot be called explicitly as if they were regular member functions. They are only executed when a new object of that class is created.

You can also see how neither the constructor prototype declaration (within the class) nor the latter constructor definition include a return value; not even void.

The destructor fulfills the opposite functionality. It is automatically called when an object is destroyed, either because its scope of existence has finished (for example, if it was defined as a local object within a function and the function ends) or because it is an object dynamically assigned and it is released using the operator delete.

The destructor must have the same name as the class, but preceded with a tilde sign (~) and it must also return no value.

The use of destructors is especially suitable when an object assigns dynamic memory during its lifetime and at the moment of being destroyed we want to release the memory that the object was allocated.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
// example on constructors and destructors
#include <iostream>
using namespace std;

class CRectangle {
    int *width, *height;
  public:
    CRectangle (int,int);
    ~CRectangle ();
    int area () {return (*width * *height);}
};

CRectangle::CRectangle (int a, int b) {
  width = new int;
  height = new int;
  *width = a;
  *height = b;
}

CRectangle::~CRectangle () {
  delete width;
  delete height;
}

int main () {
  CRectangle rect (3,4), rectb (5,6);
  cout << "rect area: " << rect.area() << endl;
  cout << "rectb area: " << rectb.area() << endl;
  return 0;
}
rect area: 12
rectb area: 30  


Overloading Constructors

Like any other function, a constructor can also be overloaded with more than one function that have the same name but different types or number of parameters. Remember that for overloaded functions the compiler will call the one whose parameters match the arguments used in the function call. In the case of constructors, which are automatically called when an object is created, the one executed is the one that matches the arguments passed on the object declaration:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
// overloading class constructors
#include <iostream>
using namespace std;

class CRectangle {
    int width, height;
  public:
    CRectangle ();
    CRectangle (int,int);
    int area (void) {return (width*height);}
};

CRectangle::CRectangle () {
  width = 5;
  height = 5;
}

CRectangle::CRectangle (int a, int b) {
  width = a;
  height = b;
}

int main () {
  CRectangle rect (3,4);
  CRectangle rectb;
  cout << "rect area: " << rect.area() << endl;
  cout << "rectb area: " << rectb.area() << endl;
  return 0;
}
rect area: 12
rectb area: 25  


In this case, rectb was declared without any arguments, so it has been initialized with the constructor that has no parameters, which initializes both width and height with a value of 5.

Important: Notice how if we declare a new object and we want to use its default constructor (the one without parameters), we do not include parentheses ():

1
2
CRectangle rectb;   // right
CRectangle rectb(); // wrong! 


Default constructor

If you do not declare any constructors in a class definition, the compiler assumes the class to have a default constructor with no arguments. Therefore, after declaring a class like this one:

1
2
3
4
5
class CExample {
  public:
    int a,b,c;
    void multiply (int n, int m) { a=n; b=m; c=a*b; }
  };


The compiler assumes that CExample has a default constructor, so you can declare objects of this class by simply declaring them without any arguments:

 
CExample ex;


But as soon as you declare your own constructor for a class, the compiler no longer provides an implicit default constructor. So you have to declare all objects of that class according to the constructor prototypes you defined for the class:

1
2
3
4
5
6
class CExample {
  public:
    int a,b,c;
    CExample (int n, int m) { a=n; b=m; };
    void multiply () { c=a*b; };
  };


Here we have declared a constructor that takes two parameters of type int. Therefore the following object declaration would be correct:

 
CExample ex (2,3);

But,
 
CExample ex;


Would not be correct, since we have declared the class to have an explicit constructor, thus replacing the default constructor.

But the compiler not only creates a default constructor for you if you do not specify your own. It provides three special member functions in total that are implicitly declared if you do not declare your own. These are the copy constructor, the copy assignment operator, and the default destructor.

The copy constructor and the copy assignment operator copy all the data contained in another object to the data members of the current object. For CExample, the copy constructor implicitly declared by the compiler would be something similar to:

1
2
3
CExample::CExample (const CExample& rv) {
  a=rv.a;  b=rv.b;  c=rv.c;
  }


Therefore, the two following object declarations would be correct:

1
2
CExample ex (2,3);
CExample ex2 (ex);   // copy constructor (data copied from ex) 


Pointers to classes

It is perfectly valid to create pointers that point to classes. We simply have to consider that once declared, a class becomes a valid type, so we can use the class name as the type for the pointer. For example:

 
CRectangle * prect;


is a pointer to an object of class CRectangle.

As it happened with data structures, in order to refer directly to a member of an object pointed by a pointer we can use the arrow operator (->) of indirection. Here is an example with some possible combinations:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
// pointer to classes example
#include <iostream>
using namespace std;

class CRectangle {
    int width, height;
  public:
    void set_values (int, int);
    int area (void) {return (width * height);}
};

void CRectangle::set_values (int a, int b) {
  width = a;
  height = b;
}

int main () {
  CRectangle a, *b, *c;
  CRectangle * d = new CRectangle[2];
  b= new CRectangle;
  c= &a;
  a.set_values (1,2);
  b->set_values (3,4);
  d->set_values (5,6);
  d[1].set_values (7,8);
  cout << "a area: " << a.area() << endl;
  cout << "*b area: " << b->area() << endl;
  cout << "*c area: " << c->area() << endl;
  cout << "d[0] area: " << d[0].area() << endl;
  cout << "d[1] area: " << d[1].area() << endl;
  delete[] d;
  delete b;
  return 0;
}
a area: 2
*b area: 12
*c area: 2
d[0] area: 30
d[1] area: 56


Next you have a summary on how can you read some pointer and class operators (*&.->[ ]) that appear in the previous example:

expressioncan be read as
*xpointed by x
&xaddress of x
x.ymember y of object x
x->ymember y of object pointed by x
(*x).ymember y of object pointed by x (equivalent to the previous one)
x[0]first object pointed by x
x[1]second object pointed by x
x[n](n+1)th object pointed by x

Be sure that you understand the logic under all of these expressions before proceeding with the next sections. If you have doubts, read again this section and/or consult the previous sections about pointers and data structures.

Classes defined with struct and union

Classes can be defined not only with keyword class, but also with keywords struct and union.

The concepts of class and data structure are so similar that both keywords (struct and class) can be used in C++ to declare classes (i.e. structs can also have function members in C++, not only data members). The only difference between both is that members of classes declared with the keyword struct have public access by default, while members of classes declared with the keyword class have private access. For all other purposes both keywords are equivalent.

The concept of unions is different from that of classes declared with struct and class, since unions only store one data member at a time, but nevertheless they are also classes and can thus also hold function members. The default access in union classes is public.
Index
Index

Wednesday, 30 November 2011


Networking Concepts

How to setup and configure a college network?
1.      Introduction:
                              
In today’s world information technology has gripped the whole world in a single hand. Information technology has merged the computing with high speed communication link carrying data in the form of images, videos, text, audios etc. from place to place over this global village, where global village means the whole world. Networking enables multiple computer users to share their resources amongst each other. So, in this way multiple computers shares their data in networking. The first and foremost purpose of networking is to centralized information and share information from one computer to other. Moreover, hardware sharing also enables by networking.
Even the smallest businesses can take advantage of networking to share the cost of peripherals such as printers and scanners and provide access to shared data. However, the growth of wireless networks and the increasing use of virtual private networks, which allow a user to access a business' network via the internet, have not only resulted in a wider choice of solutions for the business owner, but also a number of additional business benefits.
This report will explain networking between 3 departments having multiple computers and 1 server.
Following are main devices in the network:
·      Server Computer
·      Marketing department (3 PC’s)
·      Management (2 PC’s)
·      ESTATE (2 PC’s)
In our network printer should be shared only by Marketing and management department.
1.1.   Benefits of using networks

With the growth of business, good communication between employees is essential. You can improve efficiency by sharing information such as common files, databases and business application software over a computer network.
With improvements in network capacity and the ability to work wirelessly or remotely, successful businesses should regularly re-evaluate their needs and their IT infrastructure. You can improve communication by connecting your computers and working on standardized systems, so that:
·     Staff, suppliers and customers is able to share information and get in touch more easily
·     sharing information can make your business more efficient - e.g. networked access to a common database can avoid the same data being keyed multiple times, which would waste time and could result in errors
·     Staff are better equipped to deal with queries and deliver a better standard of service as a result of sharing customer data
You can reduce costs and improve efficiency by storing information in one centralized database and streamlining working practices, so that:
§  staff can deal with more customers at the same time by accessing customer and product databases
§  network administration can be centralized, less IT support is required
§  costs are cut through sharing of peripherals such as printers, scanners, external discs, tape drives and internet access
2.  Requirements analysis:
         
As we are supposed to create a network between three departments, where marketing has 3 computers, college management holds 2 computers and likewise, estates hold 2 computers. In order to share printer between management and marketing department we must use firewall to apply restriction protocols in our network. A server will work as main computer and it will handle all services like FTP, software sharing, printer sharing, and any other hardware sharing. We have following basic requirements in order to design an efficient network.

Computers:
We need seven personal computers for three departments. These computers will be used by different departments in our network.
Operating system:
An operating system is a set of programs running in the background of computer providing an environment in which other programs can run and user can work easily and efficiently. Here for our network I thought to use windows XP for networking between three departments (management, marketing, estate) because this is one of the best operating system. However, the most recent version of windows i.e. windows 7 is also capable of developing networking, but in our network I would like to use windows XP on all local computers and server.
Network Interface card:
Each computer which we are interested to connect to the network must contain a network interface card (NIC). Sometimes NIC is called LAN card.
Ethernet cables:
All the computers in network require Ethernet cables to enable a wire connection for resource sharing. For this purpose Ethernet cables should be there in order to implement the network.
Network Routers:
We also require a network router for printer sharing or any network compatible hardware. Basically, network router enables communication between two computers on the network.
Networking Software:
Networking software is used to create networking between computers. So we also need networking software for creation of network between three departments. Most operating systems contain the soft wares and drivers to enable networking.
Examples of network software:
Utilities, communication, VNC, team viewer.
Wireless network:
If we are interested to provide wireless connection to computers in network having wireless card we need a wireless router to accomplish this task.
Printers:
We need a printer in the network that would be shared between marketing and management departments for printing documents.
Switch:
We also need network switches to divide server access and access to hardware between marketing, management and estate. So in order to accomplish these tasks we must have at least four switches for joining three departments at a single place.
Firewall:
We also require a firewall which is a set of related programs located at a network gateway for restricting unauthorized and illegal access to user files and hardware sharing. Moreover, it will enable a secure and compiled data between three departments in our network.
3.  Development: and design of network:

In order to develop and design our network we must ensure the basics of networking.
So that in this way we’ll enable ourselves to design an efficient and secure network. Firstly, the basic network connection between two computers can be explained as:
                                             
                   Networking between two PC’s:
We can connect two basic computers by using Ethernet cables and just by using both pc. In this way both these personal computers may share their software resources.
Before carrying on our project we must have suitable knowledge about different types of network.
3.1.      What is a network?

A network is a way to produce a linkage between personal computers, so that they may share their own resources like software sharing and hardware sharing.
Main networks:
·     LAN (local area network)
·     WAN (wide area network)
·    MAN (metropolitan area network)
LAN:
A home based network between some computers in the same building, office of institute is referred to as Local area network.
MAN:
A network that is spreader around a city is called metropolitan area network. For example, the network between different branches of a college.

WAN:
A network between geographically speeded computers in called wide area network. For example Internet.
Here, I would like to show a basic network between four computers as shown in below diagram. This type of networking is called peer to peer networking, where all these four computers are connected by a hub. They may share their resources and programs amongst each others.
Available at [Reference: http://techsoup.org][18/05/2010]

I would also like to review client server networking before developing my network.
In client server networking we have multiple clients connected to a single server.
All clients have permission to access data on the single server. This server produces software and file sharing between three clients computers in above little network.
After studying peer to peer and client server networks now we are capable to design our own network where marketing department, management department and estate department should be connected to a single server for sharing their resources and information.
3.2.     Review of our own network:

We have chooses windows XP operating system for networking between management, marketing and estate department. XP will enable an ease interconnection between different computers and a server. So we must make sure that window XP operating system is installed on all computers of three departments. After observing different network diagrams and types of networks I formed a network diagram for networking between management, marketing and estate. Network Diagram is shown in diagram_network:
diagram_network
3.3.      Explanation of networking diagram:

1.   Components of network:

Internet
Router
Server
7 personal computers with XP operating system
Switches
Ethernet cables  (depending on requirements)
Printer
Firewall





2.     Departments:
2.1.        Marketing having 3 computers
2.2.        Estates having 2 computers
2.3.        Management having 2 computers
3.     Restriction in our network

Only management and marketing department has authority to access printer for printing documents. Estate department doesn’t have authority to print any file on this network. However, all personal computers in three departments are authorized to access all files available or shared on the server. Moreover, the restrictions may be modified if required by utilizing networking soft wares.  Only network manager has authority to restrict the traffic of data/ file sharing/ hardware sharing. In this way normal user enables him to access shared files if he is not restricted by network administrator. The server computer provides accessibility to all departments to put file on it and share it with a selected department. For example, if marketing department wants to share the pay slip of employees with management department, it will just upload that slip on server and share it with management department. The estates department will be unable to access this pay slip because the administrator has just given this accessibility to management department.
3.4.      Brief description of network diagram:

First of all in our network diagram we have internet connection that enables internet access to all departments. Internet (ADSL) is connected to router where router is working to make sure that internet is accessible to all users of three departments. Then firewall (a set of different programs to put restrictions on the network) will purify the data on the network. Here, network administrator has authority to change the accessibility of files on the network. The printer sharing is restricted by manager means only marketing and management departments are capable to print their files via shared printer on the network. However, in some situations if network administrator is interested to provide printer sharing to estate then he can easily provide printer sharing to estate’s department. Then main server computer providing access to all user files if they are shared. The main server enables files sharing, hardware sharing and it is also working as database server as well. We could also use print server and FTP server in our network but it will produce an increase in network cost. So, we will prefer to use only single server performing all these tasks in our network. Then server is connected to a hub or switch that is distributing the internet connection between management, marketing and estate.  This switch is further connected to three more switches that are distinctly connected to management, marketing and estate department via Ethernet cables. The printer is connected to central hub/switch through which the management and marketing department access printer and print their files.  Firewall is allowing management and marketing departments to share printer and print their files via network.
4.  Network Configuration and set up:

In order to setup our network I would like to create a client server networking model in which a centralized computer is used as a server. This centralized computer contains files, database, docs, spreadsheets, web pages and resources like hard diver, printer, fax modem, CD/DVD ROM and others. All clients computer has authority to share those files etc. over the network but only management and marketing department has authority to share printer. All clients’ computers in three departments are connected to the centralized server computer.
First of all we’ll prepare server computer. For this purpose we’ll install windows XP server on server computer and create a domain.
4.1.     Domain creation:

In order to create domain we’ll run “DCPROMO” command after successfully installing the server. After running “DCPROMO” command it will ask for domain name. All client computers will use this domain name for becoming part of this domain. This command has installed active directory on server, DNS and other required things. A step by step wizard ran all remain tasks are accomplished. During this procedure the network cable is plugged in the LAN card of the server when we ran DCPROMO.exe command.
After properly creating active directory on the server we did create network users on the server computer and also name/labeled the network resource like printer.
After successfully installing the server we are supposed to install windows XP on all clients. In this way all clients will enable to become a part of network.
4.2.    Configuration steps:

1.     Choose a unique name for each client such as PC A, B, C etc.
2.     Choose unique IP address for each computer for each computer and relevant.
3.     Use the same domain name for all client PCs.
Network system can do all these administrative tasks on clients and server computers. Any shared resource on server or client can be easily accessed by MY Network Place in windows XP platform.
a.   IP address assigning:

IP address:
An Internet Protocol (IP) address is a numerical label that is assigned to devices participating in a computer network, which uses the Internet Protocol for communication between its nodes. An IP address serves two principal functions: host or network interface identification and location addressing
In our network:
For giving the IP address you will have to right click on the My Network places>properties>Local Area Connection>Properties>Internet Protocols (TCP/IP)>Properties and then give the IP address and subnet mask of the same range and class for all the computers in the network.
For assigning IP address we decided to use class C for all client computers in the network. For server we used class A IP address as shown in network diagram.

b.  Installation of Network software:

After creating our network we may need to upgrade software or we may also require sharing software among different computer users. But we must make sure that this software is properly licensed.
Following are few steps to install software on a network and use it between selected group of users or departments:
1.     Power on each computer within the network on which you would like to install the software.
2.     Log on to each computer with the administrator username and password. If the network administrator has not established a username and password for the network, you will not be prompted for a username and password.
3.     Check each computer to ensure that it meets the minimum system requirements for the software download (for example, the correct operating system, sufficient disk space and correct processor).
4.     Insert the software CD into the CD ROM drive of each computer on which you want to install the software. Enter the software license number or product key code. This will be located in your software package.
5.     Run the software installation wizard. Some software programs may require configuration after it has been installed.
In this way we will install software over a network. This software can be shared between any or all three departments in our network. Basically, this process has enabled us to share software between any or two departments in our network. Network manager has authority to change the sharing capability of sharing this software between selected departments.

c.    Installation of network printer:

As in this assignment of networking we are restricted to share printer only between management and marketing department. But this thing will allow us to use only 1 printer instead of using numerous printers. For printer installation we have connected it to the centralized server computer that will control printer sharing.
First of all we need to install printer software and drivers on all PCs of management and marketing department. After successfully installing printer software and drivers on management and marketing’s PCs and server as well. Now at this place our network diagram will purify and the most recent and efficient diagram of network will be formed as.

Now, we have connected printer with server computer which is centralized. Now management and marketing departments can access to printer.
                                                 i.    Finding a printer on the network:

Following are few steps to find printer on network in windows XP.
To install the printer using an IP address, go to Start>Control Panel>Printers and Faxes and then click the Add Printer icon. Next, click Create a new port, then select Standard TCP/IP Port from the drop-down menu. You will then be asked to enter an IP address. Enter the IP address of the print server and click next. You will be asked to select the printer manufacturer and the model from the list. If you do not see your printer listed, insert the disk that came with the printer and click Have Disk.
If you do not know the IP address of the printer, you can sometime select Browse for printer in the beginning of the process. If the networked printer is attached to another computer is being shared, you will need to enter the name of the computer followed by the share name of the printer. For example: \\computername\printername.
In our network we assign 192.168.0.8 IP address to our printer. By using this IP address management and marketing departments are capable of printing their source documents.
4.  Network management:

5.  GENERAL RESPONSIBILITIES

Network manager manages the enterprise voice and data networks for Carroll County Government.
ESSENTIAL TASKS include the following; other duties may be assigned.
1. Perform supervisory responsibilities in accordance with the current Carroll County
Personnel Ordinance, County policies and applicable laws
2. Assign duties and examine work for exactness, neatness, and conformance to policies and
Procedures
3. Manage local and wide-area voice and data networks by providing access to network
Resources, maintaining equipment, and monitoring network performance
4. Interpret needs and oversee planning, installation, setup, support and documentation of
Network systems
5. Evaluate and recommend server hardware and software components and upgrades as
Required
6. Install, upgrade and configure client accounts, network printing, directory structures,
Rights, security and software on file servers
7. Respond to the needs and questions of clients concerning their access to resources on the
Network
8. Responsible for backup and disaster recovery measures
9. Maintain current knowledge of software and hardware methods, trends and techniques
10. Perform related duties as to specific assignments
11. Provide service to customers by answering questions, providing information, making
Referrals, and assuring appropriate follow-through and/or resolution
12. Communicate with managers, supervisors, co-workers, citizens, and others, maintains
Confidentiality; and represents the County

6.   Rights and responsibilities of network manager:

6.1.   Network manager:
A network manager is a person who is responsible for consistency and progress of network. He must make sure that network is working properly and all clients are accessing their files on server easily.
As a network manager, yours is a role of two halves. You’ll be responsible for installing and maintaining your company's computer networks, and also to train staff to provide first rate technical support.
If there are problems with the system, it’ll be down to you to have a recovery plan to minimize any disruption to the business. As most organizations are becoming increasingly reliant on technology, this makes your role particularly vital to the smooth running of the business. Depending on the size of the organization you may have more than one type of network to manage.


6.2.    Required skills for network managers:
Being a network manager is a varied role as it combines both strong IT and leadership skills. Employers will expect you to have the following:

• 
In-depth knowledge of all networks, especially those used by the company
• 
Interpersonal skills and experience in presenting
• Problem solving and project management experience
• Negotiation skills
• Team working skills
• Understanding of business
• Financial planning and budgeting experience
6.3.          Entry requirements
Training to become a network manager can start straight from school, provided you have good GCSE grades in English, Math’s, IT and Science. Although a degree or BTEC HND in a relevant computer course can give you an advantage. To enter the profession at network manager level you'll need a proven track record and relevant experience such as a previous role as a network engineer, IT support technician or IT manager.
6.4. Hours and environment

As a Network Manager, you’ll often work 37 to 40 hours a week in and office or between office sites. When a new system is being installed it may be necessary to work out of hours or at the weekend to minimize disruption to the office.  
6.5. Basic responsibilities of network managers:
The administrator's basic responsibilities include:
                 security, including password monitoring
                 designing and implementing back-up procedures - see our guide on keeping your systems and data secure
                 disaster recovery planning

One or more individuals are responsible for every IP net or subnet which is connected to the Internet.  Their names, phone numbers and postal addresses MUST be supplied to the Internet NIC (or to the local or regional transit network's NIC) prior to the network's initial connection to the Internet, and updates and corrections MUST be provided in a timely manner for as long as the net remains connected.
As the network grows the network administrator will need further training. At this point you will need their expertise to also cover the installation, configuration and maintenance of PCs, networking equipment and network operating systems.
It is a good idea to define exactly what type of emergency support and after-sales services your technology providers should supply, as they can be an important point of contact for any queries or problems you may have. If they cannot provide these services, consider another supplier who can. See our guide on computer hardware: the basics.
You need to maintain your network. You'll need to monitor software compatibility. This doesn't necessarily mean automatically getting the latest release available. Compatibility needs to extend across the network, so an upgrade strategy must be carefully planned and budgeted.
Make rules for file naming to ensure that changes take place to the right files at the right time. Multiple file copies will be created as employees download central files to work on whilst off-site and upload them later. Naming rules prevent overwriting of any changes made to the original files.
Network security issues
The increase in businesses connecting their systems and using the internet has its drawbacks. When all computers are networked, one user's problems may affect everyone. You should consider the greater potential for data loss, security breaches and viruses when creating a network.
It is important to ensure data security through regular housekeeping such as backing up files, password routines and system logs. It is important to remove access from employees who leave; otherwise they may still be able to access customer records.
As your data will be stored in one location on the server, physical security is very important. See our guide on keeping your systems and data secure.
You should enhance your system security to protect your business from potential virus attacks and hacking. This should include anti-virus software and a firewall or software barrier. See our guide on IT security: the basics.
Keep this up to date and download relevant patches - updates to software that fix security threats - because new viruses are frequently released. If you are affected by a virus your employees could lose data and have difficulties using their computers, and your business could come to a standstill.
If your staff needs to access the network while off-site, consider a virtual private network. This creates a secure link and protects information sent and received.
If you opt for a wireless networking solution then be aware that they can be insecure unless you take appropriate precautions. Typical threats include people being able to eavesdrop on your business activities or a hacker using a wireless connection to gain access to your key business systems. See our guide on securing your wireless systems.
Irrespective of the technology solution you select, you should seek expert advice when your system is installed - from your internet service provider, system provider, installer or an adviser. As when seeking any type of professional guidance, you should find out whether any adviser is familiar with businesses of your size or in your sector, or follow personal recommendations. Consult your local Chamber of Commerce or Business Link.
A Windows-based computer that is configured to use DHCP can automatically assign itself an Internet Protocol (IP) address if a DHCP server is not available. For example, this could occur on a network without a DHCP server or on a network if a DHCP server is temporarily down for maintenance.

The Internet Assigned Numbers Authority (IANA) has reserved 169.254.0.0-169.254.255.255 for Automatic Private IP Addressing. As a result, APIPA provides an address that is guaranteed not to conflict with routable addresses.

After the network adapter has been assigned an IP address, the computer can use TCP/IP to communicate with any other computer that is connected to the same LAN and that is also configured for APIPA or has the IP address manually set to the 169.254.x.y (where x.y is the client’s unique identifier) address range with a subnet mask of 255.255.0.0. Note that the computer cannot communicate with computers on other subnets, or with computers that do not use automatic private IP addressing. Automatic private IP addressing is enabled by default.

You may want to disable it in any of the following cases:
- Your network uses routers.

- Your network is connected to the Internet without a NAT or proxy server.

7.   Rights and responsibilities of Network Users:

7.1.     User rights:

While the Network monitors electronic usage as part of its normal network operating procedures, the NA (network administrator) does not routinely inspect or monitor users’ computer hardware or files, email, and/or telephone message system, nor disclose information created or stored in such media without the user’s consent. The NA (network administrator) shall attempt to notify users before accessing computer hardware and files or prior to suspending service. In the event that the District acts without user consent, under its District Rights specified above, the NA shall do so with the least perusal of contents and the least action necessary to resolve the immediate situation. When NA accesses files without user consent, it shall notify the user as soon as possible of its access and provide the reason for its action.
In our network all the client computers in management and marketing department has right to access printer they can print their files via printer simultaneously. Similarly, all client computers has right to get information available on the server, they can share files by centralizing them on server.

7.2.    User responsibilities:

In our network the server computer allows all clients in three departments to share their resources. So, all users of client computer should be very much responsible on the network. The users must respect the rights of other users of the network e.g. management department. Likewise, the open access to internet for all client users determines that the users should utilize this access only for office work only. If a file is uploaded only for management department by marketing department but it is shared between all departments. Then the users of estate department should not delete or modify these files, because it is their responsibility to respect rights of others computer users. All users should be aware of their rights and responsibilities on the network.

8.   Print queue management:

Print queue management is really very essential in order to make best use of network. As we are only allowed to share printer between management and marketing departments. This task can be accomplished by using print server software on the server. This software can perform all jobs related to print queuing.  After configuring and installing this software on server, management and marketing department we are capable to configure various print queues. So, only management and marketing departments will get their prints via printer. But if we provide precedence to marketing department then the files of marketing department will be printed first. However, we have used only FIFO (first in first out) structure same like stacks. It means which department will click to print a file; its files will be printed first then others.

9.   Conclusion:
In conclusion of this report I would like to overview my network configuration and setup. As networking is one of the best ways to share all kinds of information amongst multiple computers. We just need to centralize this information on a server, and then all clients will be capable of accessing it. So, the users of different departments like management and marketing don’t need to type the same files for the same users separately. We just need to type those files once and share them on server. For example, if marketing and management department require the fee information a student. They just have to access server where the student database is centralized. In this way networking provides us a lot of pros such as time saving, efforts saving, ease and instant access to information. Moreover, networking also reduces the cost of system in an organization. In our network model we are using only single printer which is shared between management and marketing departments. It means that 2 users of management and 3 users of marketing department are printing their files via single printer on the network. However, without network we would require five separate printers for all 5 users in two departments.
The network manager and network users should be very responsible on the network. The network manager has authority to change privileges of server access for a selected group of users. In this way we designed an efficient network model where server computer is centralized and printer is shared between only management and marketing department.
Online references:
Different network diagrams
ü [http://images.google.com][viewed almost daily]
ü [www.google.com][visited daily for browsing about networks]
Roshan, P. & Leary, J. (2010) Wireless LAN Fundamentals
Sebastopol, CA: Cisco Press
ü [available at: http://proquest.safaribooksonline.com/1587050773] [Viewed on 14/05/2010].
Configuration of LAN networks
ü [http://www.networktutorials.info/about_us.html] [Viewed on 14/05/2010].
Printer queuing handling in the network
ü [http://www.networkprinting.info/] [Viewed on 15/05/2010].
LAN models and routers in network
Setting IP addresses and IP routing.
ü [http://ultralight.caltech.edu/web-site/ultralight/workgroups/network/netconfig.html][Viewed on 17/05/2010].
Introduction to windows peer to peer networking
ü [technet.microsoft.com/en-us/library/bb457079.aspx][viewed on 17/05/2010]
Networking in xp, introduction at Microsoft
ü [www.microsoft.com/windowsxp/.../networking/.../default.mspx][viewed on 18/05/2010]
Linux networking setup and routing in the network
ü [http://www.comptechdoc.org/os/linux/usersguide/linux_ugbasicnet.html][Viewed on 18/05/2010].
Petri.co.il by Daniel Petri is one of the most comprehensive IT and certification related web sites
International case studies, LAN switching
ü [www.cisco.com/en/US/.../internetworking/.../cs010.html] [viewed on 18/05/2010]
Wireless LANs
ü [learningnetwork.cisco.com/.../wireless_lan][viewed on 21/05/2010]
The End