Mercurial > repos > guerler > springsuite
comparison planemo/lib/python3.7/site-packages/boto/iam/__init__.py @ 0:d30785e31577 draft
"planemo upload commit 6eee67778febed82ddd413c3ca40b3183a3898f1"
author | guerler |
---|---|
date | Fri, 31 Jul 2020 00:18:57 -0400 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:d30785e31577 |
---|---|
1 # Copyright (c) 2010-2011 Mitch Garnaat http://garnaat.org/ | |
2 # Copyright (c) 2010-2011, Eucalyptus Systems, Inc. | |
3 # | |
4 # Permission is hereby granted, free of charge, to any person obtaining a | |
5 # copy of this software and associated documentation files (the | |
6 # "Software"), to deal in the Software without restriction, including | |
7 # without limitation the rights to use, copy, modify, merge, publish, dis- | |
8 # tribute, sublicense, and/or sell copies of the Software, and to permit | |
9 # persons to whom the Software is furnished to do so, subject to the fol- | |
10 # lowing conditions: | |
11 # | |
12 # The above copyright notice and this permission notice shall be included | |
13 # in all copies or substantial portions of the Software. | |
14 # | |
15 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS | |
16 # OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL- | |
17 # ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT | |
18 # SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, | |
19 # WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | |
20 # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS | |
21 # IN THE SOFTWARE. | |
22 | |
23 # this is here for backward compatibility | |
24 # originally, the IAMConnection class was defined here | |
25 from boto.iam.connection import IAMConnection | |
26 from boto.regioninfo import RegionInfo, get_regions | |
27 from boto.regioninfo import connect | |
28 | |
29 | |
30 class IAMRegionInfo(RegionInfo): | |
31 | |
32 def connect(self, **kw_params): | |
33 """ | |
34 Connect to this Region's endpoint. Returns an connection | |
35 object pointing to the endpoint associated with this region. | |
36 You may pass any of the arguments accepted by the connection | |
37 class's constructor as keyword arguments and they will be | |
38 passed along to the connection object. | |
39 | |
40 :rtype: Connection object | |
41 :return: The connection to this regions endpoint | |
42 """ | |
43 if self.connection_cls: | |
44 return self.connection_cls(host=self.endpoint, **kw_params) | |
45 | |
46 | |
47 def regions(): | |
48 """ | |
49 Get all available regions for the IAM service. | |
50 | |
51 :rtype: list | |
52 :return: A list of :class:`boto.regioninfo.RegionInfo` instances | |
53 """ | |
54 regions = get_regions( | |
55 'iam', | |
56 region_cls=IAMRegionInfo, | |
57 connection_cls=IAMConnection | |
58 ) | |
59 | |
60 # For historical reasons, we had a "universal" endpoint as well. | |
61 regions.append( | |
62 IAMRegionInfo( | |
63 name='universal', | |
64 endpoint='iam.amazonaws.com', | |
65 connection_cls=IAMConnection | |
66 ) | |
67 ) | |
68 | |
69 return regions | |
70 | |
71 | |
72 def connect_to_region(region_name, **kw_params): | |
73 """ | |
74 Given a valid region name, return a | |
75 :class:`boto.iam.connection.IAMConnection`. | |
76 | |
77 :type: str | |
78 :param region_name: The name of the region to connect to. | |
79 | |
80 :rtype: :class:`boto.iam.connection.IAMConnection` or ``None`` | |
81 :return: A connection to the given region, or None if an invalid region | |
82 name is given | |
83 """ | |
84 if region_name == 'universal': | |
85 region = IAMRegionInfo( | |
86 name='universal', | |
87 endpoint='iam.amazonaws.com', | |
88 connection_cls=IAMConnection | |
89 ) | |
90 return region.connect(**kw_params) | |
91 | |
92 return connect('iam', region_name, region_cls=IAMRegionInfo, | |
93 connection_cls=IAMConnection, **kw_params) |