Files
poky/bitbake/lib/toaster/toastermain/management/commands/checksocket.py
David Reyna 9ccaee95d6 bitbake: toaster: Update to Django 4.2
Update Toaster to support Django 4.2, to match current
hosts and to address CVEs.

[YOCTO #15152]

(Bitbake rev: 4f5b1f5bede402295bf4dfc8845fe2f38973e157)

Signed-off-by: Kieran McNulty <Kieran.McNulty@windriver.com>
Signed-off-by: David Reyna <David.Reyna@windriver.com>
Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2023-08-30 10:41:54 +01:00

58 lines
1.9 KiB
Python

#!/usr/bin/env python3
#
# BitBake Toaster Implementation
#
# Copyright (C) 2015 Intel Corporation
#
# SPDX-License-Identifier: GPL-2.0-only
#
"""Custom management command checksocket."""
import errno
import socket
from django.core.management.base import BaseCommand, CommandError
from django.utils.encoding import force_str
DEFAULT_ADDRPORT = "0.0.0.0:8000"
class Command(BaseCommand):
"""Custom management command."""
help = 'Check if Toaster can listen on address:port'
def add_arguments(self, parser):
parser.add_argument('addrport', nargs='?', default=DEFAULT_ADDRPORT,
help='ipaddr:port to check, %s by default' % \
DEFAULT_ADDRPORT)
def handle(self, *args, **options):
addrport = options['addrport']
if ':' not in addrport:
raise CommandError('Invalid addr:port specified: %s' % addrport)
splitted = addrport.split(':')
try:
splitted[1] = int(splitted[1])
except ValueError:
raise CommandError('Invalid port specified: %s' % splitted[1])
self.stdout.write('Check if toaster can listen on %s' % addrport)
try:
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
sock.bind(tuple(splitted))
except (socket.error, OverflowError) as err:
errors = {
errno.EACCES: 'You don\'t have permission to access port %s' \
% splitted[1],
errno.EADDRINUSE: 'Port %s is already in use' % splitted[1],
errno.EADDRNOTAVAIL: 'IP address can\'t be assigned to',
}
if hasattr(err, 'errno') and err.errno in errors:
errtext = errors[err.errno]
else:
errtext = force_str(err)
raise CommandError(errtext)
self.stdout.write("OK")