IPv6 address using VPN's TUN/TAP to SOCKS5 wrapper

The name of the pictureThe name of the pictureThe name of the pictureClash Royale CLAN TAG#URR8PPP











up vote
1
down vote

favorite












Is there any software to wrap a IPv6 VPN (or to be precise anything using tun/tap), so it would be possible to use it without tun/tap interface with SOCKS5 without using tun/tap interface?



Rationale:



What I'm trying to do is to use cjdns without root and tun/tap interface. So far I've only found tunsocks but it only supports IPv4 (even though author noted that implementing IPv6 support should be straightforward, I lack the required skills). I think that I implemented tunsocks into cjdns correctly but since it's IPv4 only, I can't really test it (PR - https://github.com/cjdelisle/cjdns/pull/1104). Any hints are appreciated.



Update: I need to do it without using root permissions at all (not even once). Basically I need something that will provide what tunsocks provides but for IPv6.







share|improve this question

























    up vote
    1
    down vote

    favorite












    Is there any software to wrap a IPv6 VPN (or to be precise anything using tun/tap), so it would be possible to use it without tun/tap interface with SOCKS5 without using tun/tap interface?



    Rationale:



    What I'm trying to do is to use cjdns without root and tun/tap interface. So far I've only found tunsocks but it only supports IPv4 (even though author noted that implementing IPv6 support should be straightforward, I lack the required skills). I think that I implemented tunsocks into cjdns correctly but since it's IPv4 only, I can't really test it (PR - https://github.com/cjdelisle/cjdns/pull/1104). Any hints are appreciated.



    Update: I need to do it without using root permissions at all (not even once). Basically I need something that will provide what tunsocks provides but for IPv6.







    share|improve this question























      up vote
      1
      down vote

      favorite









      up vote
      1
      down vote

      favorite











      Is there any software to wrap a IPv6 VPN (or to be precise anything using tun/tap), so it would be possible to use it without tun/tap interface with SOCKS5 without using tun/tap interface?



      Rationale:



      What I'm trying to do is to use cjdns without root and tun/tap interface. So far I've only found tunsocks but it only supports IPv4 (even though author noted that implementing IPv6 support should be straightforward, I lack the required skills). I think that I implemented tunsocks into cjdns correctly but since it's IPv4 only, I can't really test it (PR - https://github.com/cjdelisle/cjdns/pull/1104). Any hints are appreciated.



      Update: I need to do it without using root permissions at all (not even once). Basically I need something that will provide what tunsocks provides but for IPv6.







      share|improve this question













      Is there any software to wrap a IPv6 VPN (or to be precise anything using tun/tap), so it would be possible to use it without tun/tap interface with SOCKS5 without using tun/tap interface?



      Rationale:



      What I'm trying to do is to use cjdns without root and tun/tap interface. So far I've only found tunsocks but it only supports IPv4 (even though author noted that implementing IPv6 support should be straightforward, I lack the required skills). I think that I implemented tunsocks into cjdns correctly but since it's IPv4 only, I can't really test it (PR - https://github.com/cjdelisle/cjdns/pull/1104). Any hints are appreciated.



      Update: I need to do it without using root permissions at all (not even once). Basically I need something that will provide what tunsocks provides but for IPv6.









      share|improve this question












      share|improve this question




      share|improve this question








      edited May 7 at 17:11
























      asked May 3 at 19:50









      sssemil

      65




      65




















          1 Answer
          1






          active

          oldest

          votes

















          up vote
          0
          down vote













          The problem is that the IP packets transferred to and from your local host must go through some kind of network interface. If you want to reroute them somewhere, no matter if that is a VPN, a SOCKS proxy, or something else, they also must go through a network interface. And since the rerouting is done in software, that network interface is a tun/tap interface. You can't access a VPN without it.



          As for "wrapping the VPN software with a SOCKS wrapper", that applies to the wrong end: The VPN software has no trouble communicating to the other end of the VPN tunnel without root rights, this is just normal network communication. And it would be that part that is wrapped by SOCKS.



          However, you can create tun/tap interfaces without root rights by setting permissions on /dev/net/tun (see here), which needs root right once.



          AFAIK you can also pre-create a named tun/tap interface (which again needs root rights once), and then use it by an application without root rights.



          Maybe one of these two options solves your problem?






          share|improve this answer

















          • 1




            If I take care of the TCP/IP stack in my wrapper, then I can handle it without tun/tap altogether. Fix example tunsocks uses lwIP.
            – sssemil
            May 4 at 5:05










          • I really would like to see a wrapper that can forward kernel packets without a network interface. Any links to an example of such a wrapper? tunsocks doesn't provide such a wrapper; all applications that want to use tunsocks instead of the normal kernel networking must explicitely use tunsocks. That's not how you use a VPN on a local machine, unless you only want a few specific applications to use the VPN (and if you want that, you didnt' mention it in your question). Maybe clarify the question?
            – dirkt
            May 4 at 6:14










          Your Answer







          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "106"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          convertImagesToLinks: false,
          noModals: false,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );








           

          draft saved


          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f441644%2fipv6-address-using-vpns-tun-tap-to-socks5-wrapper%23new-answer', 'question_page');

          );

          Post as a guest






























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes








          up vote
          0
          down vote













          The problem is that the IP packets transferred to and from your local host must go through some kind of network interface. If you want to reroute them somewhere, no matter if that is a VPN, a SOCKS proxy, or something else, they also must go through a network interface. And since the rerouting is done in software, that network interface is a tun/tap interface. You can't access a VPN without it.



          As for "wrapping the VPN software with a SOCKS wrapper", that applies to the wrong end: The VPN software has no trouble communicating to the other end of the VPN tunnel without root rights, this is just normal network communication. And it would be that part that is wrapped by SOCKS.



          However, you can create tun/tap interfaces without root rights by setting permissions on /dev/net/tun (see here), which needs root right once.



          AFAIK you can also pre-create a named tun/tap interface (which again needs root rights once), and then use it by an application without root rights.



          Maybe one of these two options solves your problem?






          share|improve this answer

















          • 1




            If I take care of the TCP/IP stack in my wrapper, then I can handle it without tun/tap altogether. Fix example tunsocks uses lwIP.
            – sssemil
            May 4 at 5:05










          • I really would like to see a wrapper that can forward kernel packets without a network interface. Any links to an example of such a wrapper? tunsocks doesn't provide such a wrapper; all applications that want to use tunsocks instead of the normal kernel networking must explicitely use tunsocks. That's not how you use a VPN on a local machine, unless you only want a few specific applications to use the VPN (and if you want that, you didnt' mention it in your question). Maybe clarify the question?
            – dirkt
            May 4 at 6:14














          up vote
          0
          down vote













          The problem is that the IP packets transferred to and from your local host must go through some kind of network interface. If you want to reroute them somewhere, no matter if that is a VPN, a SOCKS proxy, or something else, they also must go through a network interface. And since the rerouting is done in software, that network interface is a tun/tap interface. You can't access a VPN without it.



          As for "wrapping the VPN software with a SOCKS wrapper", that applies to the wrong end: The VPN software has no trouble communicating to the other end of the VPN tunnel without root rights, this is just normal network communication. And it would be that part that is wrapped by SOCKS.



          However, you can create tun/tap interfaces without root rights by setting permissions on /dev/net/tun (see here), which needs root right once.



          AFAIK you can also pre-create a named tun/tap interface (which again needs root rights once), and then use it by an application without root rights.



          Maybe one of these two options solves your problem?






          share|improve this answer

















          • 1




            If I take care of the TCP/IP stack in my wrapper, then I can handle it without tun/tap altogether. Fix example tunsocks uses lwIP.
            – sssemil
            May 4 at 5:05










          • I really would like to see a wrapper that can forward kernel packets without a network interface. Any links to an example of such a wrapper? tunsocks doesn't provide such a wrapper; all applications that want to use tunsocks instead of the normal kernel networking must explicitely use tunsocks. That's not how you use a VPN on a local machine, unless you only want a few specific applications to use the VPN (and if you want that, you didnt' mention it in your question). Maybe clarify the question?
            – dirkt
            May 4 at 6:14












          up vote
          0
          down vote










          up vote
          0
          down vote









          The problem is that the IP packets transferred to and from your local host must go through some kind of network interface. If you want to reroute them somewhere, no matter if that is a VPN, a SOCKS proxy, or something else, they also must go through a network interface. And since the rerouting is done in software, that network interface is a tun/tap interface. You can't access a VPN without it.



          As for "wrapping the VPN software with a SOCKS wrapper", that applies to the wrong end: The VPN software has no trouble communicating to the other end of the VPN tunnel without root rights, this is just normal network communication. And it would be that part that is wrapped by SOCKS.



          However, you can create tun/tap interfaces without root rights by setting permissions on /dev/net/tun (see here), which needs root right once.



          AFAIK you can also pre-create a named tun/tap interface (which again needs root rights once), and then use it by an application without root rights.



          Maybe one of these two options solves your problem?






          share|improve this answer













          The problem is that the IP packets transferred to and from your local host must go through some kind of network interface. If you want to reroute them somewhere, no matter if that is a VPN, a SOCKS proxy, or something else, they also must go through a network interface. And since the rerouting is done in software, that network interface is a tun/tap interface. You can't access a VPN without it.



          As for "wrapping the VPN software with a SOCKS wrapper", that applies to the wrong end: The VPN software has no trouble communicating to the other end of the VPN tunnel without root rights, this is just normal network communication. And it would be that part that is wrapped by SOCKS.



          However, you can create tun/tap interfaces without root rights by setting permissions on /dev/net/tun (see here), which needs root right once.



          AFAIK you can also pre-create a named tun/tap interface (which again needs root rights once), and then use it by an application without root rights.



          Maybe one of these two options solves your problem?







          share|improve this answer













          share|improve this answer



          share|improve this answer











          answered May 4 at 5:01









          dirkt

          14k2930




          14k2930







          • 1




            If I take care of the TCP/IP stack in my wrapper, then I can handle it without tun/tap altogether. Fix example tunsocks uses lwIP.
            – sssemil
            May 4 at 5:05










          • I really would like to see a wrapper that can forward kernel packets without a network interface. Any links to an example of such a wrapper? tunsocks doesn't provide such a wrapper; all applications that want to use tunsocks instead of the normal kernel networking must explicitely use tunsocks. That's not how you use a VPN on a local machine, unless you only want a few specific applications to use the VPN (and if you want that, you didnt' mention it in your question). Maybe clarify the question?
            – dirkt
            May 4 at 6:14












          • 1




            If I take care of the TCP/IP stack in my wrapper, then I can handle it without tun/tap altogether. Fix example tunsocks uses lwIP.
            – sssemil
            May 4 at 5:05










          • I really would like to see a wrapper that can forward kernel packets without a network interface. Any links to an example of such a wrapper? tunsocks doesn't provide such a wrapper; all applications that want to use tunsocks instead of the normal kernel networking must explicitely use tunsocks. That's not how you use a VPN on a local machine, unless you only want a few specific applications to use the VPN (and if you want that, you didnt' mention it in your question). Maybe clarify the question?
            – dirkt
            May 4 at 6:14







          1




          1




          If I take care of the TCP/IP stack in my wrapper, then I can handle it without tun/tap altogether. Fix example tunsocks uses lwIP.
          – sssemil
          May 4 at 5:05




          If I take care of the TCP/IP stack in my wrapper, then I can handle it without tun/tap altogether. Fix example tunsocks uses lwIP.
          – sssemil
          May 4 at 5:05












          I really would like to see a wrapper that can forward kernel packets without a network interface. Any links to an example of such a wrapper? tunsocks doesn't provide such a wrapper; all applications that want to use tunsocks instead of the normal kernel networking must explicitely use tunsocks. That's not how you use a VPN on a local machine, unless you only want a few specific applications to use the VPN (and if you want that, you didnt' mention it in your question). Maybe clarify the question?
          – dirkt
          May 4 at 6:14




          I really would like to see a wrapper that can forward kernel packets without a network interface. Any links to an example of such a wrapper? tunsocks doesn't provide such a wrapper; all applications that want to use tunsocks instead of the normal kernel networking must explicitely use tunsocks. That's not how you use a VPN on a local machine, unless you only want a few specific applications to use the VPN (and if you want that, you didnt' mention it in your question). Maybe clarify the question?
          – dirkt
          May 4 at 6:14












           

          draft saved


          draft discarded


























           


          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f441644%2fipv6-address-using-vpns-tun-tap-to-socks5-wrapper%23new-answer', 'question_page');

          );

          Post as a guest













































































          Popular posts from this blog

          How to check contact read email or not when send email to Individual?

          How many registers does an x86_64 CPU actually have?

          Nur Jahan