aboutsummaryrefslogblamecommitdiffstats
path: root/lease.h
blob: 95a7b58c768c4eea0672e71092ab3aeea097cc38 (plain) (tree)




































                                                                                

                                                                     
                                                                                






                                                                     

                                                                              
   
                                                                      
 

                                                                               
   
                     






                                                                          
/* SPDX-License-Identifier: MIT
 *
 * Copyright (C) 2019 WireGuard LLC. All Rights Reserved.
 */

#ifndef __LEASE_H__
#define __LEASE_H__

#include <stdint.h>
#include <sys/socket.h>
#include <time.h>

#include "common.h"
#include "netlink.h"

struct wg_dynamic_lease {
	time_t start_real;
	time_t start_mono;
	uint32_t leasetime; /* in seconds */
	struct in_addr ipv4;
	struct in6_addr ipv6;
	struct wg_dynamic_lease *next;
};

/*
 * Initializes internal state, reads leases from fname.
 */
void leases_init(char *fname);

/*
 * Frees everything, closes file.
 */
void leases_free();

/*
 * Creates a new lease and returns a pointer to it, or NULL if either we ran out
 * of assignable IPs or the requested IP is already taken.
 */
struct wg_dynamic_lease *new_lease(wg_key pubkey, uint32_t leasetime,
				   struct in_addr *ipv4, struct in6_addr *ipv6);

/*
 * Returns all leases belonging to pubkey, or NULL if there are none.
 */
struct wg_dynamic_lease *get_leases(wg_key pubkey);

/*
 * Extend the lease to be leasetime seconds long again. Returns true on error,
 * or false otherwise.
 */
bool extend_lease(struct wg_dynamic_lease *lease, uint32_t leasetime);

/* Refreshes all leases, meaning expired ones will be removed. Returns the
 * amount of seconds until the next lease will expire, or at most INT_MAX/1000.
 */
int leases_refresh();

/*
 * Updates all pools with information from the netlink file descriptor fd.
 */
void leases_update_pools(int fd);

#endif