*/
public class BuilderAdapter
{
- VpnService.Builder builder;
+ private final String mName;
+ private VpnService.Builder mBuilder;
public BuilderAdapter(String name)
{
- builder = new CharonVpnService.Builder();
- builder.setSession(name);
+ mName = name;
+ mBuilder = createBuilder(name);
+ }
+
+ private VpnService.Builder createBuilder(String name)
+ {
+ VpnService.Builder builder = new CharonVpnService.Builder();
+ builder.setSession(mName);
/* even though the option displayed in the system dialog says "Configure"
* we just use our main Activity */
PendingIntent pending = PendingIntent.getActivity(context, 0, intent,
Intent.FLAG_ACTIVITY_NEW_TASK);
builder.setConfigureIntent(pending);
+ return builder;
}
public synchronized boolean addAddress(String address, int prefixLength)
{
try
{
- builder.addAddress(address, prefixLength);
+ mBuilder.addAddress(address, prefixLength);
}
catch (IllegalArgumentException ex)
{
{
try
{
- builder.addDnsServer(address);
+ mBuilder.addDnsServer(address);
}
catch (IllegalArgumentException ex)
{
{
try
{
- builder.addRoute(address, prefixLength);
+ mBuilder.addRoute(address, prefixLength);
}
catch (IllegalArgumentException ex)
{
{
try
{
- builder.addSearchDomain(domain);
+ mBuilder.addSearchDomain(domain);
}
catch (IllegalArgumentException ex)
{
{
try
{
- builder.setMtu(mtu);
+ mBuilder.setMtu(mtu);
}
catch (IllegalArgumentException ex)
{
ParcelFileDescriptor fd;
try
{
- fd = builder.establish();
+ fd = mBuilder.establish();
}
catch (Exception ex)
{
{
return -1;
}
+ /* now that the TUN device is created we don't need the current
+ * builder anymore, but we might need another when reestablishing */
+ mBuilder = createBuilder(mName);
return fd.detachFd();
}
}