The Official Unofficial Zorp project
 
Overview| Examples| Bugs| FAQ | White papers | Download | Help wanted | SourceForge Project page | Filltable utility  
 
 
SourceForge.net: SF.net Project News: Zorp unofficial
  • zorp 2.0.9-6 has been released
  • iptables-utils zorp-unoff version has been released
  • New whitepaper, even more FAQs
  • Zorp whitepapers released, new FAQs
  • New tproxy versions
  • New Zorp version: get the DN
  • The best bughunter
  • Bughunting contest extended
  • Valentine day bughunting contest!
  • Site updates: FAQ, design
  • SourceForge.net: Project File Releases: Zorp unofficial
  • zorp 2.0.9-6 released (Mon, 01 Nov 2004 21:49:58 GMT)
  • zorp 2.0.9-6 released (Mon, 01 Nov 2004 21:40:56 GMT)
  • iptables-utils 1.21-1 released (Mon, 01 Nov 2004 21:19:42 GMT)
  • zorp 2.0.9-1 released (Sat, 12 Jun 2004 00:00:00 GMT)
  • zorplibll 2.0.26.24-1 released (Sat, 12 Jun 2004 00:00:00 GMT)
  • zorp zorp_2.0.8-1 released (Thu, 11 Dec 2003 00:00:00 GMT)
  • zorp zorp_2.0.7-2 released (Wed, 03 Dec 2003 00:00:00 GMT)
  • zorp zorp_2.0.7-1 released (Tue, 11 Nov 2003 00:00:00 GMT)
  • zorplibll zorplibll_2.0.26.23-1 released (Mon, 10 Nov 2003 00:00:00 GMT)
  • download
    
    Introduction
    ------------
    
    This paper is part of the "Zorp Anatomy" series of articles and as such it
    gives some background information about the Authentication/Authorization
    subsystem of Zorp. It is intended for advanced Zorp users, those interested
    in what behind the scene is.
    
    Identification, Authentication & Authorization
    ----------------------------------------------
    
    Access control is usually performed in three steps:
    
    1) identification: the subject sends its 'name' to the access control
       system (the word 'name' might refer to many things, real name, username,
       DN, social id number; anything that uniquely identifies the subject)
    
    2) authentication: the access control system verifies the 'name' received in
       the identification phase in some way. Authentication can involve the user
       giving its password, signing a blob with its private key or entering a
       response to a challenge presented by the access control system.
    
    3) authorization: based on the information returned by the authentication
       phase a decision must be made whether the given subject might access the
       object in question. This phase is usually implemented by access control
       lists (or ACLs for short), which is a list of "subject (s) might access
       to object (o) for operation (a)". The basic example for authorization is
       the access control system for file systems. (think of the standard Unix
       user/group/other authorization scheme)
    
    Network interpretation of subjects and objects
    ----------------------------------------------
    
    The interpretation of subjects and objects might greatly depend on our
    actual application. In simple cases it is enough to assume that each client
    computer in our corporate intranet is equivalent to the user sitting in
    front of that computer. The IP address of this computer and the fact that it
    is able to communicate with that IP address identifies (the IP address) and
    authenticates (it is able to communicate with the firewall) the user. 
    
    In more complex situations we want to identify real persons by their
    username independenly from the computer they are using, authenticating them
    by password or X.509 certificates.
    
    An object is a more difficult matter, in simple cases an object is an IP
    address, or an IP address and a port combination (service running on a
    host). In even more complex situations we might want even more granularity
    and want to identify the different directories on a file server.
    
    Authorization in Zorp
    ---------------------
    
    The simple IP based authorization and the user based authorization can
    nicely coexist, though they are implemented in different Zorp components.
    
    Zorp has zones & services to map IP/port based authorization and has
    AuthPolicy and Authorization lists for user/group based authorization.
    
    The first is detailed in other Zorp documentation thus is not described
    here, let us concentrate on the second part.
    
    AuthPolicy objects
    ------------------
    
    When the administrator requires user level control on various services, she
    needs to create an authentication/authorization policy. Each AuthPolicy has
    a name to make it easy to refer to different authentication policies and
    it encapsulates an authentication and an authorization part. 
    
    Example:
    
    	AuthPolicy('dmz-intra', 
    		   authentication=...,
    		   authorization=...)
    
    	Service('dmz_HTTP_intra', HttpProxy,
    		auth_policy='dmz-intra')
    
    The authentication part performs identification & authentication and results
    in a verified entity name and associated group list. There can be several
    authentication methods in Zorp each derived from the AbstractAuthentication
    class. Currently there are two different authentication classes:
    SatyrAuthentication and InbandAuthentication. Those are described in the
    next sections.
    
    The authorization part takes the information returned by the first phase and
    verifies whether services associated with this AuthPolicy can be accessed by 
    the identified 'subject'. 
    
    For example:
    
    	AuthPolicy('dmz-intra',
    		   authentication=SatyrAuthentication('zasdb'),
    		   authorization=BasicAccessList(
    		           ((Z_BACL_SUFFICIENT, PermitUser('userA')),
    		            (Z_BACL_SUFFICIENT, PermitUser('userB')),
    		            (Z_BACL_REQUIRED, PermitGroup('group1')))))
    
    	Service('dmz_HTTP_intra', HttpProxy,
    		auth_policy='dmz-intra')
    	Service('dmz_IMAP_intra', ImapProxy,
    		auth_policy='dmz-intra')
    
    
    This example creates a new AuthPolicy, named 'dmz-intra', authenticating via
    the Satyr authentication framework to an authentication database named
    'zasdb', and each subject is allowed to use the service 'dmz_HTTP_intra' who
    is either called 'userA' or 'userB' or is a member of the 'group1' group.
    
    Authentication databases
    ------------------------
    
    Each authentication method uses some kind of database to verifiy identities.
    In Zorp authentication databases are represented by
    AbstractAuthenticationProvider, each actual implementation must be derived
    from this class.
    
    The only current example is ZAS2AuthenticationProvider which communicates
    with Zorp Authentication Server (or ZAS for short) to verify identities.
    
    Each authentication provider has a name to make it easy to refer to them.
    
    Example:
    
    	ZAS2AuthenticationProvider('zasdb', SockAddrInet('192.168.1.4', 7777))
    	
    	AuthPolicy('dmz-intra',
    		   authentication=SatyrAuthentication('zasdb'),
    		   authorization=BasicAccessList(
    		           ((Z_BACL_SUFFICIENT, PermitUser('userA')),
    		            (Z_BACL_SUFFICIENT, PermitUser('userB')),
    		            (Z_BACL_REQUIRED, PermitGroup('group1')))))
    
    	Service('dmz_HTTP_intra', HttpProxy,
    		auth_policy='dmz-intra')
    
    ZAS can also encapsulate traffic to SSL/TLS in which case certificate validation
    parameters must be set (e.g. CA certificate directory and CRL directory).
    
    User authentication methods
    ---------------------------
    
    There are currently two different user authentication methods in Zorp:
    InbandAuthentication and SatyrAuthentication.
    
    * InbandAuthentication: when the protocol and its proxy implementation
      supports authentication embedded into the protocol stream, this method can
      be used. This basically instructs the proxy to perform authentication in
      the protocol and to verify the authenticated entity against the
      authorization controls. Example:
      
    	AuthPolicy('dmz-intra',
    		   authentication=InbandAuthentication('zasdb'))
    		   
      The example above creates a new AuthPolicy which employs
      InbandAuthentication to authenticate against the database named 'zasdb'.
    
      Inband authentication is currently only supported by the HTTP proxy and is
      limited to non-transparent mode.
      
    * SatyrAuthentication: this authentication method is independent from the
      main protocol: it is performed in a separate channel (this is also called
      outband authentication). An agent program is required on the client
      computer to make this authentication work. Example:
      
    	AuthPolicy('dmz-intra',
    		   authentication=SatyrAuthentication('zasdb', key_file='fwsatyr.key', cert_file='fwsatyr.crt'))
    
      The satyr agent and the satyr component in Zorp uses an SSL wrapped TCP
      channel, therefore the key_file and cert_file arguments are required, and
      they specify a trusted server certificate to present to the authentication
      agent. Again, 'zasdb' specifies the name of the authentication provider to
      use.
    
    Authentication cache
    --------------------
    
    Authentication methods are able to use an authentication cache. An
    authentication cache is a list of recently authenticated users, which are
    considered valid for a short period of time.
    
    When an authentication policy is in use, the cache is consulted first, if it
    contains a valid entry from the given IP address, the authentication is
    skipped and processing continues as if the same user was authenticated
    again. An entry is valid if
    
    * it refers to the same service or if service_equiv is set
    * the timeout has not elapsed
    
    The timeout is updated after each authentication provided update_stamp is set.
    
    Example:
    
    	AuthCache('accept10mins', timeout=600, service_equiv=TRUE, update_stamp=TRUE)
    	AuthPolicy('dmz-intra-satyr',
    		   authentication=SatyrAuthentication('zasdb', cache='accept10mins', key_file='fwsatyr.key', cert_file='fwsatyr.crt'))