setup.rst 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439
  1. Setup
  2. =====
  3. To initialize a connection to a cloud and get a provider object, you will
  4. need to provide the cloud's access credentials to CloudBridge. For more
  5. details on how to create and find these credentials, see the `Procuring Access
  6. Credentials <procuring_credentials.html>`_ page. Note that you can selectively
  7. provide the credentials for any provider you want to use and do not have to
  8. provide credentials for all the providers. CloudBridge will consume the
  9. available credentials in one of following ways:
  10. 1. `Providing access credentials through a dictionary`_
  11. 2. `Providing access credentials through environment variables`_
  12. 3. `Providing access credentials in a CloudBridge config file`_
  13. Providing access credentials through a dictionary
  14. -------------------------------------------------
  15. You can initialize a simple config as follows. The key names are the same
  16. as the environment variables, in lower case. Note that the config dictionary
  17. will override environment values.
  18. .. code-block:: python
  19. from cloudbridge.factory import CloudProviderFactory, ProviderList
  20. ## For AWS
  21. config = {'aws_access_key' : '<your_access_key>',
  22. 'aws_secret_key' : '<your_secret_key>'}
  23. provider = CloudProviderFactory().create_provider(ProviderList.AWS, config)
  24. ## For Azure
  25. config = {'azure_subscription_id': '<your_subscription_id>',
  26. 'azure_client_id': '<your_client_id>',
  27. 'azure_secret': '<your_secret>',
  28. 'azure_tenant': '<your_tenant>',
  29. 'azure_resource_group': '<your resource group>'}
  30. provider = CloudProviderFactory().create_provider(ProviderList.AZURE, config)
  31. ## For GCP
  32. config = {'gcp_service_creds_file': '<service_creds_file_name>.json'}
  33. # Alternatively, we can supply a dictionary with the credentials values
  34. # as the following:
  35. gcp_creds = {
  36. "type": "service_account",
  37. "project_id": "<project_name>",
  38. "private_key_id": "<private_key_id>",
  39. "private_key": "<private_key>",
  40. "client_email": "<client_email>",
  41. "client_id": "<client_id>",
  42. "auth_uri": "https://accounts.google.com/o/oauth2/auth",
  43. "token_uri": "https://oauth2.googleapis.com/token",
  44. "auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
  45. "client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/service-name%40my-project.iam.gserviceaccount.com"
  46. }
  47. config = {'gcp_service_creds_dict': gcp_creds}
  48. # A third alternative is to use a GCP credentials object provided by the GCP python
  49. # sdk. This is for advanced usage scenarios.
  50. # e.g. credentials = AccessTokenCredentials(access_token, "MyAgent/1.0", None)
  51. config = {'gcp_credentials_obj': credentials}
  52. provider = CloudProviderFactory().create_provider(ProviderList.GCP, config)
  53. ## For OpenStack
  54. config = {'os_username': '<your username>',
  55. 'os_password': '<your password>',
  56. 'os_auth_url': '<auth url>,
  57. 'os_user_domain_name': '<user_domain_name>',
  58. 'os_project_domain_id': '<project_domain_id>',
  59. 'os_project_domain_name': '<project_domain_name>',
  60. 'os_project_name': '<project_name>')
  61. provider = CloudProviderFactory().create_provider(ProviderList.OPENSTACK, config)
  62. Some optional configuration values can only be provided through the config
  63. dictionary. These are listed below for each provider.
  64. CloudBridge
  65. ~~~~~~~~~~~
  66. +----------------------+------------------------------------------------------------+
  67. | Variable | Description |
  68. +======================+============================================================+
  69. | default_result_limit | Number of results that a ``.list()`` method should return. |
  70. | | Default is 50. |
  71. +----------------------+------------------------------------------------------------+
  72. AWS
  73. ~~~
  74. +---------------------+--------------------------------------------------------------+
  75. | Variable | Description |
  76. +=====================+==============================================================+
  77. | aws_region_name | Default region name. Default is ``us-east-1``. |
  78. +---------------------+--------------------------------------------------------------+
  79. | aws_zone_name | Default zone name. If not specified, defaults to first zone |
  80. | | in default region. If specified, must match default region. |
  81. +---------------------+--------------------------------------------------------------+
  82. | aws_session_token | Session key for your AWS account (if using temporary |
  83. | | credentials). |
  84. +---------------------+--------------------------------------------------------------+
  85. | ec2_endpoint_url | Endpoint to use. Default is ``ec2.us-east-1.amazonaws.com``. |
  86. +---------------------+--------------------------------------------------------------+
  87. | ec2_is_secure | True to use an SSL connection. Default is ``True``. |
  88. +---------------------+--------------------------------------------------------------+
  89. | ec2_validate_certs | Whether to use SSL certificate verification. Default is |
  90. | | ``False``. |
  91. +---------------------+--------------------------------------------------------------+
  92. | ec2_retries_value | The number of retries to configure boto ec2 client with |
  93. | | Default is ``4``. |
  94. +---------------------+--------------------------------------------------------------+
  95. | s3_endpoint_url | Host connection endpoint. Default is ``s3.amazonaws.com``. |
  96. +---------------------+--------------------------------------------------------------+
  97. | s3_is_secure | True to use an SSL connection. Default is ``True``. |
  98. +---------------------+--------------------------------------------------------------+
  99. | s3_validate_certs | Whether to use SSL certificate verification. Default is |
  100. | | ``False``. |
  101. +---------------------+--------------------------------------------------------------+
  102. Azure
  103. ~~~~~
  104. +-------------------------------------+----------------------------------------------------------+
  105. | Variable | Description |
  106. +=====================================+==========================================================+
  107. | azure_access_token | To sign requests to APIs protected by Azure. |
  108. +-------------------------------------+----------------------------------------------------------+
  109. | azure_public_key_storage_table_name | Storage table name where the key pairs are stored. |
  110. | | Default is ``cbcerts``. |
  111. +-------------------------------------+----------------------------------------------------------+
  112. | azure_region_name | Default region to use for the current |
  113. | | session. Default is ``eastus``. |
  114. +-------------------------------------+----------------------------------------------------------+
  115. | aws_zone_name | Default zone name. If not specified, defaults to first |
  116. | | zone in default region. If specified, must match default |
  117. | | region. |
  118. +-------------------------------------+----------------------------------------------------------+
  119. | azure_resource_group | Azure resource group to use. Default is ``cloudbridge``. |
  120. +-------------------------------------+----------------------------------------------------------+
  121. | azure_storage_account | Azure storage account to use. Note that this value must |
  122. | | be unique across Azure and all data in a given session |
  123. | | is stored within the supplied storage account. Default |
  124. | | ``storacc`` + first 6 chars of subscription id + first 6 |
  125. | | chars of the supplied resource group. |
  126. +-------------------------------------+----------------------------------------------------------+
  127. | azure_vm_default_username | System user name for which supplied key pair will be |
  128. | | placed. |
  129. +-------------------------------------+----------------------------------------------------------+
  130. GCP
  131. ~~~
  132. +-------------------------+------------------------------------------------------------------------+
  133. | Variable | Description |
  134. +=========================+========================================================================+
  135. | gcp_region_name | Default region to use for the current session. Default is |
  136. | | ``us-central1``. |
  137. +-------------------------+------------------------------------------------------------------------+
  138. | gcp_zone_name | Default zone name. If not specified, defaults to first zone in |
  139. | | default region. If specified, must match default region. |
  140. +-------------------------+------------------------------------------------------------------------+
  141. | gcp_vm_default_username | System user name for which supplied key pair will be placed. |
  142. +-------------------------+------------------------------------------------------------------------+
  143. | gcp_credentials_obj | Provided to support advanced usage scenarios where an alternative |
  144. | | authentication mechanism is required for GCP. This object replaces |
  145. | | `GCP_SERVICE_CREDS_DICT` and is directly passed to the underlying |
  146. | | python sdk's build method as |
  147. | | ``discovery.build('storage', 'v1', credentials=gcp_credentials_obj)``. |
  148. | | You can pass in a manually constructed credentials object such as |
  149. | | ``creds = AccessTokenCredentials(access_token, "MyAgent/1.0", None)``. |
  150. | | Refer to the GCP python sdk for available options. |
  151. +-------------------------+------------------------------------------------------------------------+
  152. OpenStack
  153. ~~~~~~~~~
  154. +-------------------------+--------------------------------------------------------------+
  155. | Variable | Description |
  156. +=========================+==============================================================+
  157. | os_auth_url | Required. OpenStack authentication endpoint. |
  158. | | eg: https://my-openstack.com:5000/v3 |
  159. +-------------------------+--------------------------------------------------------------+
  160. | os_username | Required. Username for authentication. |
  161. +-------------------------+--------------------------------------------------------------+
  162. | os_password | Required. password for authentication. |
  163. +-------------------------+--------------------------------------------------------------+
  164. | os_project_name | Required. The project in which to manage resources. |
  165. +-------------------------+--------------------------------------------------------------+
  166. | os_region_name | Required. Region in which to manage resources. |
  167. +-------------------------+--------------------------------------------------------------+
  168. | os_zone_name | Default Availability Zone in which to manage resources. |
  169. | | If not provided, will default to the first available zone |
  170. | | in the region. This zone will be the default for all services|
  171. | | unless overwritten by service-specific zone configs |
  172. +-------------------------+--------------------------------------------------------------+
  173. | os_compute_zone_name | Default Availability Zone for Compute servies. |
  174. | | If not provided, will default to `os_zone_name` |
  175. +-------------------------+--------------------------------------------------------------+
  176. | os_networking_zone_name | Default Availability Zone for Networking servies. |
  177. | | If not provided, will default to `os_zone_name` |
  178. +-------------------------+--------------------------------------------------------------+
  179. | os_security_zone_name | Default Availability Zone for Security servies. |
  180. | | If not provided, will default to `os_zone_name` |
  181. +-------------------------+--------------------------------------------------------------+
  182. | os_storage_zone_name | Default Availability Zone for Storage servies. |
  183. | | If not provided, will default to `os_zone_name` |
  184. +-------------------------+--------------------------------------------------------------+
  185. | nova_service_name | Service name for the NOVA client. |
  186. +-------------------------+--------------------------------------------------------------+
  187. | os_auth_token | Authentication token, if applicable. |
  188. +-------------------------+--------------------------------------------------------------+
  189. | os_compute_api_version | Compute API version, if applicable. |
  190. +-------------------------+--------------------------------------------------------------+
  191. | os_volume_api_version | Volume API version, if applicable. |
  192. +-------------------------+--------------------------------------------------------------+
  193. | os_storage_url | Storage endpoint URL, if applicable |
  194. +-------------------------+--------------------------------------------------------------+
  195. | os_project_domain_id | Project domain id for authentication. |
  196. +-------------------------+--------------------------------------------------------------+
  197. | os_project_domain_name | Project domain name for authentication. |
  198. +-------------------------+--------------------------------------------------------------+
  199. | os_user_domain_name | User domain name for authentication. |
  200. +-------------------------+--------------------------------------------------------------+
  201. Providing access credentials through environment variables
  202. ----------------------------------------------------------
  203. The following environment variables must be set, depending on the provider in
  204. use. For the meaning of the variables and default values, see the descriptions
  205. above.
  206. AWS
  207. ~~~
  208. +---------------------+------------+
  209. | Variable | Required? |
  210. +=====================+============+
  211. | AWS_ACCESS_KEY | ✔ |
  212. +---------------------+------------+
  213. | AWS_SECRET_KEY | ✔ |
  214. +---------------------+------------+
  215. Azure
  216. ~~~~~
  217. Note that managing resources in Azure requires a Resource Group. If a
  218. Resource Group is not provided as part of the configuration, CloudBridge will
  219. attempt to create a Resource Group using the given credentials. This
  220. operation will happen with the client initialization, and requires a
  221. "contributor" or "owner" role.
  222. Similarly, a Storage Account is required when managing some resources, such
  223. as key pairs and buckets. If a Storage Account name is not provided as part
  224. of the configuration, CloudBridge will attempt to create the Storage Account
  225. when initializing the relevant services. This operation similarly requires a
  226. "contributor" or "owner" role.
  227. For more information on roles, see
  228. https://docs.microsoft.com/en-us/azure/role-based-access-control/overview.
  229. +-------------------------------------+-----------+
  230. | Variable | Required? |
  231. +=====================================+===========+
  232. | AZURE_CLIENT_ID | ✔ |
  233. +-------------------------------------+-----------+
  234. | AZURE_SECRET | ✔ |
  235. +-------------------------------------+-----------+
  236. | AZURE_SUBSCRIPTION_ID | ✔ |
  237. +-------------------------------------+-----------+
  238. | AZURE_TENANT | ✔ |
  239. +-------------------------------------+-----------+
  240. | AZURE_PUBLIC_KEY_STORAGE_TABLE_NAME | |
  241. +-------------------------------------+-----------+
  242. | AZURE_REGION_NAME | |
  243. +-------------------------------------+-----------+
  244. | AZURE_ZONE_NAME | |
  245. +-------------------------------------+-----------+
  246. | AZURE_RESOURCE_GROUP | |
  247. +-------------------------------------+-----------+
  248. | AZURE_STORAGE_ACCOUNT | |
  249. +-------------------------------------+-----------+
  250. | AZURE_VM_DEFAULT_USER_NAME | |
  251. +-------------------------------------+-----------+
  252. GCP
  253. ~~~
  254. +------------------------+-----------+
  255. | Variable | Required? |
  256. +========================+===========+
  257. | GCP_SERVICE_CREDS_DICT | ✔ |
  258. | or | |
  259. | GCP_SERVICE_CREDS_FILE | |
  260. +------------------------+-----------+
  261. | GCP_ZONE_NAME | |
  262. +------------------------+-----------+
  263. | GCP_PROJECT_NAME | |
  264. +------------------------+-----------+
  265. | GCP_REGION_NAME | |
  266. +------------------------+-----------+
  267. OpenStack
  268. ~~~~~~~~~
  269. +----------------------------------+-----------+
  270. | Variable | Required? |
  271. +==================================+===========+
  272. | OS_AUTH_URL | ✔ |
  273. +----------------------------------+-----------+
  274. | OS_USERNAME | ✔? |
  275. +----------------------------------+-----------+
  276. | OS_PASSWORD | ✔? |
  277. +----------------------------------+-----------+
  278. | OS_APPLICATION_CREDENTIAL_ID | ✔? |
  279. +----------------------------------+-----------+
  280. | OS_APPLICATION_CREDENTIAL_SECRET | ✔? |
  281. +----------------------------------+-----------+
  282. | OS_PROJECT_NAME | ✔ |
  283. +----------------------------------+-----------+
  284. | OS_REGION_NAME | ✔ |
  285. +----------------------------------+-----------+
  286. | OS_ZONE_NAME | ✔ |
  287. +----------------------------------+-----------+
  288. | OS_COMPUTE_ZONE_NAME | |
  289. +----------------------------------+-----------+
  290. | OS_NETWORKING_ZONE_NAME | |
  291. +----------------------------------+-----------+
  292. | OS_SECURITY_ZONE_NAME | |
  293. +----------------------------------+-----------+
  294. | OS_STORAGE_ZONE_NAME | |
  295. +----------------------------------+-----------+
  296. | NOVA_SERVICE_NAME | |
  297. +----------------------------------+-----------+
  298. | OS_AUTH_TOKEN | |
  299. +----------------------------------+-----------+
  300. | OS_COMPUTE_API_VERSION | |
  301. +----------------------------------+-----------+
  302. | OS_VOLUME_API_VERSION | |
  303. +----------------------------------+-----------+
  304. | OS_STORAGE_URL | |
  305. +----------------------------------+-----------+
  306. | OS_PROJECT_DOMAIN_ID | |
  307. +----------------------------------+-----------+
  308. | OS_PROJECT_DOMAIN_NAME | |
  309. +----------------------------------+-----------+
  310. | OS_USER_DOMAIN_NAME | |
  311. +----------------------------------+-----------+
  312. Once the environment variables are set, you can create a connection as follows,
  313. replacing ``ProviderList.AWS`` with the desired provider (AZURE, GCP, or
  314. OPENSTACK):
  315. .. code-block:: python
  316. from cloudbridge.factory import CloudProviderFactory, ProviderList
  317. provider = CloudProviderFactory().create_provider(ProviderList.AWS, {})
  318. Providing access credentials in a CloudBridge config file
  319. ---------------------------------------------------------
  320. CloudBridge can also read credentials from a file on your local file system.
  321. The file should be placed in one of two locations: ``/etc/cloudbridge.ini`` or
  322. ``~/.cloudbridge``. Each set of credentials should be delineated with the
  323. provider ID (e.g., ``openstack``, ``aws``, ``azure``, ``gcp``) with the
  324. necessary credentials being supplied in YAML format. Note that only one set
  325. of credentials per cloud provider type can be supplied (i.e., via this
  326. method, it is not possible to provide credentials for two different
  327. OpenStack clouds).
  328. .. code-block:: bash
  329. [aws]
  330. aws_access_key: access key
  331. aws_secret_key: secret key
  332. [azure]
  333. azure_subscription_id: subscription id
  334. azure_tenant: tenant
  335. azure_client_id: client id
  336. azure_secret: secret
  337. azure_resource_group: resource group
  338. [gcp]
  339. gcp_service_creds_file: absolute path to credentials file
  340. [openstack]
  341. os_username: username
  342. os_password: password
  343. os_auth_url: auth url
  344. os_user_domain_name: user domain name
  345. os_project_domain_id: project domain id
  346. os_project_domain_name: project domain name
  347. os_project_name: project name
  348. Once the file is created, you can create a connection as follows, replacing
  349. ``ProviderList.AWS`` with the desired provider (AZURE, GCP, or OPENSTACK):
  350. .. code-block:: python
  351. from cloudbridge.factory import CloudProviderFactory, ProviderList
  352. provider = CloudProviderFactory().create_provider(ProviderList.AWS, {})
  353. General configuration variables
  354. -------------------------------
  355. In addition to the provider specific configuration variables above, there are
  356. some general configuration environment variables that apply to CloudBridge as
  357. a whole.
  358. +-----------------------------+------------------------------------------------------+
  359. | Variable | Description |
  360. +=============================+======================================================+
  361. | CB_DEBUG | Setting ``CB_DEBUG=True`` will cause detailed |
  362. | | debug output to be printed for each provider |
  363. | | (including HTTP traces). |
  364. +-----------------------------+------------------------------------------------------+
  365. | CB_TEST_PROVIDER | Set this value to a valid :class:`.ProviderList` |
  366. | | value such as ``aws``, to limit tests to that |
  367. | | provider only. |
  368. +-----------------------------+------------------------------------------------------+
  369. | CB_DEFAULT_SUBNET_LABEL | Name to be used for a subnet that will be |
  370. | | considered the 'default' by the library. This |
  371. | | default will be used only in cases there is no |
  372. | | subnet marked as the default by the provider. |
  373. +-----------------------------+------------------------------------------------------+
  374. | CB_DEFAULT_NETWORK_LABEL | Name to be used for a network that will be |
  375. | | considered the 'default' by the library. This |
  376. | | default will be used only in cases there is no |
  377. | | network marked as the default by the provider. |
  378. +-----------------------------+------------------------------------------------------+
  379. | CB_DEFAULT_IPV4RANGE | The default IPv4 range when creating networks if |
  380. | | one is not provided. This value is also used in |
  381. | | tests. |
  382. +-----------------------------+------------------------------------------------------+
  383. | CB_DEFAULT_SUBNET_IPV4RANGE | The default subnet IPv4 range used by CloudBridge |
  384. | | if one is not specified by the user. Tests do not |
  385. | | respect this variable. |
  386. +-----------------------------+------------------------------------------------------+