mirror of
				https://gitlab.labs.nic.cz/labs/bird.git
				synced 2024-05-11 16:54:54 +00:00 
			
		
		
		
	Add min/max key length fields to the MAC algorithm description and validate configured keys before they are used.
		
			
				
	
	
		
			39 lines
		
	
	
		
			1006 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
		
			1006 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  *	BIRD -- Password handling
 | |
|  *
 | |
|  *	(c) 1999 Pavel Machek <pavel@ucw.cz>
 | |
|  *	(c) 2004 Ondrej Filip <feela@network.cz>
 | |
|  *
 | |
|  *	Can be freely distributed and used under the terms of the GNU GPL.
 | |
|  */
 | |
| 
 | |
| #ifndef PASSWORD_H
 | |
| #define PASSWORD_H
 | |
| 
 | |
| struct password_item {
 | |
|   node n;
 | |
|   const char *password;			/* Key data, null terminated */
 | |
|   uint length;				/* Key length, without null */
 | |
|   uint id;				/* Key ID */
 | |
|   uint alg;				/* MAC algorithm */
 | |
|   btime accfrom, accto, genfrom, gento;
 | |
| };
 | |
| 
 | |
| extern struct password_item *last_password_item;
 | |
| 
 | |
| struct password_item *password_find(list *l, int first_fit);
 | |
| struct password_item *password_find_by_id(list *l, uint id);
 | |
| struct password_item *password_find_by_value(list *l, char *pass, uint size);
 | |
| void password_validate_length(const struct password_item *p);
 | |
| 
 | |
| static inline int password_verify(struct password_item *p1, char *p2, uint size)
 | |
| {
 | |
|   char buf[size];
 | |
|   strncpy(buf, p1->password, size);
 | |
|   return !memcmp(buf, p2, size);
 | |
| }
 | |
| 
 | |
| uint max_mac_length(list *l);
 | |
| 
 | |
| #endif
 |