Skip to content
Snippets Groups Projects
Select Git revision
  • fc9b4e782e23577bc6d34b458e8882f97483dfab
  • master default protected
  • release/202005
  • release/202001
  • release/201912
  • release/windows-test/201910
  • release/201908
  • release/201906
  • release/201905
  • release/201904
  • release/201903
  • release/201902
  • release/201901
  • release/201812
  • release/201811
  • release/201808
  • wip/patches_poly_2017/cedryk_doucet/abderahmane_bouziane
  • releases/beta1
  • android/release_464
  • android/release_463
  • android/release_462
  • android/release_461
  • android/release_460
  • android/release_459
  • android/release_458
  • android/release_457
  • android/release_456
  • android/release_455
  • android/release_454
  • android/release_453
  • android/release_452
  • android/release_451
  • android/release_450
  • android/release_449
  • android/release_448
  • android/release_447
  • android/release_446
  • android/release_445
38 results

MenuFragment.java

Blame
  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    SdesNegotiator.cpp 6.95 KiB
    /*
     *  Copyright (C) 2009 Savoir-Faire Linux inc.
     *  Author: Pierre-Luc Bacon <pierre-luc.bacon@savoirfairelinux.com>
     *
     *  This program is free software; you can redistribute it and/or modify
     *  it under the terms of the GNU General Public License as published by
     *  the Free Software Foundation; either version 3 of the License, or
     *  (at your option) any later version.
     *  This program is distributed in the hope that it will be useful,
     *  but WITHOUT ANY WARRANTY; without even the implied warranty of
     *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     *  GNU General Public License for more details.
     *
     *  You should have received a copy of the GNU General Public License
     *  along with this program; if not, write to the Free Software
     *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
     */
    
    #include "SdesNegotiator.h"
    
    #include "Pattern.h"
    
    #include <cstdio>
    #include <iostream>
    #include <sstream>
    #include <algorithm>
    #include <stdexcept>
    
    using namespace sfl;
    
    SdesNegotiator::SdesNegotiator (const std::vector<CryptoSuiteDefinition>& localCapabilites,
                                    const std::vector<std::string>& remoteAttribute) :
            _remoteAttribute (remoteAttribute),
            _localCapabilities (localCapabilites)
    {
    
    }
    
    std::vector<CryptoAttribute *> SdesNegotiator::parse (void)
    {
        // The patterns below try to follow
        // the ABNF grammar rules described in
        // RFC4568 section 9.2 with the general
        // syntax :
        //a=crypto:tag 1*WSP crypto-suite 1*WSP key-params *(1*WSP session-param)
    
        Pattern
        * generalSyntaxPattern,
        * tagPattern,
        * cryptoSuitePattern,
        * keyParamsPattern,
        * sessionParamPattern;
    
        try {
    
            // used to match white space (which are used as separator) 
            generalSyntaxPattern = new Pattern ("[\x20\x09]+", "g");
    
            tagPattern = new Pattern ("^a=crypto:(?P<tag>[0-9]{1,9})");
    
            cryptoSuitePattern = new Pattern (
                "(?P<cryptoSuite>AES_CM_128_HMAC_SHA1_80|" \
                "AES_CM_128_HMAC_SHA1_32|" \
                "F8_128_HMAC_SHA1_80|" \
                "[A-Za-z0-9_]+)"); // srtp-crypto-suite-ext
    
            keyParamsPattern = new Pattern (
                "(?P<srtpKeyMethod>inline|[A-Za-z0-9_]+)\\:" \
                "(?P<srtpKeyInfo>[A-Za-z0-9\x2B\x2F\x3D]+)\\|" \
                "2\\^(?P<lifetime>[0-9]+)\\|" \
                "(?P<mkiValue>[0-9]+)\\:" \
                "(?P<mkiLength>[0-9]{1,3})\\;?", "g");
    
            sessionParamPattern = new Pattern (
                "(?P<sessionParam>(kdr\\=[0-9]{1,2}|" \
                "UNENCRYPTED_SRTP|" \
                "UNENCRYPTED_SRTCP|" \
                "UNAUTHENTICATED_SRTP|" \
                "FEC_ORDER=(?P<fecOrder>FEC_SRTP|SRTP_FEC)|" \
                "FEC_KEY=(?P<fecKey>" + keyParamsPattern->getPattern() + ")|" \
                "WSH=(?P<wsh>[0-9]{1,2})|" \
                "(?<!\\-)[[:graph:]]+))*", "g"); // srtp-session-extension
    
        } catch (compile_error& exception) {
            throw parse_error ("A compile exception occured on a pattern.");
        }
          
    
        // Take each line from the vector
        // and parse its content
    
        
        std::vector<std::string>::iterator iter;
    	std::vector<CryptoAttribute *> cryptoAttributeVector;
    	
        for (iter = _remoteAttribute.begin(); iter != _remoteAttribute.end(); iter++) {
            // Split the line into its component
            // that we will analyze further down.
    		std::vector<std::string> sdesLine;
    	
            *generalSyntaxPattern << (*iter);
            
            try {
                sdesLine = generalSyntaxPattern->split();
    
                if (sdesLine.size() < 3) {
                    throw parse_error ("Missing components in SDES line");
                }
            } catch (match_error& exception) {
                throw parse_error ("Error while analyzing the SDES line.");
            }
    	
    
            // Check if the attribute starts with a=crypto
            // and get the tag for this line
            *tagPattern << sdesLine.at (0);
    				
    		std::string tag; 
    		if (tagPattern->matches()) {
    			try {
    				tag = tagPattern->group ("tag");
    			} catch (match_error& exception) {
    				throw parse_error ("Error while parsing the tag field");
    			}
    		} else {
    			return cryptoAttributeVector;
    		}
    
            // Check if the crypto suite is valid and retreive
            // its value.
            *cryptoSuitePattern << sdesLine.at (1);
    
    		std::string cryptoSuite;
    		
    		if (cryptoSuitePattern->matches()) {
    			try {
    				cryptoSuite  = cryptoSuitePattern->group ("cryptoSuite");
    			} catch (match_error& exception) {
    				throw parse_error ("Error while parsing the crypto-suite field");
    			}
    		} else {
    			return cryptoAttributeVector;
    		}
    	
            // Parse one or more key-params field.
            *keyParamsPattern << sdesLine.at (2);
    
    		std::string srtpKeyInfo;
    		std::string srtpKeyMethod;
    		std::string lifetime;
    		std::string mkiLength;
    		std::string mkiValue;
    		
            try {
                while (keyParamsPattern->matches()) {
                    srtpKeyMethod = keyParamsPattern->group ("srtpKeyMethod");
                    srtpKeyInfo = keyParamsPattern->group ("srtpKeyInfo");
                    lifetime = keyParamsPattern->group ("lifetime");
                    mkiValue = keyParamsPattern->group ("mkiValue");
                    mkiLength = keyParamsPattern->group ("mkiLength");
                }
            } catch (match_error& exception) {
                throw parse_error ("Error while parsing the key-params field");
            }
    
            /**
             *  Parse the optional session-param fields
             * @TODO Implement this !
             */
            /*
            if (sdesLine.size() == 3) continue;
    
            int i;
            for (i = 3; i < sdesLine.size(); i++) {
            	sessionParamPattern << sdesLine.at(i);
            	while (sessionpParamPattern.matches()) {
    
            		} catch (match_error& exception) {
            			throw parse_error("Error while parsing the crypto-suite field");
            		}
            	}
            } */
    		
    		// Add the new CryptoAttribute to the vector
    		std::cout << (*iter) << std::endl;
    		CryptoAttribute * cryptoAttribute = new CryptoAttribute(tag, cryptoSuite, srtpKeyMethod, srtpKeyInfo, lifetime, mkiValue, mkiLength);
    		cryptoAttributeVector.push_back(cryptoAttribute);
        }
    
    	return cryptoAttributeVector;
    }
    
    bool SdesNegotiator::negotiate (void)
    {
    	try {
    		std::vector<CryptoAttribute *> cryptoAttributeVector = parse();
    		
    		std::vector<CryptoAttribute *>::iterator iter;
    		for (iter = cryptoAttributeVector.begin(); iter != cryptoAttributeVector.end(); iter++) {
    			std::cout << "Negotiate tag: " + (*iter)->getTag() << std::endl;
    			std::cout << "Crypto Suite: " + (*iter)->getCryptoSuite() << std::endl;
    			std::cout << "SRTP Key Method: " + (*iter)->getSrtpKeyMethod() << std::endl;
    			std::cout << "SRTP Key Info: " + (*iter)->getSrtpKeyInfo() << std::endl;
    			std::cout << "Lifetime: " + (*iter)->getLifetime() << std::endl;
    			std::cout << "MKI Value: " + (*iter)->getMkiValue() << std::endl;			
    			std::cout << "MKI Length: " + (*iter)->getMkiLength() << std::endl;			
    			
    			delete (*iter);
    		}
    		
    	} catch (parse_error& exception) {
    		return false;
    	} catch (match_error& exception) {
    		return false;
    	}
    	
        return true;
    }