⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 plutoalg.c

📁 This a good VPN source
💻 C
📖 第 1 页 / 共 2 页
字号:
/* * Kernel runtime algorithm handling interface definitions * Originally by: JuanJo Ciarlante <jjo-ipsec@mendoza.gov.ar> * * Reworked into openswan 2.x by Michael Richardson <mcr@xelerance.com> * * kernel_alg.h,v 1.1.2.1 2003/11/21 18:12:23 jjo Exp * * 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 2 of the License, or (at your * option) any later version.  See <http://www.fsf.org/copyleft/gpl.txt>. * * 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. */#include <sys/types.h>#include <stdlib.h>#include <openswan.h>#include <pfkeyv2.h>#include <sys/queue.h>#include <openswan/passert.h>#include <openswan/ipsec_policy.h>#include "constants.h"#include "oswlog.h"#include "oswalloc.h"#include "defs.h"#include "id.h"#include "connections.h"#include "state.h"#include "kernel_alg.h"#include "alg_info.h"#include "ike_alg.h"#include "plutoalg.h"#include "crypto.h"#include "spdb.h"#include "db_ops.h"#include "log.h"#include "whack.h"/** * 	Search oakley_enc_names for a match, eg: * 		"3des_cbc" <=> "OAKLEY_3DES_CBC" * * @param str String containing ALG name (eg: AES, 3DES) * @param len Length of ALG (eg: 256,512) * @return int Registered # of ALG if loaded. */static intealg_getbyname_ike(const char *const str, int len){	int ret=-1;	if (!str||!*str)		goto out;	ret=alg_enum_search_prefix(&oakley_enc_names,"OAKLEY_",str,len);	if (ret>=0) goto out;	ret=alg_enum_search_ppfix(&oakley_enc_names, "OAKLEY_", "_CBC", str, len);out:	return ret;}/** * 	Search  oakley_hash_names for a match, eg: * 		"md5" <=> "OAKLEY_MD5" * @param str String containing Hash name (eg: MD5, SHA1) * @param len Length of Hash (eg: 256,512) * @return int Registered # of Hash ALG if loaded. */static intaalg_getbyname_ike(const char *const str, int len){	int ret=-1;	unsigned num;	if (!str||!*str)		goto out;	ret=alg_enum_search_prefix(&oakley_hash_names,"OAKLEY_",str,len);	if (ret>=0) goto out;	sscanf(str, "id%d%n", &ret, &num);	if (ret >=0 && num!=strlen(str))		ret=-1;out:	return ret;}/** * 	Search oakley_group_names for a match, eg: * 		"modp1024" <=> "OAKLEY_GROUP_MODP1024" * @param str String MODP Name (eg: MODP) * @param len Length of Hash (eg: 1024,1536,2048) * @return int Registered # of MODP Group, if supported. */static intmodp_getbyname_ike(const char *const str, int len){	int ret=-1;	if (!str||!*str)		goto out;	ret=alg_enum_search_prefix(&oakley_group_names,"OAKLEY_GROUP_",str,len);	if (ret>=0) goto out;	ret=alg_enum_search_ppfix(&oakley_group_names, "OAKLEY_GROUP_", " (extension)", str, len);out:	return ret;}static void__alg_info_ike_add (struct alg_info_ike *alg_info, int ealg_id, unsigned ek_bits, int aalg_id, unsigned ak_bits, int modp_id){	struct ike_info *ike_info=alg_info->ike;	unsigned cnt=alg_info->alg_info_cnt, i;	/* 	check for overflows 	*/	passert(cnt < elemsof(alg_info->ike));	/*	dont add duplicates	*/	for (i=0;i<cnt;i++)		if (	ike_info[i].ike_ealg==ealg_id &&			(!ek_bits || ike_info[i].ike_eklen==ek_bits) &&			ike_info[i].ike_halg==aalg_id &&			(!ak_bits || ike_info[i].ike_hklen==ak_bits) &&			ike_info[i].ike_modp==modp_id		   )			return;	ike_info[cnt].ike_ealg=ealg_id;	ike_info[cnt].ike_eklen=ek_bits;	ike_info[cnt].ike_halg=aalg_id;	ike_info[cnt].ike_hklen=ak_bits;	ike_info[cnt].ike_modp=modp_id;	alg_info->alg_info_cnt++;	DBG(DBG_CRYPT, DBG_log("__alg_info_ike_add() "				"ealg=%d aalg=%d modp_id=%d, cnt=%d",				ealg_id, aalg_id, modp_id,				alg_info->alg_info_cnt));}/*	 * 	Proposals will be built by looping over default_ike_groups array and * 	merging alg_info (ike_info) contents */static int default_ike_groups[] = { 	OAKLEY_GROUP_MODP1536,	OAKLEY_GROUP_MODP1024};/*	 *	Add IKE alg info _with_ logic (policy): */static voidalg_info_ike_add (struct alg_info *alg_info		  , int ealg_id, int ek_bits		  , int aalg_id, int ak_bits		  , int modp_id, int permitmann UNUSED){	int i=0, n_groups;	n_groups=elemsof(default_ike_groups);	/* if specified modp_id avoid loop over default_ike_groups */	if (modp_id) {		n_groups=0;		goto in_loop;	}		for (;n_groups--;i++) {		modp_id=default_ike_groups[i];in_loop:		/*	Policy: default to 3DES */		if (ealg_id==0)			ealg_id=OAKLEY_3DES_CBC;		if (ealg_id>0) {			if (aalg_id>0)				__alg_info_ike_add((struct alg_info_ike *)alg_info,						ealg_id, ek_bits,						aalg_id, ak_bits,						modp_id);			else {				/*	Policy: default to MD5 and SHA */				__alg_info_ike_add((struct alg_info_ike *)alg_info,						ealg_id, ek_bits, \						OAKLEY_MD5, ak_bits, modp_id);				__alg_info_ike_add((struct alg_info_ike *)alg_info,						ealg_id, ek_bits, \						OAKLEY_SHA, ak_bits, modp_id);			}		}	}}intalg_info_snprint_esp(char *buf, int buflen, struct alg_info_esp *alg_info){	char *ptr=buf;	int ret;	struct esp_info *esp_info;	int cnt;	int eklen, aklen;	ptr=buf;	ALG_INFO_ESP_FOREACH(alg_info, esp_info, cnt) {		if (kernel_alg_esp_enc_ok(esp_info->esp_ealg_id, 0, NULL) &&			(kernel_alg_esp_auth_ok(esp_info->esp_aalg_id, NULL))) {		eklen=esp_info->esp_ealg_keylen;		if (!eklen) 			eklen=kernel_alg_esp_enc_keylen(esp_info->esp_ealg_id)*BITS_PER_BYTE;		aklen=esp_info->esp_aalg_keylen;		if (!aklen) 			aklen=kernel_alg_esp_auth_keylen(esp_info->esp_aalg_id)*BITS_PER_BYTE;		ret=snprintf(ptr, buflen, "%d_%03d-%d_%03d, ",				esp_info->esp_ealg_id,				eklen,				esp_info->esp_aalg_id,				aklen);		ptr+=ret;		buflen-=ret;		if (buflen<0) break;		}	}	return ptr-buf;}char *alg_info_snprint_ike1(struct ike_info *ike_info			    , int eklen, int aklen			    , char *buf			    , int buflen){    snprintf(buf, buflen-1, "%d_%03d-%d_%03d-%d",	     ike_info->ike_ealg,	     eklen,	     ike_info->ike_halg,	     aklen,	     ike_info->ike_modp);    return buf;}intalg_info_snprint_ike(char *buf, int buflen, struct alg_info_ike *alg_info){	char *ptr=buf;	int ret;	struct ike_info *ike_info;	int cnt;	int eklen, aklen;	struct encrypt_desc *enc_desc;	struct hash_desc *hash_desc;	ALG_INFO_IKE_FOREACH(alg_info, ike_info, cnt) {	    if (ike_alg_enc_present(ike_info->ike_ealg) 		&& (ike_alg_hash_present(ike_info->ike_halg)) 		&& (lookup_group(ike_info->ike_modp))) {		enc_desc=ike_alg_get_encrypter(ike_info->ike_ealg);		passert(enc_desc != NULL);		hash_desc=ike_alg_get_hasher(ike_info->ike_halg);		passert(hash_desc != NULL);				eklen=ike_info->ike_eklen;		if (!eklen) 		    eklen=enc_desc->keydeflen;		aklen=ike_info->ike_hklen;		if (!aklen) 		    aklen=hash_desc->hash_digest_len * BITS_PER_BYTE;		ret=snprintf(ptr, buflen, "%d_%03d-%d_%03d-%d, ",			     ike_info->ike_ealg,			     eklen,			     ike_info->ike_halg,			     aklen,			     ike_info->ike_modp);		ptr+=ret;		buflen-=ret;		if (buflen<0) break;	    }	}	return ptr-buf;}/*	 *	Must be called for each "new" char, with new *	character in ctx.ch */static voidparser_init_ike(struct parser_context *p_ctx){    memset(p_ctx, 0, sizeof (*p_ctx));    p_ctx->protoid=PROTO_ISAKMP;    p_ctx->ealg_str=p_ctx->ealg_buf;    p_ctx->aalg_str=p_ctx->aalg_buf;    p_ctx->modp_str=p_ctx->modp_buf;    p_ctx->state=ST_INI;    p_ctx->ealg_getbyname=ealg_getbyname_ike;    p_ctx->aalg_getbyname=aalg_getbyname_ike;    p_ctx->modp_getbyname=modp_getbyname_ike;}struct alg_info_ike *alg_info_ike_create_from_str (const char *alg_str, const char **err_p){	struct alg_info_ike *alg_info_ike;	/*	 * 	alg_info storage should be sized dynamically	 * 	but this may require 2passes to know	 * 	transform count in advance.	 */	alg_info_ike=alloc_thing (struct alg_info_ike, "alg_info_ike");	if (!alg_info_ike) goto out;	alg_info_ike->alg_info_protoid=PROTO_ISAKMP;	if (alg_info_parse_str((struct alg_info *)alg_info_ike,			       alg_str, err_p,			       parser_init_ike,			       alg_info_ike_add,			       lookup_group,			       TRUE) < 0)	{		pfreeany(alg_info_ike);		alg_info_ike=NULL;	}out:	return alg_info_ike;}static voidkernel_alg_policy_algorithms(struct esp_info *esp_info){    int ealg_i=esp_info->esp_ealg_id;    switch(ealg_i) {        case 0:        case ESP_DES:

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -