Wednesday, June 5, 2019
Ipsec implementation
Ipsec carrying outThere atomic number 18 many methods to IP protection department. In the Microsofts Windows 2003 the server version, on that point are many such(prenominal) techniques and tweaks which are useful to help provide a control base to the body. The operating system is actu tout ensembley good in protecting the system from attacks which may be active attacks or in some(prenominal) cases passive attacks. The procedures for IPSec are placed properly into the system which helps it tackle such attacks. This is possible by providing a ripe packet imbue for packet trans style and also using cryptography. This technology is precise in high use for communication types like host to host, router to router, entre to gate substance, site to site and also in realistic private interlockings. Some other places for successful implementation are secure servers. The IPSec comes as a staple fiber Group Policy controlled by Dos Prompt commands and it also has user interface w ith custom programs inst entirelyed.The implementation of IPSec involves these stepsOverview of IPSec Deploymentdetermine Our earnings communications protocol credential targetsPreparing a Internet Protocol security system PolicyImplementation of the designed policiesOverview of IPSec DeploymentThere are many techniques such as usage of cryptography and hallmark software to secure the communication in a ne 2rk. The connector may be between two parties or between a group of users. Security is to thread sure that the communication is non broken, the communication is not intervened and the data is not altered. The Internet Protocol Security has some features which help running a secure transmission. IPSec has represent procedures which help achieve these ends.Today on that point are many companies and it is getting harder day by day to ensure the shelter of such humungous intercommunicates with a heavy workload on the networks. It is also very hard to track any attacks on the network in millions and millions of request. Using firewalls to protect a network did work for some days but it has proved to be im hardheaded as it has no proper rules to detect intrusions or attacks. The advent of IPSec is a leap in computer and network security. This protocol has a wide spectrum of features which are strong enough to contain such high volume of network requests and also handle intrusions.The Internet Protocol for Security is not a versatile detection protocol. It is capable of managing most of the policies to grant or reject, impede and accomplish the merchandise in a network. This kitty also be permitted to a special set of addresses or in some cases protocol and also a different constitution to each port. It is recommended that we use ICF (Internet Connection Firewall) when we are in ingest of a firewall which is capable of providing a network interface for very bragging(a) networks. This is because the internet protocol for Security has a very stri ct and a very stern strategy which is based on static filtering based on IP addresses. But this is it is totally different in the case of the Internet Connection Firewall. The ICF has policies which has a set of filter for all the addresses which are capable of beingness accessed. The Internet Protocol for Security bottomland be use when the restriction is only to a particular set of addresses or the communication between a group of computers.There are many ways to use IPSec in a network but the best way is bye using a directory with all the domains and also a GP when needed.Some areas of interest when implementing IPSecurityThe decision of where we must secure computers and how on our network which can be done by running a group of systems in a directory which is also called as the Active Directory Organisational Units or OUs. The next step is to determine the strength of the policies we assign.Determining Our Internet Protocol Security targetsThe first base step in deploying IP Sec on our server or the network can be done properly by decision making which set of systems are in dire need of security. There are surely some places on the network which are in a need of higher security than the other shares. It is for sure that IPSec is capable of providing optimal security but the problems starts when the network slows down due to the excessive data to be elegant and also a large number of systems for IPSec to follow and maintain. In some cases, at that place are systems which are not upgraded to be able to support the IPSecurity.Determining Your IPsec NeedsIn beginning of the protocol design procedure, proper planning should be done to make sure that our current network milieu uncommitted for use. It is always helpful to have a set of the network topology with all of its hardware and software components. This procedure is of high importance mainly in the designing procedure. IPSecurity is highly vulnerable to a network topology. There are many network t opologies in which IPSec is not well desirable.Preparing a Internet Protocol Security PolicyAs said earlier, there are many network topologies which are not suitable to the default structure of the IPSec policies. There is a need to develop a custom IPSec set of policies well suited for the current network. Some organisations can run their network with a small set of policies. But in companies with a very huge network, there are many policies which are to be implemented properly and also a blotto structure is to be maintained.Steps below shows how IP Sec policies work.Designing IPsec PoliciesThere might be some cases where the company or the organisation is interest in implementing a policy which sets a secure communication between two qualify computers. This can be done by restricting all traffic and adding exceptions which relates to these two systems. This method can be done vice versa. A network can be setup with policies to allow all requests and cram specific ports or com puters. To implement such exceptions, a thorough analysis of the network is clearly needed.Computer rolesSecurity for Data Transmission Security needs are different from each and every data packet transmitted. The security policies are also very different. There are many levels in this instance. When considering encryption, there are many types such as AES, DE5, RSA and many more. RSA is the best encryption software available presently. These programs can be used to secure files on transmission, on a network or even in the system.Operating System Computers IPSecurity is a very unique technique used to implement security in a network. There are many operating systems which are not so advanced to implement IPSec. There is no support for IPSec. But there are many operating systems which are capable of running IPSec in transport system. Some other cases, the policies are stored locally which makes it easier to fix as the implementation doesnt take long enough. In some cases, IPSec p olicies are implemented through the Group Policy.General IPSec Policy SettingsGeneral IPSec policy settings must be specified whether we want the policy to provide packet filtering or end-to-end networks.IPSec RulesIPSec rules determine which traffic is affected by an IPSec policy and which dos take place when that type of traffic is encountered. Table6.5 describes the contents of IPSec rules that two computers use to establish a secure, demonstrated channel.Specifies a named itemization of filters. Each filter in the filter list specifies the types of traffic to which the filter action is applied. Filters can be defined to match specific IP protocols, source and finish TCP and UDP ports, and source and destination IP addresses.The filter list name might include the version number, the last update quantify, and the administrative owner. Each computer discards the filter list name during policy fermenting.Filter actionSpecifies whether a packet is permitted, blocked, or secured . If packets are to be secured, specifies how they are secured. A list of security methods specifies the security protocol, cryptographic algorithm, and session line regeneration frequency. beseech SecurityAu and sotication methodsOne or more credential methods, which are specified in order of preference. Available options are KerberosV5, certificate, or preshared key.Specifies whether to use dig mode and, if so, the delves endpoint.Specifies whether the rule applies to LAN connections, remote access connections, or twain.Assigning IPSec PoliciesAs a domain administrator, we can configure IPSec policies to meet the security requirements of a user, group, use, domain, site, or global enterprise from a domain controller. IPSec policy can also be implemented in a non-Windows2000-based domain environment by using local IPSec policies.Deploying Our IPSec SolutionAfter scoping our needs, building IPSec policies, and determining our strategy for assigning the policies to specific OUs , test the IPSec policies in a lab environment and take up a pilot project before rolling them out for production use.To ensure that IPSec policy functions as expected and provides the appropriate level of security, test specific IPSec policy configurations on clients and servers in a lab environment, and then conduct pilot or beta tests in a limited achievemental environment before conducting a full-scale deployment.A Cryptographic Evaluation of IPsecEven with all the serious critisisms that we have on IPsec, it is probablythe best IP security protocol available at the moment. We have looked at other,functionally similar, protocols in the past (including PPTP SM98, SM99) inmuch the aforementioned(prenominal) manner as we have looked at IPsec. None of these protocolscome anywhere near their target, but the others manage to miss the mark by awider margin than IPsec. This difference is less significant from a security pointof view there are no points for getting security nearly rig ht. From a marketingpoint of view, this is important. IPsec is the current best practice, no matterhow badly that reects on our ability to create a good security standard.Our main criticism of IPsec is its complexity. IPsec contains in addition many optionsand too much exibility there are often several ways of doing the same or similarthings. This is a typical committee efiect. Committees are notorious for addingfeatures, options, and additional exibility to satisfy different factions within thecommittee. As we all know, this additional complexity and bloat is seriouslydetrimental to a normal (functional) standard. However, it has a devastatingefiect on a security standard.It is instructive to compare this to the approach taken by NIST for the developmentof AES NIST97a, NIST97b. Instead of a committee, NIST organized acontest. Several small groups each created their own proposal, and the process is limited to picking one of them. At the time of writing there has been one stageof extermination, and any one of the five remaining candidates allow make a much better standard than any committee could ever have made.The Complexity Trap Securitys worst enemy is complexity.Complexity of IPsec In our opinion, IPsec is too complex to be secure. Thedesign obviously tries to support many difierent situations with difierent options.We feel very strongly that the resulting system is well beyond the level ofcomplexity that can be analysed or properly implemented with current methodologies.Thus, no IPsec system will achieve the goal of providing a high level ofsecurity.IPsec has two modes of operation transport mode and dig mode. Thereare two protocols AH and clairvoyance. AH provides assay-mark, ESP provides authentication,encryption, or both. This creates a lot of extra complexity twomachines that wish to authenticate a packet can use a total of four difierentmodes transport/AH, tunnel/AH, transport/ESP with aught encryption, andtunnel/ESP with NULL encryption. The d ifierences between these options, bothin functionality and performance, are minor. The documentation also makes itclear that under some circumstances it is envisioned to use two protocols AHfor the authentication and ESP for the encryption.Modes As far as we can determine, the functionality of tunnel mode is a supersetof the functionality of transport mode. (From a network point of view, onecan view tunnel mode as a special case of transport mode, but from a securitypoint of view this is not the case.) The only advantage that we can see to transportmode is that it results in a somewhat smaller bandwidth overhead. However,the tunnel mode could be extended in a straightforward way with a specializedheader-compression system that we will explain shortly. This would achieve virtual(prenominal)lythe same performance as transport mode without introducing an entirelynew mode. We thereof recommend that transport mode be eliminated.Recommendation 1 Eliminate transport mode.Without any docu mented rationale, we do not know why IPsec has twomodes. In our opinion it would require a very compelling argument to introducea second major mode of operation. The extra cost of a second mode (interms of added complexity and resulting loss of security) is huge, and it certainlyshould not be introduced without clearly documented reasons.Eliminating transport mode also eliminates the need to discipline the machineson the network into the two categories of hosts and security gateways. The maindistinction seems to be that security gateways may not use transport modewithout transport mode the distinction is no longer necessary.Protocols The functionality provided by the two protocols overlaps somewhat.AH provides authentication of the payload and the packet header, while ESPprovides authentication and confidentiality of the payload.In transport mode, AH provides a stronger authentication than ESP can provide,as it also authenticates the IP header handle. One of the standard modes ofo peration would seem to be to use both AH and ESP in transport mode. In tunnelmode, ESP provides the same level of authentication (as the payload includesthe original IP header), and AH is typically not combined with ESP KA98c,section 4.5. (Implementations are not required to support nested tunnels thatwould allow ESP and AH to both be used in tunnel mode.)One can question why the IP header palm are being authenticated at all. Theauthentication of the payload proves that it came from someone who knows theproper authentication key. That by itself should provide equal information.The IP header landing fields are only used to get the data to the recipient, and shouldnot afiect the interpretation of the packet. There might be a very good reasonwhy the IP header fields need to be authenticated, but until somebody providesthat reason the rationale remains unclear to us.The AH protocol KA98a authenticates the IP headers of the loour classs.This is a clear violation of the modularization of the protocol great deal. It createsall kind of problems, as some header fields change in transit. As a result, theAH protocol needs to be aware of all data formats used at loour layers so thatthese mutable fields can be avoided. This is a very ugly construction, and onethat will create more problems when future extensions to the IP protocol aremade that create new fields that the AH protocol is not aware of. Also, as someheader fields are not authenticated, the receiving application let off cannot rely onthe entire packet. To fully understand the authentication provided by AH, anapplication needs to take into account the same complex IP header parsing rulesthat AH uses. The complex definition of the functionality that AH provides caneasily lead to security-relevant errors.The tunnel/ESP authentication avoids this problem, but uses more bandwidth.The extra bandwidth requirement can be reduced by a simple specializedcompression scheme for some suitably chosen set of IP header fi elds X, a singlebit in the ESP header indicates whether the X fields in the inner IP header areidentical to the corresponding fields in the outer header.2 The fields in questionare then re go to reduce the payload size. This compression should beapplied after computing the authentication but before any encryption. The authenticationis thus still computed on the entire original packet. The receiverreconstitutes the original packet using the outer header fields, and verifies theauthentication. A suitable choice of the set of header fields X allows tunnel/ESPto achieve virtually the same low message expansion as transport/AH.We conclude that eliminating transport mode allows the elimination of theAH protocol as well, without loss of functionality. We therefore recommend thatthe AH protocol be eliminated.IPSEC methodology using different operating systemsIPSEC is a framework for security that operates at the Network Layer by extending the IP packet header. This gives it the ability to e ncrypt any higher layer protocol, including TCP and UDP sessions, so it offers the greatest flexibility of all the existing TCP/IP cryptosystems. While conceptually simple, setting up IPSEC is much more complex that in carrel SSH, for example.IPSEC also has the disadvantage of requiring operating system support, since most O/S amounts dont allow direct manipulation of IP headers. Linux IPSEC support (the FreeS/ gruesome project), for example, isnt included in the standard nerve distribution for this reason, and has to be applied as an add-on. Furthermore, putting the cryptography in the kernel isolates it from the application, making it more difficult to recruit crypto-aware software. Using SSL, for example, simply requires linking a library into the application and allows the application to easily query what certificates have been used to authenticate a client.IPSEC defines a Security Association (SA) as its primitive means of protecting IP packets. An SA is defined by the packe ts destination IP address and a 32-bit Security Parameter Index (SPI), that functions somewhat like a TCP or UDP port number. SAs can operate in transport mode, where the IPSEC data field begins with upper level packet headers (usually TCP, UDP, or ICMP), or in tunnel mode, where the IPSEC data field begins with an entirely new IP packet header, ala RFC 2003. Furthermore, SAs can be encapsulated within SAs, forming SA bundles, allowing layered IPSEC protection.For example, one SA might protect all traffic through a gateway, while another SA would protect all traffic to a particular host. The packets finally routed across the network would be encapsulated in an SA bundle consisting of both SAs.A common use of IPSEC is the construction of a Virtual Private Network (VPN), where multiple segments of a private network are linked over a public network using encrypted tunnels. This allows applications on the private network to communicate securely without any local cryptographic support, s ince the VPN routers perform the encryption and decryption. IPSEC is well suited for this environment, more so than tunneling PPP over SSL or SSH, since it operates directly on the IP packets and preserves a one-to-one correspondence between packets inside and remote the network. In the case of tunneling PPP over an encrypted TCP connection, any packet loss in the public network would trigger a TCP retransmission, stalling the link until the packet was delivered. In particular, running Voice Over IP (VoIP) traffic through a TCP/PPP tunnel would largely beat the RTP protocol used for VoIP IPSEC is better suited in this case.IPsec Development for LinuxIn the Linux IPv4 IPsec world, a lot of mickle useFreeS/ wan projects implementation. It consists of an inkernelIPsec affect part, Key throw daemon Plutoand some utility commands/scripts.To run Pluto with small changes on our IPsec kernelimplementation and reduce impact for user who useFreeS/WAN implementation, we have decided to ke ep compatibilitywith FreeS/WANs IPsec programming interfacebetween kernel and userland. For this, we use the samePF KEY interface which FreeS/WAN project extended.In kernel IPsec packet processing part, we developedAH, ESP, SAD and SPD from scratch. PF KEY interfacePF KEY(v2), which is described in RFC2367, is keymanagement API mainly for IPsec. PF KEY is used forhandling the IPsec Security Association Database. Additionallywe have to handle the IPsec Security PolicyDatabase, but there is no standard for the IPsec SecurityPolicy management API. In FreeS/WAN implementation,PF KEY interface is extended to manage the IPsec SecurityPolicy Database. Our kernel 2.4 IPsec implementationalso uses the same PF KEY interface as FreeS/WANs one.It is important to be able to run the FreeS/WANs userlandapplication (e.g., Pluto) with small changes.Encryption and Authentication algorithmWe provide HMAC-SHA1 and HMAC-MD5 for authentication,NULL, DES-CBC, 3DES-CBS and AES for encryption.We thought enc ryption and authentication algorithmis not only used by IPsec and there are many algorithmsso that we consider encryption and authentication algorithmand those interface should have good modularity.We adopted cipher modules which provided by CryptoAPIProject.Security Association and Security PolicySA and SP themselves dont depend substantially on theIP version. FreeS/WAN project architecture depends ontheir special virtual network interface for IPsec because itmight focus on IPv4 tunnel mode (Their implementationalso provides IPv4 transport mode). Their SA, SP, SAD andSPD also depend on their special virtual network interface.We considered and decided it was not suit to IPv6 because the IPv6 stack needed the neighbor discovery and the auto address configuration in its basic specification. If we hadimplemented IPv6 IPsec stack with their architecture, wehad to implement those basic specification in their specialvirtual network interface. Therefore we implemented ourown SAD and SPD in order to handle both IPv4 and IPv6.To improve the system performance, Each database willbe locked by smallest granularity. And in many cases weuse the read lock. SA and SP are managed by the referencecounter to foreclose used SA from removing by accident.IPsec Packet Processing outputThere are various packet output paths from the IP(v4/6)layer to the network number one wood layer in Linux kernel networkingstack (TCP, UDP/ICMP, and NDP10 for IPv6).The packets which may be applied IPsec will gothrough these paths. We had to add IPsec functionalityfor these output paths, e.g, in IPv6 ip6 xmit()for TCP, ip6 build xmit() for UDP/ICMP andndisc send ns()/ndisc send rs() for neighbordiscovery packets.Output process is as follows)check IPsec SPlookup the IPsec SA by the IPsec SPapply IPsec processing to the packetoutput the packet to the network driver layerTo reduce SA searhing time, we link the SP and thefound SA after lookup from the first time.InputAt input, there is only path for IP packets. We added IPsecprocessing part in ip6 input finish.Input process is as followsreceive the packetlookup the IPsec SA by SPI(which resides in AH/ESP header)check uprightness and decryptcheck IPsec Policy.IPsec cut into modeWe are using IPv6-over-IPv6(and IPv4-over-IPv4) virtualtunnel device to implement IPsec tunnel mode. Thisimplementation can avoid to duplication code of encapsulation/decapsulation outer IP header compairing with havingthese code in the IPsec processing part itself. The virtualtunnel device is not different from the normal IP-over-IPvirtual tunnel device in Linux.4 IPsec implementation for kernel 2.6The most important difference between ours and them is SAD/SPD part. They thought the whole SPD/SAD mechanic should be flow save up based lookup system shared byIPv4 and IPv6. One month later, they introduced the newnetwork architecture called XFRM to Linux kernel 2.5.At first their developing code lacked IPv6 IPsec only forIPv4 IPsec. In order to suport IPv6 IPsec, we have implementedIPv6 IPsec code based on XFRM (and discarded ouroriginal code).PF KEY interfaceThe PF KEY interface of Linux kernel 2.6(and 2.5) iscompatible with KAME3 PF KEY interface. We can usesetkey command for configuring SA and SP and Racoonfor IKE. Additionally we can add IPsec Policy each socketvia Netlink3. They have suported only IPv4 in their firstcode, we have added IPv6 support.Security Association and Security PolicyOn the XFRM architecture, IPsec SP, which is representedas xfrm policy structure, will be bound tothe routing flow cache (and IPsec policy will pointIPsec SA bundle) and IPsec SA, which is represented asxfrm state structure, is included in destination cache,dst entry structure. The chaining destination cachemeans IPsec SA bundle.IPsec Packet ProcessingOutputThe output part of the XFRM architecture is placed betweenthe IP layer and the network driver layer. In general, nonIPsec packet will be passed to the network driver layer by asingle destinati on output function, which is resolved routinglookup. But IPsec packet will be need to apply some IPsecprocessing (e.g., encryption, hash). XFRM functions makea chain of destination output functions (We call StackableDestination, as shown in Figure3). Each function matcheach IPsec processing (AH, ESP and IPcomp11).To be more specific, in order to pass a packet to the networkdriver layer we have to do as follows.lookup routing table to decide output function byip6 route outputlookup IPsec Security Policylookup IPsec Security Association(s) suitable for IPsecSecurity Policy and create destination chainto apply IPsec, pass a packet to the destination chainInputThe input part of the XFRM architecture is simpler than output.The XFRM input function is handled as same as upperlayer protocols like TCP, UDP, etc. In IPv6, IPsec headersare defined as IPv6 extension header but IPsec input functionsare handled as an upper layer protocol handler. As theresult of introducing IPv6 IPsec input proce ssing in Linux.kernel, inconsistencies existed between IPsec headers and other IPv6 extension headers. In order to resolve this, wemoved to the other IPv6 extension header handler functionsto upper layer protocol handler. In detail, we registeredIPsec header (both AH and ESP) handler functions with upperlayer protocol handler adjust inet6 protos.Incoming IPsec packet processing flow is as followsprocess IP packet from IP header in sequenceprocess IPsec part (check integrity and decrypt) iffoundedcheck IPsec Security Policypass IP packet next handlerIPsec Tunnel modeLinux kernel 2.6 IPsec tunnel mode doesnt use the virtualtunnel device to create tunnel. The IPsec stack buildsthe outer IP header during IPsec processing by itself.IPSec Best practicesBest practicesIPSEC in transport mode has some serious advantages over other solutions. Compared to other technologies, IPSEC is built into to the Linux kernel. In other words there is nodaemonrunning in the background. Better yet, IPSEC d oes not require port-forwarding some people elect to useSSH, stunnel, and other technologies that rely onport forwarding. With IPSEC, you simply have to run a program and its configuration file. After running it,encryptionbetween hosts is mandatory. Connections will be refused if the other connection does not have the appropriate keys. Groups of computers can share the same key, and it can even be done on a per-port setting (for example securing VNC, etc).Downsides?IPSEC in transport mode does have a couple draw backs. In transport mode you cannot have any dynamic setups where the IP addresses change from time to time. In other words, IPSEC is usually insufficient for workstation environments or dynamically assigned networks. Also, if you want to do a per-port setup the configuration becomes harder.Security ImplicationsA very astute user can use IPSEC to bypass firewalls and other security measures. Since IPSEC uses cryptography, information is passed between machines in encrypted f ormat. If the keys are not known, there is no practical way to decrypt the information (it is virtual impossible due to the sheer amount of time it would take).Machine-to-Machine IPSEC installations should be considered as Virtual Private Networks (VPNs) for security considerations. divert check with yoursystem administrator, business policies, and laws and regulations of your locality in order to establish whether or not to institute IPSEC.Requirementsipsec-tools packagestatic IP addresses for each machine descriptor fileThe configuration file, /etc/setkey.conf, contains the information about the IPSECpolicy. Below is a sampleconfiguration policy(i.e. dont implement this policy because it is insecure).These lines are the literal keys and the encryption that will be used. The first block has the keys that will be used for authentication. In this case, it is the hmac-md5algorithm. The second block contains the keys that will be used for privacy, and the method of encryption. In the example, AES-CBC will be used, which is probably stronger than should be required the key that we will be using is 194bits, meaning that it is good enough for US Government Secret and below classifications.The final block includes the actual policy. This is where you can put port numbers and even define whether it will be TCP orUDP.Generating the keysThe more random the key, the better. Obviously, the example above is insufficient to secure a network. The following command will generate a random key. While running this command, youll need to wiggle the mouse to make it run faster. Or, if you are using a terminal use/dev/urandom instead.dd if=/dev/random count=16 bs=1 xxd -psDepending on the size of the key that you want, adjust the count (16 will produce a 128 bit key, 24 will produce a 196 bit key, and 32 will produce a 512 bit key)The size of the key is important. If you really paranoid or just haveCPUcycles to
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment
Note: Only a member of this blog may post a comment.