mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
adds socket usage to network common (#21196)
* updates network common the reconstruct the persistent connection socket
This commit is contained in:
parent
953ca38b67
commit
39aaa32e40
1 changed files with 46 additions and 0 deletions
|
@ -25,6 +25,12 @@
|
||||||
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
|
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
|
||||||
# USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
# USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
#
|
#
|
||||||
|
import socket
|
||||||
|
import struct
|
||||||
|
import signal
|
||||||
|
|
||||||
|
from ansible.module_utils.basic import get_exception
|
||||||
|
from ansible.module_utils._text import to_bytes, to_native
|
||||||
from ansible.module_utils.six import iteritems
|
from ansible.module_utils.six import iteritems
|
||||||
|
|
||||||
def to_list(val):
|
def to_list(val):
|
||||||
|
@ -95,3 +101,43 @@ class ComplexList:
|
||||||
objects.append(obj)
|
objects.append(obj)
|
||||||
return objects
|
return objects
|
||||||
|
|
||||||
|
def send_data(s, data):
|
||||||
|
packed_len = struct.pack('!Q',len(data))
|
||||||
|
return s.sendall(packed_len + data)
|
||||||
|
|
||||||
|
def recv_data(s):
|
||||||
|
header_len = 8 # size of a packed unsigned long long
|
||||||
|
data = to_bytes("")
|
||||||
|
while len(data) < header_len:
|
||||||
|
d = s.recv(header_len - len(data))
|
||||||
|
if not d:
|
||||||
|
return None
|
||||||
|
data += d
|
||||||
|
data_len = struct.unpack('!Q',data[:header_len])[0]
|
||||||
|
data = data[header_len:]
|
||||||
|
while len(data) < data_len:
|
||||||
|
d = s.recv(data_len - len(data))
|
||||||
|
if not d:
|
||||||
|
return None
|
||||||
|
data += d
|
||||||
|
return data
|
||||||
|
|
||||||
|
def exec_command(module, command):
|
||||||
|
try:
|
||||||
|
sf = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM)
|
||||||
|
sf.connect(module._socket_path)
|
||||||
|
|
||||||
|
data = "EXEC: %s" % command
|
||||||
|
send_data(sf, to_bytes(data.strip()))
|
||||||
|
|
||||||
|
rc = int(recv_data(sf), 10)
|
||||||
|
stdout = recv_data(sf)
|
||||||
|
stderr = recv_data(sf)
|
||||||
|
except socket.error:
|
||||||
|
exc = get_exception()
|
||||||
|
sf.close()
|
||||||
|
module.fail_json(msg='unable to connect to socket', err=str(exc))
|
||||||
|
|
||||||
|
sf.close()
|
||||||
|
|
||||||
|
return (rc, to_native(stdout), to_native(stderr))
|
||||||
|
|
Loading…
Reference in a new issue