lms.cli.courses.groupsets.memberships.set

Set membership for a group set.

usage: python3 -m lms.cli.courses.groupsets.memberships.set
       [-h] [--version] [--server SERVER]
       [--server-type {blackboard,canvas,moodle}] [--auth-user AUTH_USER]
       [--auth-password AUTH_PASSWORD] [--auth-token AUTH_TOKEN]
       [--course COURSE] [--groupset GROUPSET] [--group GROUP]
       [--format {json,table,text}] [--include-extra-fields]
       [--pretty-headers] [--skip-headers] [--skip-rows SKIP_ROWS] [--strict]
       PATH

Set membership for a group set.

positional arguments:
  PATH                  Path to a TSV file where each row has 2 columns: group
                        query and user query.

options:
  -h, --help            show this help message and exit
  --version             show program's version number and exit
  --course COURSE       The course to target for this operation.
  --groupset GROUPSET   The group set to target for this operation.
  --group GROUP         The group to target for this operation.
  --skip-rows SKIP_ROWS
                        The number of header rows to skip (default: 0).
  --strict              Enable strict mode, which is stricter about what
                        counts as an error (default: False).

server options:
  --server SERVER       The address of the LMS server to connect to.
  --server-type {blackboard,canvas,moodle}
                        The type of LMS being connected to (this can normally
                        be guessed from the server address).

authentication options:
  --auth-user AUTH_USER
                        The user to authenticate with.
  --auth-password AUTH_PASSWORD
                        The password to authenticate with.
  --auth-token AUTH_TOKEN
                        The token to authenticate with.

output formatting options:
  --format {json,table,text}
                        The format to display the output as (default: text).
  --include-extra-fields
                        Include non-common (usually LMS-specific) fields in
                        results (default: False).
  --pretty-headers      When displaying headers, try to make them look
                        "pretty" (default: False).
  --skip-headers        Skip headers when outputting results, will not apply
                        to all formats (default: False).
 1"""
 2Set membership for a group set.
 3"""
 4
 5import argparse
 6import sys
 7
 8import lms.backend.instance
 9import lms.cli.common
10import lms.cli.courses.groupsets.memberships.common
11import lms.cli.parser
12import lms.model.base
13
14def run_cli(args: argparse.Namespace) -> int:
15    """ Run the CLI. """
16
17    config = args._config
18
19    backend = lms.backend.instance.get_backend(**config)
20
21    course_query = lms.cli.common.check_required_course(backend, config)
22    if (course_query is None):
23        return 1
24
25    groupset_query = lms.cli.common.check_required_groupset(backend, config)
26    if (groupset_query is None):
27        return 2
28
29    memberships = lms.cli.courses.groupsets.memberships.common.load_group_memberships(backend, args.path, args.skip_rows)
30
31    stats = backend.courses_groupsets_memberships_resolve_and_set(course_query, groupset_query, memberships)
32    (created_groups, deleted_groups, add_counts, sub_counts) = stats
33
34    if (len(created_groups) > 0):
35        display_groups = [str(group.to_query()) for group in created_groups]
36        print(f"Created {len(created_groups)} groups: {display_groups}.")
37
38    if (len(deleted_groups) > 0):
39        display_groups = [str(group_query) for group_query in deleted_groups]
40        print(f"Deleted {len(deleted_groups)} groups: {display_groups}.")
41
42    total_add_count = 0
43    for group_query in sorted(set(add_counts.keys()) | set(sub_counts.keys())):
44        add_count = add_counts.get(group_query, 0)
45        sub_count = sub_counts.get(group_query, 0)
46
47        print(f"Added {add_count} and subtracted {sub_count} users to/from group {group_query}.")
48        total_add_count += add_count
49
50    return lms.cli.common.strict_check(args.strict, (total_add_count != len(memberships)),
51        f"Expected to set {len(memberships)} memberships in groupset, but set {total_add_count}.", 3)
52
53def main() -> int:
54    """ Get a parser, parse the args, and call run. """
55    return run_cli(_get_parser().parse_args())
56
57def _get_parser() -> argparse.ArgumentParser:
58    """ Get the parser. """
59
60    parser = lms.cli.parser.get_parser(__doc__.strip(),
61            include_output_format = True,
62            include_course = True,
63            include_groupset = True,
64            include_group = True,
65            include_skip_rows = True,
66            include_strict = True,
67    )
68
69    parser.add_argument('path', metavar = 'PATH',
70        action = 'store', type = str,
71        help = 'Path to a TSV file where each row has 2 columns: group query and user query.')
72
73    return parser
74
75if (__name__ == '__main__'):
76    sys.exit(main())
def run_cli(args: argparse.Namespace) -> int:
15def run_cli(args: argparse.Namespace) -> int:
16    """ Run the CLI. """
17
18    config = args._config
19
20    backend = lms.backend.instance.get_backend(**config)
21
22    course_query = lms.cli.common.check_required_course(backend, config)
23    if (course_query is None):
24        return 1
25
26    groupset_query = lms.cli.common.check_required_groupset(backend, config)
27    if (groupset_query is None):
28        return 2
29
30    memberships = lms.cli.courses.groupsets.memberships.common.load_group_memberships(backend, args.path, args.skip_rows)
31
32    stats = backend.courses_groupsets_memberships_resolve_and_set(course_query, groupset_query, memberships)
33    (created_groups, deleted_groups, add_counts, sub_counts) = stats
34
35    if (len(created_groups) > 0):
36        display_groups = [str(group.to_query()) for group in created_groups]
37        print(f"Created {len(created_groups)} groups: {display_groups}.")
38
39    if (len(deleted_groups) > 0):
40        display_groups = [str(group_query) for group_query in deleted_groups]
41        print(f"Deleted {len(deleted_groups)} groups: {display_groups}.")
42
43    total_add_count = 0
44    for group_query in sorted(set(add_counts.keys()) | set(sub_counts.keys())):
45        add_count = add_counts.get(group_query, 0)
46        sub_count = sub_counts.get(group_query, 0)
47
48        print(f"Added {add_count} and subtracted {sub_count} users to/from group {group_query}.")
49        total_add_count += add_count
50
51    return lms.cli.common.strict_check(args.strict, (total_add_count != len(memberships)),
52        f"Expected to set {len(memberships)} memberships in groupset, but set {total_add_count}.", 3)

Run the CLI.

def main() -> int:
54def main() -> int:
55    """ Get a parser, parse the args, and call run. """
56    return run_cli(_get_parser().parse_args())

Get a parser, parse the args, and call run.