PA160: Net-Centric Computing II. Network Security Luděk Matýska Slides by: Tomáš Rebok Faculty of Informatics Masaryk University Spring 2017 Luděk Matýska (Fl MU) 1. Network Security Spring 2017 1 / 125 Course Introduction Course Introduction PA160 - Course Introduction j Luděk Matýska (Fl MU) 1. Network Security Spring 2017 /125 Course Organization • attending the lectures is optional • the knowledge acquired during PB156 & PA159 courses is assumed • course materials will be published on the course webpage (more or less in time ;-) ) • assessment methodology: • final exam (written form) o course literature: • slides, RFCs, ... • literature being announced in relevant course parts Luděk Matýska (Fl MU) 1. Network Security Spring 2017 3 Course Overview • the course goal: • to provide an advanced insight into the area of computer networks and their applications • discussed topics: • network security • network management and monitoring o parallel and distributed applications, grids • service-oriented architectures • specification and verification of communication protocols • network simulators and emulators • etc. Luděk Matýska (Fl MU) 1. Network Security Spring 2017 4 / 125 1. Network Security 1. Network Security J Luděk Matýska (Fl MU) 1. Network Security Spring 2017 /125 Lecture overview Lecture overview Introduction ^ Motivation ^ Network Security Elements Cryptography Introduction © Symmetric Cryptography O Asymmetric Cryptography Network Security Mechanisms ^ Entity Authentication ^ Message Confidentiality (Security) ® Message Integrity ^ Message Authentication w Digital Signature 9 Key Management and Distribution Example Protocols Ensuring Network Security in the Internet ^ Application-layer Security ^ Transport-layer Security ^ Network-layer Security ^ Link-layer Security Network & Data Protection - Maintaining the Availability ^ Firewalls ^ Intrusion Detection Systems ^ Denial of Service (DoS) & Distributed Denial of Service (DDoS) attacks 9 Virusses & Worms ^ Network & Data Protection - Concluding Remarks Conclusion 1. Network Security Spring 2017 6 / 125 Luděk Matýska (Fl MU) Introduction Lecture overview Introduction 9 Motivation G Network Security Elements Cryptography Introduction ^ Symmetric Cryptography 9 Asymmetric Cryptography VSV Network Security Mechanisms w Entity Authentication ^ Message Confidentiality (Security) 9 Message Integrity ^ Message Authentication 9 Digital Signature ^ Key Management and Distribution Example Protocols Ensuring Network Security in the Internet ^ Application-layer Security ® Transport-layer Security © Network-layer Security ^ Link-layer Security Network & Data Protection - Maintaining the Availability ^ Firewalls © Intrusion Detection Systems ^ Denial of Service (DoS) & Distributed Denial of Service (DDoS) attacks © Virusses & Worms ® Network & Data Protection - Concluding Remarks \SM Conclusion 1. Network Security Spring 2017 7 / 125 Luděk Matýska (Fl MU) Security • most of computer science is concerned with achieving desired behavior o in some sense, security is concerned with preventing undesired behavior • different way of thinking! • an enemy/opponent/hacker/adversary may be actively and maliciously trying to circumvent any protective measures one put in place • computer vs. network security • computer security - focuses on security aspects of systems in isolation 9 viruses, secure data storage, OS security, etc. • network security - focuses on security of data as it is transmitted between networked systems • authentication protocols, encryption of transmitted data, firewalls, etc. • not always a clear-cut dividing line.. . Ludek Matyska (Fl MU) 1. Network Security Spring 2017 8 / 125 Introduction Motivation What can go wrong? when your computer y receives or is waiting for a message ml m Luděk Matýska (Fl MU) 1. Network Security Spring 2017 9 / 125 Introduction Motivation What can go wrong? Message loss adversary A can discard m in its transit m \ x Luděk Matýska (Fl MU) 1. Network Security Motivation What can go wrong? Message interception Luděk Matýska (Fl MU) 1. Network Security What can go wrong? Message modification • adversary A can arbitrarily modify the content of m to become m' A _ Luděk Matýska (Fl MU) 1. Network Security Spring 2017 12 / 125 Introduction Motivation What can go wrong? Message insertion • adversary A can arbitrarily fabricate a message m, pretending that m was sent by x s---V src: x What can go wrong? Message replay • adversary A can replay a message m that has been sent earlier by x and received by y What can go wrong? Denial-of-Service attack • adversary A can send huge amount of messages to y to block m from arriving at y • in the case of botnet attack, the adversary instructs many bots to send messages to y simultaneously x What is needed? Reliable transmission • y wants to receive all messages sent by x to her • both x and y want to make sure the message is not tampered with • eventually they both want the message not to be overheard by any third party What is needed? Sender verification • y wants to be able to verify that the message m has been really sent by x src: ? Introduction Motivation What is needed? Message non-repudiation 9 x wants to be able to prove to third party z that y has received a message m from x 9 y wants to be able to prove to third party z that x has sent a message m to y Introduction Motivation Network Security Network Security is great... • protects messages from interception in their transit • provides desired level of privacy for users or data a detects and discards messages that had been modified, inserted, or replayed • disallows unauthorized access to local system resources and sensitive data ... but hard to achieve • many layers in network architecture a many different media of network connection o adversary's location hard to determine • new attacks keep emerging • cryptographic overhead Ludek Matyska (Fl MU) 1. Network Security Spring 2017 19 / 125 Introduction Network Security Elements Network Security - Basic Elements A secure communication network should provide the following mechanisms/services: • AAA • Authentication • Authorization • Accounting • + secured communication • Confidentiality • Integrity 9 Non-repudiation • + Availability Luděk Matýska (Fl MU) 1. Network Security Spring 2017 20 / 125 Introduction Network Security Elements Network Security - Basic Elements Authentication Authentication o in Czech: autentizace • NOT autentikace, autentifikace, ... • several perspectives: • a process verifying that someone is who they claim they are (= entity authentication) • a process assuring the recipient that the message is from the source that it claims to be from (= message authentication) • requires a determination of the entity's identity o several methods for identity determination exist: • based on what a user knows - a proper pair of username and password/PIN • based on what a user has - a tool which a user owns (USB dongle, smart card, private key, etc.) • based on what a user is - a user has characteristics, which can be verified (fingerprint, retinal images, etc.) • based on what a user can - a user is able to answer particular verifying questions Ludek Matyska (Fl MU) 1. Network Security Spring 2017 21 / Introduction Network Security Elements Network Security - Basic Elements Authorization and Accounting Authorization 9 process of granting the user access to specific system resources 9 based on user's profile and the local/global policy controlling the resource access • follows the authentication process a ensured by access control lists (ACLs) • define permissions to perform particular operation or to access particular resources Accounting • monitoring the users' usage of network services • the information can be used for management, planning, billing, or other purposes Luděk Matýska (Fl MU) 1. Network Security Spring 2017 Introduction Network Security Elements Network Security - Basic Elements Confidentiality, Integrity, and Non-repudiation Confidentiality 9 protects data and information from unauthorized disclosure (sniffers) • data during transmission cannot be read by any unauthorized user o just the sender and receiver understand the content of the transferred message • ensured by message encryption Integrity • protects data from unauthorized modification 9 data during transmission cannot be modified or fabricated by any unauthorized user • usually based on encryption and hashing algorithms Non-repudiation • sender nonrepudiation and receiver nonrepudiation serves the receiver/sender for the purposes of proving origin/delivery of the message • neither the sender of a message can deny the transmission of the message nor the receiver of a message is able to deny the reception of the message • ensured by digital signatures Ludek Matyska (Fl MU) 1. Network Security Spring 2017 23 / 125 Introduction Network Security Elements Network Security - Basic Elements Availability Availability * property of a system, network, or a resource being accessible and usable any time upon demand by an authorized system entity • i.e., a system is available if it provides services according to the system design whenever users require them • has to be associated with various security services • such as services protecting from denial of service (DoS) attacks Luděk Matýska (Fl MU) 1. Network Security Spring 2017 24 / 125 Lecture overview U Introduction 9 Motivation 9 Network Security Elements Cryptography Introduction Ä Symmetric Cryptography O Asymmetric Cryptography VSV Network Security Mechanisms w Entity Authentication ^ Message Confidentiality (Security) 9 Message Integrity 9 Message Authentication 9 Digital Signature 9 Key Management and Distribution Example Protocols Ensuring Network Security in the Internet 9 Application-layer Security 9 Transport-layer Security 9 Network-layer Security 9 Link-layer Security Network & Data Protection - Maintaining the Availability 9 Firewalls 9 Intrusion Detection Systems 9 Denial of Service (DoS) & Distributed Denial of Service (DDoS) attacks 9 Virusses & Worms 9 Network & Data Protection - Concluding Remarks \SM Conclusion 1. Network Security Spring 2017 25 / 125 Luděk Matýska (Fl MU) Cryptography Introduction Cryptography Introduction • network security is mostly achieved through the use of Cryptography Cryptography: • the science and art of transforming messages to make them secure and immune to attacks • basic cryptography mechanisms: • symmetric (secret-key) cryptography • asymmetric (public-key) cryptography plaintext key. encryption algorithm sender (Alice) ciphertext ^— key B TT channe intruder (Trudy) plaintext decryption algorithm receiver (Bob) Luděk Matýska (Fl MU) 1. Network Security Spring 2017 26 / 125 Cryptography Introduction Symmetric Cryptography Symmetric Cryptography the same key is used by both parties for both encryption and decryption advantages: • low computational demands • suitable for encryption of large messages drawbacks: • a necessity to share the secret key (—>> a mechanism for key distribution is required) • can lead to many keys required to be maintained (e.g., many-to-one communication in distributed environment) e.g., DES, 3DES, IDEA, Blowfish, Rivest Cipher 4 (RC4), AES, etc. Alice plaintext Shared secret key Bob l Encryption ciphertext ciphertext Decryption T plaintext Luděk Matýska (Fl MU) 1. Network Security Spring 2017 27 / 125 Symmetric Cryptography Simple Symmetric Ciphers Character-oriented • operate on characters of an alphabet • substitution ciphers - substitutes one symbol with another • monoalphabetic - a character/symbol in the plaintext is always changed to the same character/symbol in the ciphertext (e.g., Caesar cipher) • polyalphabetic - each occurrence of a character can have a different substitute • transposition ciphers - reorders (permutes) symbols in a block of symbols • instead of substitutions, locations of characters change Bit-oriented • operate on blocks of bits 9 e.g., XOR cipher, rotation cipher, etc. Ludek Matyska (Fl MU) 1. Network Security Spring 2017 28 / 125 Cryptography Introduction Symmetric Cryptography Symmetric Cryptography DES (Data Encryption Standard) DES (Data Encryption Standard) • designed by IBM and adopted by the U.S. government as the standard encryption method for nonmilitary and nonclassified use • the algorithm encrypts a 64-bit plaintext blocks using a 64-bit key 9 in fact, the key is just 56-bits long (every eighth bit is used for parity checking and is ignored) • DES has two transposition blocks (so-called P-boxes) and 16 complex round ciphers • although the 16 iteration round ciphers are conceptually the same, each uses a different key derived from the original key • not considered to be secure any more • because of the key length (too short) • see details in the animation: http://www.cs.bham.ac.uk/ research/proj ects/lemsys/DES/DESPage.j sp Ludek Matyska (Fl MU) 1. Network Security Spring 2017 29 / 125 Cryptography Introduction Symmetric Cryptography Symmetric Cryptography DES (Data Encryption Standard) - Algorithm outline I. DES 64-bit plaintext iL Initial permutation Final permutation V Round key generator hi Zl 64-bit key 64-bit dphertext Luděk Matýska (Fl MU) 1. Network Security Spring 2017 30 / 125 Cryptography Introduction Symmetric Cryptography Symmetric Cryptography DES (Data Encryption Standard) - Algorithm outline II. (single round) Round: 32 bits -1+1 32 bits 32 bits Li 32 bits f fíR^K,) < K| I (48 bits) 32 bits XOR 32 bits a. Encryption round Round: 32 bits 32 bits b. Decryption round 32 bits R, k / 1 32 bits f 32 bits y XOR Lj+I Ri+1 32 bits ■ (48 bits) _ j Luděk Matýska (Fl MU) 1. Network Security Spring 2017 31 / 125 Cryptography Introduction Symmetric Cryptography Symmetric Cryptography Triple DES (3DES) Triple DES (3DES) • has been proposed and implemented to lengthen the DES key • uses three DES blocks • encryption: DES encryption-decryption-encryption • decryption: DES decryption-encryption-decryption 9 different variants: • 3DES with three keys —>► the size of the key is increased to 168 bits • 3DES with two keys (Keyi = Keys) —^ the size of the key is 112 bits • if (Keyi = Key2 = Keys) =>• standard DES Luděk Matýska (Fl MU) 1. Network Security Spring 2017 32 / Cryptography Introduction Symmetric Cryptography Symmetric Cryptography Triple DES (3DES) 64-bit plaintext Encrypt DES Key1 LU Q Q. Decrypt DES Encrypt DES ■ Key- P= => Key, 64-bit ciphertext a. Encryption Triple DES 64-bit plaintext Decrypt DES LU Q o. Encrypt DES Key, Decrypt DES A V Key- Key, 64-bit ciphertext b. Decryption Triple DES Luděk Matýska (Fl MU) 1. Network Security Spring 2017 33 / 125 Symmetric Cryptography AES (Advanced Encryption Standard) AES (Advanced Encryption Standard) • proposed as a reaction to competition for selecting a successor to DES (1997) • originally called Rijndael 9 standardized in 2001 • three variants: AES-128, AES-192 and AES-256 • the number indicates the key length • the keysize has no theoretical maximum • operates on a 4 x 4 array of bytes (= 128 bits) • AES performs a number of repetitions of transformation rounds that convert the input plaintext into the final output of ciphertext • each round consists of several processing steps, including one that depends on the encryption key 9 can be effectively implemented in HW • see details in the animation: http://www.formaestudio.com/rijndaelinspector/ Ludek Matyska (Fl MU) 1. Network Security Spring 2017 34 / 125 Cryptography Introduction Symmetric Cryptography Symmetric Cryptography AES (Advanced Encryption Standard) - Algorithm outline I. AES Luděk Matýska (Fl MU) 128-bit plaintext Round 10 (slightly different) f 128-bit ciphertext Round key generator 1. Network Security Cryptography Introduction Symmetric Cryptography Symmetric Cryptography AES (Advanced Encryption Standard) - Algorithm outline II. (single round) Round i 128-bit data SubByte 1 ShiftRow Byte substitution ~r~ MixColumn Byte permutation T~ Complex operation (missing in round 10) AddRound Key I T 3 K, Luděk Matýska (Fl MU) 128-bit data 1. Network Security Spring 2017 36 / 125 Asymmetric Cryptography • also known as Public-key Cryptography 9 uses different keys for encryption and decryption • both keys are denoted as keypair • the public key is used for encryption, while the private key is used for decryption • the message encrypted by a public key can be decrypted only by the appropriate private key • advantages: • no secret key is passed between two communicating parties lowers the risk of its disclosure • the public key can be published a drawbacks: • the speed asymmetric ciphers are suitable for small messages » for example, for a symmetric key exchange • suffer from the man-in-the-middle attack • the public keys have to be provided by a trusted party • e.g., RSA, Diffie-Hellman (key exchange), etc. Ludek Matyska (Fl MU) 1. Network Security Spring 2017 37 / 125 Cryptography Introduction Asymmetric Cryptography Asymmetric Cryptography Illustration Alice I plaintext Encryption To the public ciphertext í ciphertext Bob's public Bob's private plaintext Luděk Matýska (Fl MU) 1. Network Security Spring 2017 38 / 125 Asymmetric Cryptography RSA (Rivest, Shamir, and Adleman algorithm) I. RSA (Rivest, Shamir, and Adleman algorithm) • the most common and popular public key algorithm • RSA gets its security from the difficulty of factoring large numbers • uses two (large) numbers, e and d, as the encryption and decryption keys • public/private keys generation: • choose two random large prime numbers, p and q (ideally of equal length, e.g., 200 digits) • compute the product N = p • q • then randomly choose the encryption key, e (between 1 and N — 1), such that e and (p — l)(q — 1) are relatively prime • then compute the decryption key, d\ d = e_1 mod ((p — l)(q — 1)) • i.e., d • e = 1 mod ((p - l)(q - 1)) • p and q are no longer needed • public key: (e, N) • private key: (c7, N) Ludek Matyska (Fl MU) 1. Network Security Spring 2017 39 / 125 Cryptography Introduction Asymmetric Cryptography Asymmetric Cryptography RSA (Rivest, Shamir, and Adleman algorithm) II RSA (Rivest, Shamir, and Adleman algorithm) cont'd • message encryption • to encrypt a message m, it has to be divided into numerical blocks smaller than N • each block is then individually encrypted: c = me mod N • message decryption 9 decrypt every block by: m = cd mod N • see all the details in the RSA animation: http://cryptool.org/media/RSA/RSA-Flash-en/player.html Luděk Matýska (Fl MU) 1. Network Security Spring 2017 40 / 125 Lecture overview Introduction 9 Motivation 9 Network Security Elements 9 Cryptography Introduction © Symmetric Cryptography 9 Asymmetric Cryptography Network Security Mechanisms 9 Entity Authentication 9 Message Confidentiality (Security) 9 Message Integrity 9 Message Authentication 9 Digital Signature 9 Key Management and Distribution Example Protocols Ensuring Network Security in the Internet 9 Application-layer Security 9 Transport-layer Security 9 Network-layer Security 9 Link-layer Security Network & Data Protection - Maintaining the Availability 9 Firewalls 9 Intrusion Detection Systems 9 Denial of Service (DoS) & Distributed Denial of Service (DDoS) attacks 9 Virusses & Worms 9 Network & Data Protection - Concluding Remarks Conclusion Luděk Matýska (Fl MU) 1. Network Security Spring 2017 41 / 125 Network Security Mechanisms Entity Authentication Entity Authentication Passwords Password authentication: • the simplest and the oldest method • Alice authenticates to Bob by sending a password • fixed passwords - subjects to several attacks: • eavesdropping, stealing a password, accessing a file with passwords, guessing (dictionary attacks), etc. • can be (partially) solved by: o hashing the passwords • hashing salted passwords • e.g., PAP (Password Authentication Protocol) - transmits unencrypted ASCII passwords (assumes out-of-band control channel) • one-time passwords - passwords valid just for only one login session • new password generated based on previous password • new password generated based on a challenge o specialized electronic tokens, out-of-band channels (SMS), etc. Ludek Matyska (Fl MU) 1. Network Security Spring 2017 42 / 125 Network Security Mechanisms Entity Authentication Entity Authentication Challenge-Response Authentication 9 in password authentication, the claimant proves her identity by demonstrating that she knows a secret (the password) 9 however, since the claimant reveals this secret, the secret is susceptible to interception by the adversary • in challenge-response authentication, the claimant proves that she knows a secret without revealing it 9 the challenge is a time-varying value (a random number or a timestamp) sent by the verifier • the claimant applies a function to the challenge and sends the result (response) to the verifier • the response shows that the claimant knows the secret Luděk Matýska (Fl MU) 1. Network Security Spring 2017 43 / 125 Network Security Mechanisms Entity Authentication Entity Authentication Challenge-Response Authentication - Symmetric keys using a nonce Alice asks Bob for sending a nonce (a random number, timestamp, etc.) Alice encrypts the nonce by shared secret key (the password) and sends it back to Bob Alice r is Alice R B K Aß R B Alice sends data to Bob using KAB Bob Luděk Matýska (Fl MU) 1. Network Security Spring 2017 44 / 125 Network Security Mechanisms Entity Authentication Entity Authentication Challenge-Response Authentication - Symmetric keys using a nonce (mutual auth.) • same as the previous one, but with the mutual authentication Alice r o Alice, RA Alice sends data to Bob using KAB Bob r Luděk Matýska (Fl MU) 1. Network Security Spring 2017 45 / 125 Network Security Mechanisms Entity Authentication Entity Authentication Challenge-Response Authentication - Hash functions usage • instead of encryption/decryption, one can also use a hash function for entity authentication • hash function - a one-way function generating a message digest • details on hash functions - see Message Integrity part • e.g., MS CHAP (Challenge-Handshake Authentication Protocol) Alice (user) 1 Bob (server) Luděk Matýska (Fl MU) 1. Network Security Spring 2017 46 / 125 Network Security Mechanisms Entity Authentication Entity Authentication Asymmetric keys - Public key usage • instead of symmetric-key ciphers, asymmetric-key ciphers can be also used for entity authentication • the secret is the private key of the claimant • she must show that she owns the private key related to the public key a the nonce can be encrypted either by the claimant's public key Alice (user) □ Luděk Matýska (Fl MU) Bob (server) 111 Alice R B 1. Network Security Spring 2017 47 / 125 Network Security Mechanisms Entity Authentication Entity Authentication Asymmetric keys - Private key usage or by her private key (= digital signatures, see later) Alice (user) 1 Alice K, Bob SA (RB, Bob) Bob (server) ...... Luděk Matýska (Fl MU) 1. Network Security Spring 2017 48 / 125 Message Confidentiality/Security - Data Encryption the transmitted data are usually (especially for the long messages) encrypted using a symmetric cryptography algorithm • because of their speed • the shared secret key necessary for the encryption can be (prior to the transmission) obtained using: • asymmetric cryptography - the chosen shared key is encrypted using the public key of the communicating partner and delivered to her • Diffie-Hellman algorithm - shared key computation Luděk Matýska (Fl MU) 1. Network Security Spring 2017 49 / 125 Network Security Mechanisms Message Confidentiality (Security) Message Confidentiality/Security - Data Encryption Symmetric Cryptography Alice J Plaintext -i Shared keys Encryption Ciphertext -9 Bob 1 Decryption Plaintext Data flow a. A shared secret key can be used in Alice-Bob communication Alice □ 3 Plaintext fr °1 Shared keys Decryption Ciphertext Bob I Encryption Plaintext Data flow b. A different shared secret key is recommended in Bob-Alice communication Luděk Matýska (Fl MU) 1. Network Security Spring 2017 50 / 125 Network Security Mechanisms Message Confidentiality (Security) Message Confidentiality/Security - Data Encryption Diffie-Hellman algorithm for session key generation I. Alice Bob r 1 - Both Alice and Bob know the values of N and G Q I Rl = Gx mod N Rl R2 = Gy mod N R2 O K= (R2) Shared secret key O 0 I K = (Rl)y mod N ř K - G^ mod N G and N are prime numbers, which both parties have to agree on • can be freely transmitted through the network the x and y are (private) large numbers chosen by the parties independently on each othe the computed K becomes the shared key used for the following symmetric encryption employed principle: (Gx mod Ny mod N = (Gy mod N)x mod N = Gxy mod N Luděk Matýska (Fl MU) 1. Network Security Spring 2017 51 / Network Security Mechanisms Message Confidentiality (Security) Message Confidentiality/Security - Data Encryption Diffie-Hellman algorithm for session key generation II. a weakness - suffers from a man-in-the-middle attack 9 can be avoided if Bob and Alice first authenticate each other Alice It" Fi, = gx mod p K, = (R,)xmod p p and g are public. Eve □ R2 = gz mod p K1 = (R^mod p K2= (R3)zmod p Alice-Eve key Bob R3 = gY mod p K2 = (R2)ymod p Eve-Bob key Luděk Matýska (Fl MU) K-| = gxz mod p K2 - gzv mod p 1. Network Security Spring 2017 Message Integrity Message Integrity Hash functions • encryption provides confidentiality, but not integrity • sometimes, the message does not need to be hidden (encrypted) - the only need is to keep it safe from any tampering • to preserve the integrity of a message, the message is passed through a hash function • an algorithm that creates a compressed "image" (fingerprint) of the message • so-called a message digest or a modification detection code (MDC) • the digest needs to be kept secret Hash function Message (Variable length) Message Digest (Fixed length) Luděk Matýska (Fl MU) 1. Network Security Spring 2017 53 / 125 3176 Network Security Mechanisms Message Integrity Message Integrity Hash function criteria * to be eligible for a hash, a function needs to meet the four criteria: 9 one-wayness - a message digest is created by a one-way hashing function • it must be impossible to recreate the message from the digest • resistance to weak collision - ensures that a message cannot easily be forged • one cannot easily modify the original message so that the new message hashes exactly to the same digest • resistance to strong collision - ensures that we cannot find two messages that hash to the same digest • called "strong" because the probability of a collision is higher than in the previous case • computation ease - it must be easy to compute the hash value for any given message • hash function examples: • MD5 (broken not secure), SHA-1, SHA-256, SHA-512, etc. Ludek Matyska (Fl MU) 1. Network Security Spring 2017 54 / 125 Network Security Mechanisms Message Integrity Message Integrity Message integrity check Alice Message and digest Digest Bob 3 Discard Luděk Matýska (Fl MU) 1. Network Security Spring 2017 55 / 125 Network Security Mechanisms Message Authentication Message Authentication Message Authentication • a process assuring the recipient that the message is from the source that it claims to be from • can be provided by: • symmetric cryptography - keyed hash functions, HMAC • asymmetric cryptography - digital signature Luděk Matýska (Fl MU) 1. Network Security Spring 2017 56 / Network Security Mechanisms Message Authentication Message Authentication Symmetric cryptography keyed hash functions are used • when creating the digest, such a function includes the symmetric key between the sender and receiver into the computation • ^> so-called Message Authentication Code (MAC) is computed • besides the message authentication, the message integrity is obviously ensured as well Alice Bob MAC function MAC Message and VI AC Luděk Matýska (Fl MU) 1. Network Security Spring 2017 57 / 125 Network Security Mechanisms Message Authentication Message Authentication Symmetric cryptography - HMAC • instead of keyed hash functions, a keyless hash function can also be used for message authentication • = hashed MAC (HMAC) • creates a MAC by applying a keyless hash function to the concatenation of the message and a symmetric key • i.e., a copy of the symmetric key is prepended to the message and this combination is hashed using a keyless hash function (e.g., SHA-1, SHA-256, etc.) mm Message :_i_i_i_i_i_i_i_i_■ - ■A ^—1m——:-„-—•■ - - -.........- Luděk Matýska (Fl MU) HMAC 1. Network Security Spring 2017 58 / 125 Network Security Mechanisms Digital Signature Digital Signature 9 MAC's/HMAC's main drawback: they require a symmetric key to be established between the sender and the receiver • =4> Digital Signatures - employ asymmetric cryptography to provide message authentication and integrity • besides, the message nonrepudiation is also provided Digital Signature 9 a message is "signed" (= encrypted) using the sender's private key • and "verified" (= decrypted) using the sender's public key • can be achieved in two ways: • signing the whole document - easier, but less efficient (for long messages) • signing a digest of the document • most commonly used • instead of signing the whole document, just the message's digest is signed Ludek Matyska (Fl MU) 1. Network Security Spring 2017 59 / Network Security Mechanisms Digital Signature Digital Signature Sender's side Alice Message 1 J Alice's private Hash I Message To Bob □ Digest Message plus signed digest Encrypt Signed digest Luděk Matýska (Fl MU) 1. Network Security Spring 2017 60 / 125 Network Security Mechanisms Digital Signature Digital Signature Receiver's side From Alice Alice's public T T Digest Bob □ Message Decrypt Compare Hash ■ ] Digest Luděk Matýska (Fl MU) 1. Network Security Spring 2017 61 / 125 Network Security Mechanisms Digital Signature Digital Signature Summary In a cryptosystem (to provide message confidentiality), we use the private and public keys of the receiver; in digital signatures (to provide message authentication /integrity/nonrepudiation), we use the private and public keys of the sender. • to combine both, the message is signed at first and later both the message and the signature are encrypted Luděk Matýska (Fl MU) 1. Network Security Spring 2017 62 / 125 Network Security Mechanisms Key Management and Distribution Key Management and Distribution How secret keys in symmetric-key cryptography and how public keys in asymmetric-key cryptography are distributed and maintained? Symmetric-key Distribution • the symmetric key needs to be shared between every two communicating parties • if Alice needs to exchange confidential messages with N people - she needs to maintain N different keys • if N people need to communicate with one another - a total of N • (N - l)/2 keys is needed • (each person needs to maintain N — 1 keys; since the keys are shared, we need "only" N • (N — l)/2 keys) • moreover, the keys' distribution is another problem • =4> a trusted party - Key Distribution Center (KDC) - is needed to reduce the number of keys Ludek Matyska (Fl MU) 1. Network Security Spring 2017 63 / 125 Network Security Mechanisms Key Management and Distribution Symmetric-key Management and Distribution Key Distribution Center (KDC) I. Key Distribution Center (KDC) • each person/entity establishes a shared secret key with the KDC 1. Network Security Spring 2017 64 / 125 Network Security Mechanisms Key Management and Distribution Symmetric-key Management and Distribution Key Distribution Center (KDC) II. Key Distribution Center (KDC) cont'd. o the process of sending a confidential message from Alice to Bob may proceed as follows: O Alice sends a request to KDC, stating that she needs a session (temporary) secret key between herself and Bob O KDC informs Bob of Alice's request O If Bob agrees, a session key is created between the two • once the communication is terminated, the session key is no longer valid • several approaches of creating the session key based on the previous ideas have been proposed 9 e.g., basic approach, Needham-Schroeder protocol, Otway-Rees protocol, etc. • for the following three slides, the following holds: • K/\ (Kb) ■ ■ ■ a symmetric key known only to A and S (resp. B and S) • R, Ra, Rb, Ri, R2 ■ ■ ■ nonces 9 Kab ■ ■ - the symmetric session key • example real implementation - Kerberos Luděk Matýska (Fl MU) 1. Network Security Spring 2017 65 / 125 Network Security Mechanisms Key Management and Distribution Symmetric-key Management and Distribution Key Distribution Center (KDC) III. - Basic Approach Alice n KDC Alice, Bob KAB i Alice, Bob, KAB G Alice, Bob, KAB Exchanging Data Using KAB Bob r ] Luděk Matýska (Fl MU) 1. Network Security Spring 2017 Network Security Mechanisms Key Management and Distribution Symmetric-key Management and Distribution Key Distribution Center (KDC) III. - Needham-Schroeder protocol Alice r : Alice ... R B RA, Alice, Bob. I RB RA, Bob, KAB I KAB, Alice, RB K ABl R, KDC KAB, Alice, RB kabI" Rlf R2 Bob r ] 0 Luděk Matýska (Fl MU) 1. Network Security Spr Network Security Mechanisms Key Management and Distribution Symmetric-key Management and Distribution Key Distribution Center (KDC) III. - Otway-Rees protocol Alice KDC R, Alice, Bob , I RA, R, Alice, Bob RB, R, Alice, Bob , RA, R, Alice , Bob R, RB, KAB , RA, KAB RA' KAB K AB| A message Ó Luděk Matýska (Fl MU) 1. Network Security Spring 2017 Network Security Mechanisms Key Management and Distribution Public-key Management and Distribution Public-key Distribution • in public-key cryptography, everyone shields a private key and advertises a public key • the public-key is freely available • Why a public-key distribution mechanism is needed, when the public-keys can be freely announced? • to protect the keys from forgery • the mechanism: the use of a trusted center - Certification Authority Luděk Matýska (Fl MU) 1. Network Security Spring 2017 69 / 125 Network Security Mechanisms Key Management and Distribution Public-key Management and Distribution Certification Authority (CA) Certification Authority (CA) • issues so-called public-key certificates 9 bind an entity (human, server, etc.) with its public key • to prevent the certificate itself from being forged, the CA signs the certificate with its private key • such a certificate can be freely published and distributed • anyone who wants to extract the public key from the certificate uses the CA's public key to extract it • when compromised, the previously issued certificates can be revoked • example: X.509 certificates • supports hierarchical structure to allow the use in the wide Internet • (= hierarchical trust model) • called Public Key Infrastructure (PKI) Luděk Matýska (Fl MU) 1. Network Security Spring 2017 70 / Network Security Mechanisms Key Management and Distribution Public-key Management and Distribution X.509 Certificates Optional Certificate Version Certificate Serial Number Certificate Algorithm Identifier for Certificate Issuer's Signature Issuer Validity Period Subject Subject Public-Key Information il Algorithm Identifier Public-Key Value Issuer Unique Identifier Subject Unique Identifier Extensions Certification Authority's Digital Signature ]\ Extension Fields (optional) Luděk Matýska (Fl MU) 1. Network Security Network Security Mechanisms Key Management and Distribution Public-key Management and Distribution Public Key Infrastructure (PKI) Root CA Level-2 CA1 Level-2 CA2 Level-2 CA3 I ,evel-2 CA4 Level-2 CAS Level-2 CA6 ► One of many definitions: a set of hardware, software, people, policies, and procedures needed to create, manage, store, distribute, and revoke certificates based on public key cryptography > each certificate is issued (and signed) only by a single party (= CA) • each CA certifies only its children • the CA's certificate itself may be signed by a different CA (all the way up to a "self-signed" root certificate) • ^> root certificates must be available to those who use a lower level CA certificate (root certificates are typically widely distributed) Ludek Matyska (Fl MU) 1. Network Security Spring 2017 72 / 125 Example Protocols Ensuring Network Security in the Internet Lecture overview U Introduction 9 Motivation 9 Network Security Elements Cryptography Introduction 9 Symmetric Cryptography 9 Asymmetric Cryptography VSV Network Security Mechanisms w Entity Authentication 9 Message Confidentiality (Security) 9 Message Integrity 9 Message Authentication 9 Digital Signature 9 Key Management and Distribution Example Protocols Ensuring Network Security in the Internet 9 Application-layer Security 9 Transport-layer Security 9 Network-layer Security 9 Link-layer Security Network & Data Protection - Maintaining the Availability 9 Firewalls 9 Intrusion Detection Systems 9 Denial of Service (DoS) & Distributed Denial of Service (DDoS) attacks 9 Virusses & Worms 9 Network & Data Protection - Concluding Remarks \SM Conclusion 1. Network Security Spring 2017 73 / 125 Luděk Matýska (Fl MU) Example Protocols Ensuring Network Security in the Internet Example Protocols Ensuring Network Security in the Internet • all the presented concepts can be realized on: • application layer - security mechanisms provided by applications (application protocols) themselves • e.g., PGP, SET, S/MIME, S-HTTP, etc. transport layer - SSL and TLS network layer - IPv6 & IPSec (IPv4) link layer - e.g., PPP 9 9 Luděk Matýska (Fl MU) 1. Network Security Spring 2017 Example Protocols Ensuring Network Security in the Internet Application-layer Security Application-layer Security Pretty Good Privacy (PGP) Pretty Good Privacy (PGP) • a de-facto standard proposed by Phil Zimmermann (1991) 0 the mechanism providing secure email communication channels © originally uses an alternative approach to PKI for distributing user's public keys - • decentralized trust model • identity certificates are digitally signed by other users who, by that act, endorse the association of that public key with the person/entity listed in the certificate • leaves the trust decisions in the hands of individual users • there are several levels of confidence which can be included in such signatures • later versions are able to use PKI as well • involves all the basic security mechanisms: • email confidentiality (using a symmetric one-time key because of performance -3DES, IDEA, etc.) • integrity (hash functions - MD5, SHA) • authentication (asymmetric cryptography - RSA) • non-repudiation (through the use of PKI) • « Digital Signatures Ludek Matyska (Fl MU) 1. Network Security Spring 2017 75 / 125 Web of Trust Example Protocols Ensuring Network Security in the Internet Application-layer Security Application-layer Security - PGP Sender's side Sender site (Alice) Digital signature Privacy Email Alice's private Ü Hash 11 I [-Encrypt Digest Signed digest Encrypted (secret key & message + digest) Figure : The mechanism of signing and encrypting the sending message (sender's side). Luděk Matýska (Fl MU) 1. Network Security Spring 2017 76 / 125 Example Protocols Ensuring Network Security in the Internet Application-layer Security Application-layer Security - PGP Receiver's side Encrypted (secret key & message + digest) Receiver site (Bob) Bobs private Encrypted (secret key) Decrypt Encrypted (message + digest) One-time secret key I ■>-| Decrypt J | | Email Alice's public,. f Decrypt Hash Compare Digest Digest Figure : The mechanism of decrypting and verifying the received message (receiver's side). Luděk Matýska (Fl MU) 1. Network Security Spring 2017 77 / 125 Example Protocols Ensuring Network Security in the Internet Application-layer Security Application-layer Security Secure Electronic Transactions (SET) I. Secure Electronic Transactions (SET) • a specialized cryptographic protocol developed by a group of companies (Visa, Microsoft, IBM, MasterCard, etc.) • designed for securing credit card transactions over insecure networks • NOT for a general encryption • design goals: • confidentiality of payment and ordering information • integrity of all transmitted data • authentication of all card holders • ensuring that a merchant can accept card transactions based on buyer's relationship with her financial institution • the merchant does not need to know the buyer's identity • creating protocols that neither depend on transport security mechanism nor prevent their use Ludek Matyska (Fl MU) 1. Network Security Spring 2017 78 / 125 Example Protocols Ensuring Network Security in the Internet Application-layer Security Application-layer Security Secure Electronic Transactions (SET) II. Customer t 1. Customer browses and decides to purchase. 2. SET sends order and payment information. 7. Merchant completes order. 9. Issuer sends credit card bill to customer. Customer's bank ("issuer") 3. Merchant forwards payment information to bank. 4. Bank checks with issuer for payment authorization. 5. Issuer authorizes payment. Merchant 6. Bank authorizes payment. 8. Merchant captures transaction. B A N ZTJ~ K ■u 0 0 Merchant's bank Figure : The SET transactions outline. 1. Network Security Spring 2017 Example Protocols Ensuring Network Security in the Internet Application-layer Security Application-layer Security S/MIME and S-HTTP Secure/Multipurpose Internet Mail Extension (S/MIME) o a standard for public key encryption and signing of MIME data o MIME - Internet standard that extends the format of e-mail to support, e.g., text in character sets other than ASCII, non-text attachments (pictures, video, audio, etc.), message bodies with multiple parts, etc. • provides authentication, message integrity and non-repudiation of origin (using digital signatures) and privacy and data security (using encryption) Secure-HTTP (S-HTTP) • extends the Hypertext Transfer Protocol (HTTP) to support encryptions and digital signatures • extends the negotiation between the client browser and the server to include the negotiation for security matters • uses additional headers for message encryption, digital certificates, and authentication in the HTTP format • the HTTP headers are encapsulated into the S-HTTP headers • has been bundled away by the HTTPs (HTTP over SSL/TLS) Ludek Matyska (Fl MU) 1. Network Security Spring 2017 80 / 125 Example Protocols Ensuring Network Security in the Internet Transport-layer Security Transport-layer Security - SSL/TLS I. Secure Sockets Layer (SSL) / Transport Layer Security (TLS) • the protocols for ensuring secure communication channels on the transport layer • (SSL precedes the TLS) • SSL 3.0 « TLS 1.0 (but see Poodle attack) 9 SSL/TLS provide secure and authenticated data paths between servers and clients: • data encryption - protect data in transport between the client and the server from interception (making them readable only by the intended recipient) • server and client authentication - the SSL uses standard public key encryption to authenticate the communicating parties to each other • message integrity - achieved through the use of session keys so that data cannot be intentionally/unintentionally tampered a main drawback: the necessity to adapt the applications (applications' protocols) • HTTP -> HTTPS (HTTP Secure) • FTP FTPS (FTP Secure) • etc. Ludek Matyska (Fl MU) 1. Network Security Spring 2017 81 / 125 Example Protocols Ensuring Network Security in the Internet Transport-layer Security Transport-layer Security - SSL/TLS II. Application Layer Change Cipher Specification SSL Alert Protocol SSL Handshake Protocol SSL Record Protocol SSL TCP Protocol IP Protocol Figure : The SSL protocol stack. Luděk Matýska (Fl MU) 1. Network Security Spring 2017 82 / 125 Example Protocols Ensuring Network Security in the Internet Transport-layer Security Transport-layer Security - SSL/TLS III. Before any SSL connection can be established, there must be a handshake performed: Browser Web Server 1 Algorithms I support. My random number. ^Verify certificate and ^ extract seiver's public key. Enciypt pi e-master secret with seiver's public key. Use this algorithm. My random niimher. My digital certificate. V_J Deciypt pi e-master secret with seiver's private key. Compute secret key. Compute secret key. Send checksum of handshake messages using secret key. V_J Compare checksum on seiver side. Compare checksum on client side. r ^ Send checksum of handshake messages using secret key. V___J Figure : The SSL handshake (steps 5 and 6 verify the integrity of the handshake; the communication is encrvpted usin^^svrrurietric (sessior^kev^^^^^^^^^^^^^^^^^^^^^^^^^ Luděk Matýska (Fl MU) 1. Network Security Spring 2017 83 / 125 Example Protocols Ensuring Network Security in the Internet Network-layer Security Network-layer Security - IPv6 & IPSec (IPv4) I. IP Security - IPv6 & IPSec (IPv4) • a set of protocols providing secured communication channels on the network layer • Authentication Header (AH) protocol - designed for ensuring sender's and receiver's authentication and communication integrity (NOT for communication confidentiality) • Encapsulating Security Payload (ESP) protocol - designed for providing sender's authentication, communication integrity and confidentiality • can be used independently or in combination • establishes logical channels (called Security Associations, SAs) • always one-way channels (two channels are needed for duplex communication) • identified by: • protocol identifier (AH or ESP), source IP address, and channel identification (so-called Security Parameter Index, SPI) 9 operates in 2 modes: • Transport mode - IPSec header is inserted between IP header and message body • Tunnel mode - IPSec header is inserted in front of the original IP header; subsequently, a new IP header is created Ludek Matyska (Fl MU) 1. Network Security Spring 2017 84 / 125 Example Protocols Ensuring Network Security in the Internet Network-layer Security Network-layer Security - IPv6 & IPSec (IPv4) II. IP Security - IPv6 & IPSec (IPv4) cont'd. • key distribution: • Internet Key Exchange (IKE) - used to set up an SA (RFC 4306 for v2) • uses X.509 certificates for authentication and Diffie-Hellman key exchange to set up a shared session secret • Internet Security Association and Key management Protocol (ISAKMP) - a framework for authentication and key exchange (RFC 2408) • designed to be key exchange independent (IKE or other protocols can be used to provide authenticated keying material) • advantages: secures all the data flows between two communicating parties; it is not necessary to adapt applications (application protocols) • drawbacks: there are no automated mechanisms for cryptographic keys' management • further information: • see IPv6 section in PA159 • see the animation (ongoing BP Thesis =4> will be available in a month): http://frakira.fi.muni.cz/~jeronimo/vyuka/IPSec Ludek Matyska (Fl MU) 1. Network Security Spring 2017 85 / 125 Example Protocols Ensuring Network Security in the Internet Network-layer Security Network-layer Security - IPv6 & IPSec (IPv4) III Transport vs. Tunnel mode IP Header í The rest of the packet IP Header IPsec Header The rest of the packet Figure : Transport mode. Payload for new IP header Figure : Tunnel mode. IP Header The rest of the packet \ New IP Header IPsec Header IP Header The rest of the packet Luděk Matýska (Fl MU) 1. Network Security Spring 2017 86 / 125 Example Protocols Ensuring Network Security in the Internet Network-layer Security Network-layer Security - IPv6 & IPSec (IPv4) IV. Virtual Private Networks (VPNs) I. Virtual Private Network (VPN) • a computer network that uses a public telecommunication infrastructure (such as the Internet) to provide remote offices or individual users with secure access to their organization's network • using a secure cryptographic method, it encapsulates data transfers between two or more networked devices which are not on the same private network • in order to keep the transferred data private • the VPN technology provides the following activities: • IP encapsulation - involves enclosing TCP/IP data packets within another packet with an IP-address of either a firewall or a server that acts as a VPN endpoint • various tunneling mechanisms: IPSec ESP tunnel, Point-to-Point Tunneling protocol (PPTP), Layer 2 Tunneling Protocol (L2TP), PPP over SSL and PPP over SSH, etc. • Encryption - used to obfuscate the contents of the encapsulated data • Authentication - used to determine whether or not the endpoint can participate in the encrypted tunnel • may also be used to exchange the secret or public key used for payload ^^^^^^^^^^^^encmDtior^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Ludek Matyska (Fl MU) 1. Network Security Spring 2017 87 / 125 Example Protocols Ensuring Network Security in the Internet Network-layer Security Network-layer Security - IPv6 & IPSec (IPv4) IV. Virtual Private Networks (VPNs) II. Laptop Laptop Protected Network Protected Network Luděk Matýska (Fl MU) 1. Network Security Spring 2017 88 / Example Protocols Ensuring Network Security in the Internet Link-layer Security Link-layer Security Point-to-Point Protocol (PPP) Point-to-Point Protocol (PPP) o a data link protocol commonly used in establishing a direct connection between two networking nodes • limited to a single data link • provides connection authentication, transmission encryption (confidentiality), and compression • several authentication protocols can be used (PAP, CHAP, EAP, etc.) • transmission encryption - DES or 3DES • most commonly used forms: • Point-to-Point Protocol over ATM (PPPoA) • Point-to-Point Protocol over Ethernet (PPPoE) • both serve to establish a DSL line connection with an ISP Luděk Matýska (Fl MU) 1. Network Security Spring 2017 89 / Network & Data Protection - Maintaining the Availability Lecture overview U Introduction 9 Motivation 9 Network Security Elements Cryptography Introduction 9 Symmetric Cryptography 9 Asymmetric Cryptography VSV Network Security Mechanisms w Entity Authentication 9 Message Confidentiality (Security) 9 Message Integrity 9 Message Authentication 9 Digital Signature 9 Key Management and Distribution Example Protocols Ensuring Network Security in the Internet 9 Application-layer Security 9 Transport-layer Security 9 Network-layer Security 9 Link-layer Security Network & Data Protection - Maintaining the Availability 9 Firewalls 9 Intrusion Detection Systems G Denial of Service (DoS) & Distributed Denial of Service (DDoS) attacks • Virusses & Worms 9 Network & Data Protection - Concluding Remarks Conclusion Ludek Matyska (Fl MU) 1. Network Security Spring 2017 90 / 125 Network & Data Protection - Maintaining the Availability Network&Data Protection - Maintaining the Availability I • all the previous security mechanisms cannot prevent Eve from sending a harmful message to a system a network & data protection - a complicated problem without a simple solution • authentication and encryption mechanisms are just technical fundamentals • organizational and social aspects are needed • humans (users) are usually the weakest elements =^> social engineering • possible threats: • accessing private data • modification of private or public data • including their removal (e.g., web pages) • undesired interferences to the network traffic/operation • including services' denial (so-called Denial of Service attacks) Ludek Matyska (Fl MU) 1. Network Security Spring 2017 91 / 125 Network & Data Protection - Maintaining the Availability Networks Data Protection - Maintaining the Availability A bit of History Public Internet use explodes -World Wide Web is born ■ AOL brings e-mail to masses IBM PC released • Home computers widely ■ available First microcomputers created First e-mail message sent Intel develops first microprocessor DARPA Internet project is born - ENIAC, the first digital ■ computer, is developed Ludek Matvska (Fl MIT 2005 1995 - 1985 1975' 1965 1955 1945 • Network Security Foundations published CERT reports 52,000 Internet hacks CERT reports 10,000 Internet hacks ■ First Office document viruses appear - DARPA funds "Firewall Toolkit" • CERT reports six Internet hacks ■ First computer virus developed - Movie War Games popularizes hacker culture Modems usher in Era of Hacking DES encryption developed Public key encryption developed Network Security Spring 2017 92 / 125 Network & Data Protection - Maintaining the Availability Network&Data Protection - Maintaining the Availability II Attack/Intrusion a deliberate unauthorized attempt, successful or not, to break into, access, manipulate, or misuse some valuable property and where the misuse may result into or render the property unreliable or unusable The attack/intrusion process consists of few stages: • Reconnaissance - the process of gathering information about the target system and the details of its workings and weak points • a scanning program sends network traffic to all/selected computers and expects receiving return traffic that will indicate whether those computers have known vulnerabilities Physical Intrusion to acquire/modify private information, and/or Denial of Service to crash a service (or a machine), overload network links or machines' CPU, fill up a disk, etc. Luděk Matýska (Fl MU) 1. Network Security Spring 2017 93 / 125 Network & Data Protection - Maintaining the Availability Network&Data Protection - Maintaining the Availability m The protection from exploits has to be implemented on: • physical level • access protection • software level 9 authentication • encryption • traffic monitoring and instant reaction to incidents 9 juridical level • a definition of desired and undesired behaviour The basic security mechanisms for network protection: • Firewalls • Intrusion Detection Systems • Antiviruses Luděk Matýska (Fl MU) 1. Network Security Spring 2017 94 / 125 Network & Data Protection - Maintaining the Availability Firewalls Firewalls I. Firewall • a primary mean of securing a private network against penetration • firewall = a hardware, software, or a combination of both that monitors and filters traffic packets that attempt to either enter or leave a protected private network • i.e., interconnects networks with different trust • creates a perimeter defense designed to protect information resources of an organization Network & Data Protection - Maintaining the Availability Firewalls Firewalls II. What a firewall can do... a implement security policies network access protection) at a single point • only authorized traffic is allowed to access the network/services • (or leave the network) • monitor security-related events (audit, log) • alarms for abnormal behavior can be implemented Luděk Matýska (Fl MU) 1. Network Security Spring 2017 96 / Network & Data Protection - Maintaining the Availability Firewalls Firewalls I. and what a firewall cannot do... • protect against attacks that bypass the firewall o e.g., dial-out from internal host to an ISP • protect against internal threats • disgruntled employee • an insider cooperates with an external attacker • protect against the transfer of virus-infected programs or files • not including application gateways, which may be able to do so Luděk Matýska (Fl MU) 1. Network Security Spring 2017 97 / 125 Network & Data Protection - Maintaining the Availability Firewalls Firewalls IV. Firewalls' Classification Basic firewalls' classification: • Packet filtering firewalls - operate on network layer • Circuit level gateways - operate on session/transport layer • Application gateways (or proxy servers) - operate on application layer • Dynamic packet filtering firewalls (or Session filtering firewalls) 9 a combination of the three above • these technologies operate at different levels of detail, providing varying degrees of network access protection Luděk Matýska (Fl MU) 1. Network Security Spring 2017 98 / Network & Data Protection - Maintaining the Availability Firewalls Firewalls V. Packet Filtering firewalls Packet Filtering firewalls • decisions are made on per-packet basis a no state information is maintained o applies packet filters based on access rules defined by the following parameters: • source address • destination address • application or protocol/next header (TCP, UDP, etc.) • source port number • destination port number • advantages: 9 simple, low cost, fast, transparent to users • disadvantages: • cannot prevent attacks that employ application-specific vulnerabilities or functions • because they do not examine upper-layer data Ludek Matyska (Fl MU) 1. Network Security Spring 2017 99 / Network & Data Protection - Maintaining the Availability Firewalls Firewalls V. Dynamic Packet Filtering (Session Filtering) firewalls I. Dynamic Packet Filtering (Session Filtering) firewalls • traditional packet filters do not examine higher layer context • i.e., matching the incoming (returned) packets with an outgoing flow 9 dynamic packet filtering examines and maintains a context of each packet • they keep track of client-server connection • ^> a connection table (so-called State table) is maintained • packet decision is made in the context of a connection • if a packet establishes a new connection, it is checked against a policy • if a packet is a part of an existing connection, it is matched up in the state table • advantages: • transparent to users • low CPU overheads • for all the packets (except the first one) belonging to the same connection, no policy database lookups are performed Luděk Matýska (Fl MU) 1. Network Security Spring 2017 100 / 125 letwork & Data d ^ata Protect/on - F'rewa//S V D^'c Packet 'F Uint^S the Ava/,ab, l/ty F ng CSessíon Fí/tenWl r Network & Data Protection - Maintaining the Availability Firewalls Firewalls V. Circuit Level Gateways I. Circuit Level Gateways • work at the session layer of the ISO/OSI model (TCP layer of the TCP/IP model) • monitor TCP handshaking between packets to determine whether a requested session is legitimate • do not permit an end-to-end TCP connection • rather, the gateway sets up two TCP connections • one between itself and a TCP user on an inner host, and • one between itself and a TCP user on an outside host • once the two connections are established, the gateway typically relays TCP segments from one to the other without examining the contents • usage example: • hiding information about interna I/protected networks • non-requested data from outside the firewall is not allowed in - all ports are closed until the firewall opens them • e.g., requests from protected network pass through the gateway, which intercept and record them • once the answer reaches the gateway, it is compared to the original request to _see if the IP address and the port match up_ Ludek Matyska (Fl MU) 1. Network Security Spring 2017 102 / 125 Network & Data Protection - Maintaining the Availability Firewalls Firewalls V. Circuit Level Gateways II Circuit Level Gateways cont'd. • a combination of circuit-level gateway with Internet sharing = Network Address Translation (NAT) • originally a reaction to IPv4 address exhaustion • but the NAT is not a firewall on itself! Network & Data Protection - Maintaining the Availability Firewalls Firewalls V. Circuit Level Gateways III. 5 Application 4 Transport Control Protocol (TCP) Internet Protocol (IP) 2 Data Link 1 Physical Incoming Traffic 0 DissailowutJ Allowed Traffic is filtered based on specified session rules, such as when a session is initiated by a recognised computer Unknown traffic is only allowed up to level 4 of the Network Stack. Allowed Outgoing Traffic Luděk Matýska (Fl MU) 1. Network Security Spring 2017 104 / 125 Network & Data Protection - Maintaining the Availability Firewalls Firewalls V. Application Gateways I. Application Gateways • similar to circuit-level gateways except that they are application specific • i.e., tailored to a specific application program • every connection between two networks is made via an application program called a proxy • proxies are application/protocol specific • they investigate the content of the passing flows • connection state is maintained and updated • only protocols that have specific proxies configured are allowed through the firewall (all other traffic is rejected) • e.g., a gateway that is configured to be a web proxy will not allow any FTP, telnet or other traffic through Application-level gateway Luděk Matýska (Fl MU) 1. Network Security Spring 2017 105 / 125 Network & Data Protection - Maintaining the Availability Firewalls Firewalls V. Application Gateways II. Application Gateways cont'd. • usage example: 9 HTTP proxies (URL blocking), SMTP proxies (virus scanning, spam identification), DNS proxies, etc. • advantages: 9 more secure than packet filtering firewalls • can investigate the content of the flows • can protect against protocol errors • it is easy to log and audit all incoming/outgoing traffic • disadvantages: • very CPU intensive lower performance • require high performance host computer • more vulnerable to DoS attacks (see later) • problematic for encrypted data (including IPSec) Ludek Matyska (Fl MU) 1. Network Security Spring 2017 106 / 125 Network & Data Protection - Maintaining the Availability Firewalls Firewalls VI. Concluding Remarks • firewalls cannot serve as a panacea to network security threats • many security attacks led from within the internal (not protected) network • increase the risk of rapid infection spread • false safety feeling • the internal network is not usually sufficiently protected • users become lazy • usually cause a slowdown on high-speed networks o their functionality is very useful for interrupting the ongoing attack o application proxies: • risk of faults (e.g., false virus detection) • the importance of privacy protection Luděk Matýska (Fl MU) 1. Network Security Spring 2017 107 / Network & Data Protection - Maintaining the Availability Intrusion Detection Systems Intrusion Detection Systems (IDS) I. • network perimeter security technologies (i.e., firewalls) and anti-malicious software technologies (i.e., antiviruses, see later) cannot stop attackers if they obtain authenticated access to target computers and log on to them as if they are legitimate users • (i.e., they had obtained login information of a legitimate user) • it is desirable (and often necessary) to detect intrusion activities by monitoring ingress packets that have passed through firewalls and analyze how users use their computers • Intrusion Detection Systems (IDS) and Honeypots Intrusion Detection Systems (IDS) « a system used to detect unauthorized intrusions into computer systems and networks • based on an assumption that the behavior of the intruder differs from that of a legitimate user • they collect information from a variety of system and network sources and look for attack signatures • = specific patterns that usually indicate malicious or suspicious intent Ludek Matyska (Fl MU) 1. Network Security Spring 2017 108 / 125 Network & Data Protection - Maintaining the Availability Intrusion Detection Systems Intrusion Detection Systems (IDS) II. Classification IDS classification: • different ways of classifying an IDS • IDSs based on detection model: • anomaly detection • signature based misuse (misuse detection) • hybrid • IDSs based on scope: • host-based • multihost-based • network-based • IDSs based on operation: 9 offline - inspect system logs at set intervals • online - monitor the system continuously Luděk Matýska (Fl MU) 1. Network Security Network & Data Protection - Maintaining the Availability Intrusion Detection Systems Intrusion Detection Systems (IDS) III. Anomaly Detection Anomaly Detection IDSs: • model the normal usage of the network as a noise characterization o anything distinct from the noise (atypical behavior) is assumed to be an intrusion activity • e.g., flooding a host with lots of packet • the primary strength is its ability to recognize novel attacks 9 drawbacks: • assume, that intrusions will be accompanied by manifestations that are sufficiently unusual • generate many false alarms • =4> compromise the effectiveness of the IDS Luděk Matýska (Fl MU) 1. Network Security Spring 2017 110 / 125 Network & Data Protection - Maintaining the Availability Intrusion Detection Systems Intrusion Detection Systems (IDS) III. Misuse Detection Misuse Detection IDSs: • recognize known attacks based on signatures 9 a set of attack signatures has to be defined (and updated) • if an action matching a signature is detected, it is considered to be an attack o drawbacks: • unable to detect novel attacks • suffer from false alarms • have to be programmed again for every new pattern to be detected Luděk Matýska (Fl MU) 1. Network Security Spring 2017 111 / 125 Network & Data Protection - Maintaining the Availability Intrusion Detection Systems Intrusion Detection Systems (IDS) III. Host-based & Multihost-based IDSs I. Host-based IDSs: • host operating system (or an application) logs in the audit information • e.g., use of identification and authentication mechanisms (logins, etc.), file opens and program executions, admin activities, etc. 9 the audit is then analyzed to detect trails of intrusion Multihost-based IDSs: • audit information is analyzed from multiple hosts a analysis architecture: • centralized - all data shipped to a central location for analysis • hierarchical - data is analyzed as it passed up through the layers • distributed - distributed analysis of the data Ludek Matyska (Fl MU) 1. Network Security Spring 2017 112 / 125 Network & Data Protection - Maintaining the Availability Intrusion Detection Systems Intrusion Detection Systems (IDS) III. Host-based & Multihost-based IDSs II. Host-based & Multi host-based IDSs: cont'd. • advantages: • can detect data that are encrypted during transmissions • do not need special hardware devices • check system logs and so can analyze system behavior more accurately • disadvantages: 9 are installed in the target systems, and so they require extra system managing • may consume extra computing resources on the systems • might become affected by attacks that affect the host computers/servers they are installed in Luděk Matýska (Fl MU) 1. Network Security Spring 2017 113 / 125 Network & Data Protection - Maintaining the Availability Intrusion Detection Systems Intrusion Detection Systems (IDS) III. Network-based IDSs Network-based IDSs: 9 look for attack signatures in network traffic via a promiscuous interface 9 a filter is usually applied to determine which traffic will be discarded or passed on to an attack recognition module • to filter out known un-malicious traffic • advantages: • low cost - usually small number of selected points to monitor the entire network • no interference - packets are monitored passively (it does not interfere normal network traffic) • intrusion resistent - usually a small system, which can be easily made to resist an intrusion • disadvantages: • may not be able to analyze encrypted packets • may not be able to handle large volume of network traffics in time • some intrusion activities (e.g., fragmentation-attack) are hard to identify • hard to determine, whether the intrusion activity has been successfully carried out Luděk Matýska (Fl MU) 1. Network Security Spring 2017 114 / 125 Network & Data Protection - Maintaining the Availability Intrusion Detection Systems Intrusion Detection Systems (IDS) IV. Concluding Remarks • Intrusion Detection Systems are only one piece of the whole security puzzle • they must be supplemented by other security and protection mechanisms • they are a very important part of security architecture but do not solve all the potenciál problems Luděk Matýska (Fl MU) 1. Network Security Spring 2017 115 / Network & Data Protection - Maintaining the Availability Intrusion Detection Systems Honeypots Honeypot o a system designed to teach how intruders probe for and exploit a system • by learning their tools and methods, one can better protect her network and systems • usually used for: 9 diverting an attacker from accessing critical systems • collecting information about the attacker's activity • encouraging the attacker to stay on the system long enough for administrators to respond • based on virtual or real systems Luděk Matýska (Fl MU) 1. Network Security Spring 2017 116 / 125 Network & Data Protection - Maintaining the Availability Intrusion Detection Systems Honeypots "Tracking Their Moves" I. "Tracking Their Moves" • do not log information on the honeypot itself • the fewer modification you make to the honeypot, the better • the more changes you make, the better the chance an intruder will discover something is up • you can easily lose the information • track in layers, do not depend on a single source of information 9 first layer of tracking is the firewall logs • second layer is the system logs 9 third layer of tracking is to use a sniffer 9 it picks up all keystrokes and screen captures • run, e.g., the Tripwire on the honeypot • to discover what binaries have been altered on a compromised system Luděk Matýska (Fl MU) 1. Network Security Spring 2017 117 / Network & Data Protection - Maintaining the Availability Intrusion Detection Systems Honeypots "Tracking Their Moves" II. "Tracking Their Moves" cont'd. • do not mindlessly reinstall the compromised system!!! • otherwise you'll lose the information about the security hole the intruder had exploited • if possible, do not reboot the compromised system • running malicious programs may not automatically start after the reboot • if possible, do not disconnect the compromised system from the network • the system, once being disconnected from the network, may close all the active network connections • better way is to cut off the system on the closest firewall • or disconnect it behind first network element (switch, router, etc.) Ludek Matyska (Fl MU) 1. Network Security Spring 2017 118 / 125 Network & Data Protection - Maintaining the Availability attacks Denial of Service (DoS) & Distributed DoS (DDoS) I. Denial of Service (DoS) attack: • an attack that causes a loss of a service to users • typically the loss of network connectivity and services by consuming the bandwidth of the victim's network or overloading the computational resources of the victim's system • the flood of incoming messages essentially forces the target system to shut down (thus denying the service) • attack lead from a single source • not too dangerous - can be stopped in the closest active network element • attack lead from many sources = Distributed Denial of Service (DDoS) attack • a synchronized attack from many sources (e.g., Botnets) • hard to discover - all the requests appear to be sent by legitimate users • much more dangerous o stopping requires a cooperation in the network o stopping in active networks - consecutive cut of flows against their direction Luděk Matýska (Fl MU) 1. Network Security Spring 2017 119 / 125 v- I I I a I W I >w»^l V I V-V-. ^L/U*J ^ OÍ. L/IOLI Ik/U U^-^J I—-' v- I I I CM W I sJtilV IV-I L/L/W^ Network & Data Protection - Maintaining the Availability attacks Denial of Service (DoS) & Distributed DoS (DDoS) II. M.i%Ecr $crvcr Luděk Matýska (Fl MU) 1. Network Security Spring 2017 120 / 125 Network & Data Protection - Maintaining the Availability Virusses & Worms Virusses & Worms I. Computer virus a self-propagating computer program designed to alter or destroy a computer system resource Worm a self-replicating program, similar to a computer virus - a virus attaches itself to, and becomes part of, another executable program; however, a worm is self-contained and does not need to be part of another program to propagate itself (through security holes of a networked system) Virus/Worm attacks: • some sort of trigger will activate the attack phase, and the virus will then "do something" • trigger = a specific date, or the number of times the virus has been replicated, or anything similar • "do something" = anything from printing a silly message on the screen to erasing all of your data Spring 2017 121 / 125 Luděk Matýska (Fl MU) 1. Network Security Network & Data Protection - Maintaining the Availability Virusses & Worms Virusses & Worms I. Protection from virus/worm attacks: • run a secure operating system with access rights • security features keep viruses away » run virus protection software • in end-nodes and/or application gateways • avoid programs from unknown sources • educating the users is a must • = computer hygiene Luděk Matýska (Fl MU) 1. Network Security Spring 2017 122 / 125 Network & Data Protection - Maintaining the Availability Network & Data Protection - Concluding Remarks Network & Data Protection - Concluding Remarks • attacks/intrusions - an effort to acquire an access to a network or its services • reasons range from boyish fun ("testing neighbor's pears") to military/terroristic actions • usage: • private data access/modification • source platform for subsequent activity (e.g., DDoS) • protection: 9 access control on all possible levels • regular maintanance (patches, upgrades, etc.) • network traffic monitoring • monitoring of processes running on the servers/end-nodes • users' education Ludek Matyska (Fl MU) 1. Network Security Spring 2017 123 / 125 Lecture overview Introduction • Motivation 9 Network Security Elements Cryptography Introduction 9 Symmetric Cryptography 9 Asymmetric Cryptography Network Security Mechanisms 9 Entity Authentication 9 Message Confidentiality (Security) 9 Message Integrity 9 Message Authentication 9 Digital Signature 9 Key Management and Distribution Example Protocols Ensuring Network Security in the Internet 9 Application-layer Security 9 Transport-layer Security 9 Network-layer Security w Link-layer Security Network & Data Protection - Maintaining the Availability 9 Firewalls 9 Intrusion Detection Systems • Denial of Service (DoS) & Distributed Denial of Service (DDoS) attacks 9 Virusses & Worms • Network & Data Protection - Concluding Remarks o Conclusion Recapitulation - Network Security • AAA mechanisms + secured communication mechanisms + data/services protection/availability 9 features of a secured communication network: • Confidentiality • Integrity • Non-repudiation • symmetric (shared key) and asymmetric (key pair - private and public) cryptography • secured communication mechanisms can be provided on various ISO/OSI layers (application, transport, network, data link) • further information: • PV017: Information Technology Security (doc. Staudek) • PV079: Applied Cryptography (prof. Matyáš et al.) • PV080: Protection of Data and Information Privacy (prof. Matyáš) • PV157: Authentication and Access Control (prof. Matyáš and dr. Říha) 9 PV210: Security analysis of network traffic (RNDr. Vykopal) • etc. Luděk Matýska (Fl MU) 1. Network Security Spring 2017 125 /