-
Notifications
You must be signed in to change notification settings - Fork 59
/
contact_group_mgmt.py
103 lines (80 loc) · 3.79 KB
/
contact_group_mgmt.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
"""This is the demo script to show how to manage contact groups.
This script will not work without replacing parameters with real values.
Its basic goal is to present what can be done with this module and to
ease its usage.
"""
from mstrio.connection import get_connection
from mstrio.users_and_groups import (
Contact, ContactGroup, ContactGroupMember, ContactGroupMemberType, list_contact_groups, User
)
# Define a variable which can be later used in a script
PROJECT_NAME = $project_name # Insert project name here
conn = get_connection(workstationData, project_name=PROJECT_NAME)
# Define variables which can be later used in a script
MEMBER_NAME = $member_name # here insert member name
MEMBER_ID = $member_id # Insert member ID
member1 = ContactGroupMember(
name=MEMBER_NAME,
type=ContactGroupMemberType.CONTACT, # it can be also ContactGroupMemberType.CONTACT_GROUP
id=MEMBER_ID,
enabled=True,
)
# Define variables which can be later used in a script
USERNAME = $username # name of user to link to the contact group
CONTACT_GROUP_NAME = $contact_group_name # Name of contact group
CONTACT_GROUP_DESCRIPTION = $contact_group_description # Description of newly created contact group
# create contact group with one member represented as an object (it can be more
# and they can be also represented as dictionaries). User linked to the contact
# group can be passed as a `User` object or just its ID.
new_cg = ContactGroup.create(
connection=conn,
name=CONTACT_GROUP_NAME,
linked_user=User(conn, username=USERNAME),
members=[member1], # list of `ContactGroupMember` objects
description=CONTACT_GROUP_DESCRIPTION,
enabled=True,
)
# list all contact groups
contact_groups = list_contact_groups(conn)
# Define a variable which can be later used in a script
CONTACT_GROUP_ID = $contact_group_id # Insert your contact group ID here
# There are two ways to get already existing contact group
# get contact group by ID
cg = ContactGroup(conn, id=CONTACT_GROUP_ID)
# get contact group by name
cg = ContactGroup(conn, name=CONTACT_GROUP_NAME)
# get properties of contact group
cg_name = cg.name
cg_description = cg.description
cg_lined_user = cg.linked_user
cg_members = cg.members
cg_enabled = cg.enabled
# Define variables which can be later used in a script
CONTACT_GROUP_NEW_NAME = $contact_group_new_name # Insert new name of contact group
CONTACT_GROUP_NEW_DESCRIPTION = $contact_group_new_description # Insert new description of contact group
OTHER_USERNAME = $other_username # Insert new user for contact group
# alter contact group
cg.alter(
name=CONTACT_GROUP_NEW_NAME,
description=CONTACT_GROUP_NEW_DESCRIPTION,
linked_user=User(conn, username=OTHER_USERNAME),
enabled=False,
)
# Define a variable which can be later used in a script
CONTACT_NAME = $contact_name # Insert contact name here
# more examples for contact are defined in snippet `contacts.py`
# add members to contact group - it can be `ContactGroupMember`, `Contact`
# or `ContactGroup`
contact = Contact(conn, name=CONTACT_NAME)
cg.add_members(members=[contact]) # add contact (list of `Contact` objects)
cg.add_members(members=[new_cg]) # add contact group (list of `ContactGroup` objects)
# Define a variable which can be later used in a script
OTHER_CONTACT_GROUP_NAME = $other_contact_group_name # Insert name of another contact group here
# remove members from contact group - it can be `ContactGroupMember`, `Contact`
# or `ContactGroup`
contact_group = ContactGroup(conn, name=OTHER_CONTACT_GROUP_NAME)
cg.remove_members(members=[contact]) # remove contact
cg.remove_members(members=[contact_group]) # remove contact group
# Delete contact group. When argument `force` is set to `False` (default value),
# then deletion must be confirmed by selecting appropriate prompt value.
cg.delete(force=True)