Getting Stuck with DHCPd

At work we are trying to establish a Virtual Private Network (VPN) connection to another company in Melbourne. Being a die-hard Microsoft shop themselves, we have settled down to use Microsoft's VPN (PPTP or IPSec) technology to connect our internal LAN and their network together over the Internet. We are on the client side and they provide the server. Initially, they want to give each of us in the office a separate certificate so that we can connect to their network independently via separate VPN channels. This is just stupid - why don't we just have gateway box connecting to them so all the packets from our LAN destined to their network can route through one single PPP session on the VPN link? We can install a Linux PPTP client or a Linux IPSec implementation on our router box, and everyone will be happy. However, after they have been enlightened, they decided that they don't want to let our Linux router box to connect to their VPN. Instead, they are going to provide their own box to sit inside our network, ring home using its VPN client through our router box and NAT, and then everyone in the office can then connect to their office by routing the traffic to it. They want to do it o that not only we can have a peek at their network, they too can access our network in this way. I don't see having our router box connecting to their network would prevent what they are trying to achieve here, but anyway, they have settled on this decision and started building the box for us.

But it does give me a challenge in terms of routing. Actually, not really a challenge on routing but a challenge on configuring routing information on each of the boxes here. So, once this box arrived sometime tomorrow, and it will receive a private IP address inside our LAN ( for example). For all the requests to their LAN ( for example) to route through this box, it is simply adding a route command similar to...

  C:\< route ADD MASK

But I am think of whether it is possible to configure our DHCP server to automatically distribute this extra static routing information to its clients, so that no one has to enter them manually, and everything will just happen automatic. I am by means a network engineer, and my knowledge of DHCPd is quite limited. After digging the man pages and Googling the news groups, here's the closest I can find:

  option static-routes ip-address ip-address
                   [, ip-address ip-address...];

    This option specifies a list of static routes that the client should
    install in its routing cache.  If multiple routes to the same desti-
    nation  are specified, they are listed in descending order of prior-

    The routes consist of a list of IP address pairs.  The first address
    is the destination address, and the second address is the router for
    the destination.

    The default route ( is an illegal destination for  a  static
    route.   To  specify  the  default  route,  use  the routers option.
    Also, please note that this option is not intended for classless  IP
    routing  -  it  does not include a subnet mask.   Since classless IP
    routing is now the  most  widely  deployed  routing  standard,  this
    option  is  virtually  useless, and is not implemented by any of the
    popular DHCP clients, for example the Microsoft DHCP client.

It is exactly the kind of option I would like to use - broadcasting static routes to DHCP clients. However, notice the emphasised paragraph - it is only intended for classless IP routing, and it does not work with a subnet. D'oh. That means for every machine I would like to connect to on their end, I need to add an option to the DHCP server configuration. Moreover, Microsoft DHCP client might not work (actually, Windows 2000 in front of me seems to work fine). At the end, the problem is only half solved.

Another option is to put their machine on a separate IP network, so that the main router (which is the default route of all other boxes) can decide where the pocket should go. Then I do not need to modify the DHCP configuration, as the default route is already broadcasted. But then there is hardware problem. Our main router box is on an old IBM Pentium 166 with only 2 PCI slot - and both of them filled with network card already. One is for the LAN, and another one for the ADSL modem... Maybe it is just easier to get another cheap box and a few more network cables...

Okay. Back to work.