mirror of
				https://github.com/optim-enterprises-bv/kubernetes.git
				synced 2025-11-03 19:58:17 +00:00 
			
		
		
		
	Merge pull request #30888 from humblec/mypr/29006
Automatic merge from submit-queue GlusterFS dynamic provisioner and deleter interface based on storageclass claims This PR depends on PR#29006
This commit is contained in:
		
							
								
								
									
										20
									
								
								Godeps/Godeps.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										20
									
								
								Godeps/Godeps.json
									
									
									
										generated
									
									
									
								
							@@ -1370,6 +1370,21 @@
 | 
			
		||||
			"Comment": "v0.5.1-1-g1d46ce7",
 | 
			
		||||
			"Rev": "1d46ce7e1eca635f372357a8ccbf1fa7cc28b7d2"
 | 
			
		||||
		},
 | 
			
		||||
		{
 | 
			
		||||
			"ImportPath": "github.com/heketi/heketi/client/api/go-client",
 | 
			
		||||
			"Comment": "v2.1.0-dev-2-gcb07059",
 | 
			
		||||
			"Rev": "cb07059aed8760ef857a58d37598b9e51c36a9ae"
 | 
			
		||||
		},
 | 
			
		||||
		{
 | 
			
		||||
			"ImportPath": "github.com/heketi/heketi/pkg/glusterfs/api",
 | 
			
		||||
			"Comment": "v2.1.0-dev-2-gcb07059",
 | 
			
		||||
			"Rev": "cb07059aed8760ef857a58d37598b9e51c36a9ae"
 | 
			
		||||
		},
 | 
			
		||||
		{
 | 
			
		||||
			"ImportPath": "github.com/heketi/heketi/pkg/utils",
 | 
			
		||||
			"Comment": "v2.1.0-dev-2-gcb07059",
 | 
			
		||||
			"Rev": "cb07059aed8760ef857a58d37598b9e51c36a9ae"
 | 
			
		||||
		},
 | 
			
		||||
		{
 | 
			
		||||
			"ImportPath": "github.com/imdario/mergo",
 | 
			
		||||
			"Comment": "0.1.3-8-g6633656",
 | 
			
		||||
@@ -1441,6 +1456,11 @@
 | 
			
		||||
			"Comment": "release.r56-29-gf7ee69f",
 | 
			
		||||
			"Rev": "f7ee69f31298ecbe5d2b349c711e2547a617d398"
 | 
			
		||||
		},
 | 
			
		||||
		{
 | 
			
		||||
			"ImportPath": "github.com/lpabon/godbc",
 | 
			
		||||
			"Comment": "v1.0-1-g9577782",
 | 
			
		||||
			"Rev": "9577782540c1398b710ddae1b86268ba03a19b0c"
 | 
			
		||||
		},
 | 
			
		||||
		{
 | 
			
		||||
			"ImportPath": "github.com/mailru/easyjson/buffer",
 | 
			
		||||
			"Rev": "d5b7844b561a7bc640052f1b935f7b800330d7e0"
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										832
									
								
								Godeps/LICENSES
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										832
									
								
								Godeps/LICENSES
									
									
									
										generated
									
									
									
								
							@@ -46653,6 +46653,630 @@ Exhibit B - "Incompatible With Secondary Licenses" Notice
 | 
			
		||||
================================================================================
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
================================================================================
 | 
			
		||||
= vendor/github.com/heketi/heketi/client/api/go-client licensed under: =
 | 
			
		||||
 | 
			
		||||
Apache License
 | 
			
		||||
                           Version 2.0, January 2004
 | 
			
		||||
                        http://www.apache.org/licenses/
 | 
			
		||||
 | 
			
		||||
   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
 | 
			
		||||
 | 
			
		||||
   1. Definitions.
 | 
			
		||||
 | 
			
		||||
      "License" shall mean the terms and conditions for use, reproduction,
 | 
			
		||||
      and distribution as defined by Sections 1 through 9 of this document.
 | 
			
		||||
 | 
			
		||||
      "Licensor" shall mean the copyright owner or entity authorized by
 | 
			
		||||
      the copyright owner that is granting the License.
 | 
			
		||||
 | 
			
		||||
      "Legal Entity" shall mean the union of the acting entity and all
 | 
			
		||||
      other entities that control, are controlled by, or are under common
 | 
			
		||||
      control with that entity. For the purposes of this definition,
 | 
			
		||||
      "control" means (i) the power, direct or indirect, to cause the
 | 
			
		||||
      direction or management of such entity, whether by contract or
 | 
			
		||||
      otherwise, or (ii) ownership of fifty percent (50%) or more of the
 | 
			
		||||
      outstanding shares, or (iii) beneficial ownership of such entity.
 | 
			
		||||
 | 
			
		||||
      "You" (or "Your") shall mean an individual or Legal Entity
 | 
			
		||||
      exercising permissions granted by this License.
 | 
			
		||||
 | 
			
		||||
      "Source" form shall mean the preferred form for making modifications,
 | 
			
		||||
      including but not limited to software source code, documentation
 | 
			
		||||
      source, and configuration files.
 | 
			
		||||
 | 
			
		||||
      "Object" form shall mean any form resulting from mechanical
 | 
			
		||||
      transformation or translation of a Source form, including but
 | 
			
		||||
      not limited to compiled object code, generated documentation,
 | 
			
		||||
      and conversions to other media types.
 | 
			
		||||
 | 
			
		||||
      "Work" shall mean the work of authorship, whether in Source or
 | 
			
		||||
      Object form, made available under the License, as indicated by a
 | 
			
		||||
      copyright notice that is included in or attached to the work
 | 
			
		||||
      (an example is provided in the Appendix below).
 | 
			
		||||
 | 
			
		||||
      "Derivative Works" shall mean any work, whether in Source or Object
 | 
			
		||||
      form, that is based on (or derived from) the Work and for which the
 | 
			
		||||
      editorial revisions, annotations, elaborations, or other modifications
 | 
			
		||||
      represent, as a whole, an original work of authorship. For the purposes
 | 
			
		||||
      of this License, Derivative Works shall not include works that remain
 | 
			
		||||
      separable from, or merely link (or bind by name) to the interfaces of,
 | 
			
		||||
      the Work and Derivative Works thereof.
 | 
			
		||||
 | 
			
		||||
      "Contribution" shall mean any work of authorship, including
 | 
			
		||||
      the original version of the Work and any modifications or additions
 | 
			
		||||
      to that Work or Derivative Works thereof, that is intentionally
 | 
			
		||||
      submitted to Licensor for inclusion in the Work by the copyright owner
 | 
			
		||||
      or by an individual or Legal Entity authorized to submit on behalf of
 | 
			
		||||
      the copyright owner. For the purposes of this definition, "submitted"
 | 
			
		||||
      means any form of electronic, verbal, or written communication sent
 | 
			
		||||
      to the Licensor or its representatives, including but not limited to
 | 
			
		||||
      communication on electronic mailing lists, source code control systems,
 | 
			
		||||
      and issue tracking systems that are managed by, or on behalf of, the
 | 
			
		||||
      Licensor for the purpose of discussing and improving the Work, but
 | 
			
		||||
      excluding communication that is conspicuously marked or otherwise
 | 
			
		||||
      designated in writing by the copyright owner as "Not a Contribution."
 | 
			
		||||
 | 
			
		||||
      "Contributor" shall mean Licensor and any individual or Legal Entity
 | 
			
		||||
      on behalf of whom a Contribution has been received by Licensor and
 | 
			
		||||
      subsequently incorporated within the Work.
 | 
			
		||||
 | 
			
		||||
   2. Grant of Copyright License. Subject to the terms and conditions of
 | 
			
		||||
      this License, each Contributor hereby grants to You a perpetual,
 | 
			
		||||
      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
 | 
			
		||||
      copyright license to reproduce, prepare Derivative Works of,
 | 
			
		||||
      publicly display, publicly perform, sublicense, and distribute the
 | 
			
		||||
      Work and such Derivative Works in Source or Object form.
 | 
			
		||||
 | 
			
		||||
   3. Grant of Patent License. Subject to the terms and conditions of
 | 
			
		||||
      this License, each Contributor hereby grants to You a perpetual,
 | 
			
		||||
      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
 | 
			
		||||
      (except as stated in this section) patent license to make, have made,
 | 
			
		||||
      use, offer to sell, sell, import, and otherwise transfer the Work,
 | 
			
		||||
      where such license applies only to those patent claims licensable
 | 
			
		||||
      by such Contributor that are necessarily infringed by their
 | 
			
		||||
      Contribution(s) alone or by combination of their Contribution(s)
 | 
			
		||||
      with the Work to which such Contribution(s) was submitted. If You
 | 
			
		||||
      institute patent litigation against any entity (including a
 | 
			
		||||
      cross-claim or counterclaim in a lawsuit) alleging that the Work
 | 
			
		||||
      or a Contribution incorporated within the Work constitutes direct
 | 
			
		||||
      or contributory patent infringement, then any patent licenses
 | 
			
		||||
      granted to You under this License for that Work shall terminate
 | 
			
		||||
      as of the date such litigation is filed.
 | 
			
		||||
 | 
			
		||||
   4. Redistribution. You may reproduce and distribute copies of the
 | 
			
		||||
      Work or Derivative Works thereof in any medium, with or without
 | 
			
		||||
      modifications, and in Source or Object form, provided that You
 | 
			
		||||
      meet the following conditions:
 | 
			
		||||
 | 
			
		||||
      (a) You must give any other recipients of the Work or
 | 
			
		||||
          Derivative Works a copy of this License; and
 | 
			
		||||
 | 
			
		||||
      (b) You must cause any modified files to carry prominent notices
 | 
			
		||||
          stating that You changed the files; and
 | 
			
		||||
 | 
			
		||||
      (c) You must retain, in the Source form of any Derivative Works
 | 
			
		||||
          that You distribute, all copyright, patent, trademark, and
 | 
			
		||||
          attribution notices from the Source form of the Work,
 | 
			
		||||
          excluding those notices that do not pertain to any part of
 | 
			
		||||
          the Derivative Works; and
 | 
			
		||||
 | 
			
		||||
      (d) If the Work includes a "NOTICE" text file as part of its
 | 
			
		||||
          distribution, then any Derivative Works that You distribute must
 | 
			
		||||
          include a readable copy of the attribution notices contained
 | 
			
		||||
          within such NOTICE file, excluding those notices that do not
 | 
			
		||||
          pertain to any part of the Derivative Works, in at least one
 | 
			
		||||
          of the following places: within a NOTICE text file distributed
 | 
			
		||||
          as part of the Derivative Works; within the Source form or
 | 
			
		||||
          documentation, if provided along with the Derivative Works; or,
 | 
			
		||||
          within a display generated by the Derivative Works, if and
 | 
			
		||||
          wherever such third-party notices normally appear. The contents
 | 
			
		||||
          of the NOTICE file are for informational purposes only and
 | 
			
		||||
          do not modify the License. You may add Your own attribution
 | 
			
		||||
          notices within Derivative Works that You distribute, alongside
 | 
			
		||||
          or as an addendum to the NOTICE text from the Work, provided
 | 
			
		||||
          that such additional attribution notices cannot be construed
 | 
			
		||||
          as modifying the License.
 | 
			
		||||
 | 
			
		||||
      You may add Your own copyright statement to Your modifications and
 | 
			
		||||
      may provide additional or different license terms and conditions
 | 
			
		||||
      for use, reproduction, or distribution of Your modifications, or
 | 
			
		||||
      for any such Derivative Works as a whole, provided Your use,
 | 
			
		||||
      reproduction, and distribution of the Work otherwise complies with
 | 
			
		||||
      the conditions stated in this License.
 | 
			
		||||
 | 
			
		||||
   5. Submission of Contributions. Unless You explicitly state otherwise,
 | 
			
		||||
      any Contribution intentionally submitted for inclusion in the Work
 | 
			
		||||
      by You to the Licensor shall be under the terms and conditions of
 | 
			
		||||
      this License, without any additional terms or conditions.
 | 
			
		||||
      Notwithstanding the above, nothing herein shall supersede or modify
 | 
			
		||||
      the terms of any separate license agreement you may have executed
 | 
			
		||||
      with Licensor regarding such Contributions.
 | 
			
		||||
 | 
			
		||||
   6. Trademarks. This License does not grant permission to use the trade
 | 
			
		||||
      names, trademarks, service marks, or product names of the Licensor,
 | 
			
		||||
      except as required for reasonable and customary use in describing the
 | 
			
		||||
      origin of the Work and reproducing the content of the NOTICE file.
 | 
			
		||||
 | 
			
		||||
   7. Disclaimer of Warranty. Unless required by applicable law or
 | 
			
		||||
      agreed to in writing, Licensor provides the Work (and each
 | 
			
		||||
      Contributor provides its Contributions) on an "AS IS" BASIS,
 | 
			
		||||
      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
 | 
			
		||||
      implied, including, without limitation, any warranties or conditions
 | 
			
		||||
      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
 | 
			
		||||
      PARTICULAR PURPOSE. You are solely responsible for determining the
 | 
			
		||||
      appropriateness of using or redistributing the Work and assume any
 | 
			
		||||
      risks associated with Your exercise of permissions under this License.
 | 
			
		||||
 | 
			
		||||
   8. Limitation of Liability. In no event and under no legal theory,
 | 
			
		||||
      whether in tort (including negligence), contract, or otherwise,
 | 
			
		||||
      unless required by applicable law (such as deliberate and grossly
 | 
			
		||||
      negligent acts) or agreed to in writing, shall any Contributor be
 | 
			
		||||
      liable to You for damages, including any direct, indirect, special,
 | 
			
		||||
      incidental, or consequential damages of any character arising as a
 | 
			
		||||
      result of this License or out of the use or inability to use the
 | 
			
		||||
      Work (including but not limited to damages for loss of goodwill,
 | 
			
		||||
      work stoppage, computer failure or malfunction, or any and all
 | 
			
		||||
      other commercial damages or losses), even if such Contributor
 | 
			
		||||
      has been advised of the possibility of such damages.
 | 
			
		||||
 | 
			
		||||
   9. Accepting Warranty or Additional Liability. While redistributing
 | 
			
		||||
      the Work or Derivative Works thereof, You may choose to offer,
 | 
			
		||||
      and charge a fee for, acceptance of support, warranty, indemnity,
 | 
			
		||||
      or other liability obligations and/or rights consistent with this
 | 
			
		||||
      License. However, in accepting such obligations, You may act only
 | 
			
		||||
      on Your own behalf and on Your sole responsibility, not on behalf
 | 
			
		||||
      of any other Contributor, and only if You agree to indemnify,
 | 
			
		||||
      defend, and hold each Contributor harmless for any liability
 | 
			
		||||
      incurred by, or claims asserted against, such Contributor by reason
 | 
			
		||||
      of your accepting any such warranty or additional liability.
 | 
			
		||||
 | 
			
		||||
   END OF TERMS AND CONDITIONS
 | 
			
		||||
 | 
			
		||||
   APPENDIX: How to apply the Apache License to your work.
 | 
			
		||||
 | 
			
		||||
      To apply the Apache License to your work, attach the following
 | 
			
		||||
      boilerplate notice, with the fields enclosed by brackets "{}"
 | 
			
		||||
      replaced with your own identifying information. (Don't include
 | 
			
		||||
      the brackets!)  The text should be enclosed in the appropriate
 | 
			
		||||
      comment syntax for the file format. We also recommend that a
 | 
			
		||||
      file or class name and description of purpose be included on the
 | 
			
		||||
      same "printed page" as the copyright notice for easier
 | 
			
		||||
      identification within third-party archives.
 | 
			
		||||
 | 
			
		||||
   Copyright {yyyy} {name of copyright owner}
 | 
			
		||||
 | 
			
		||||
   Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
   you may not use this file except in compliance with the License.
 | 
			
		||||
   You may obtain a copy of the License at
 | 
			
		||||
 | 
			
		||||
       http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 | 
			
		||||
   Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
   distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
   See the License for the specific language governing permissions and
 | 
			
		||||
   limitations under the License.
 | 
			
		||||
= vendor/github.com/heketi/heketi/LICENSE 6c4db32a2fa8717faffa1d4f10136f47  -
 | 
			
		||||
================================================================================
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
================================================================================
 | 
			
		||||
= vendor/github.com/heketi/heketi/pkg/glusterfs/api licensed under: =
 | 
			
		||||
 | 
			
		||||
Apache License
 | 
			
		||||
                           Version 2.0, January 2004
 | 
			
		||||
                        http://www.apache.org/licenses/
 | 
			
		||||
 | 
			
		||||
   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
 | 
			
		||||
 | 
			
		||||
   1. Definitions.
 | 
			
		||||
 | 
			
		||||
      "License" shall mean the terms and conditions for use, reproduction,
 | 
			
		||||
      and distribution as defined by Sections 1 through 9 of this document.
 | 
			
		||||
 | 
			
		||||
      "Licensor" shall mean the copyright owner or entity authorized by
 | 
			
		||||
      the copyright owner that is granting the License.
 | 
			
		||||
 | 
			
		||||
      "Legal Entity" shall mean the union of the acting entity and all
 | 
			
		||||
      other entities that control, are controlled by, or are under common
 | 
			
		||||
      control with that entity. For the purposes of this definition,
 | 
			
		||||
      "control" means (i) the power, direct or indirect, to cause the
 | 
			
		||||
      direction or management of such entity, whether by contract or
 | 
			
		||||
      otherwise, or (ii) ownership of fifty percent (50%) or more of the
 | 
			
		||||
      outstanding shares, or (iii) beneficial ownership of such entity.
 | 
			
		||||
 | 
			
		||||
      "You" (or "Your") shall mean an individual or Legal Entity
 | 
			
		||||
      exercising permissions granted by this License.
 | 
			
		||||
 | 
			
		||||
      "Source" form shall mean the preferred form for making modifications,
 | 
			
		||||
      including but not limited to software source code, documentation
 | 
			
		||||
      source, and configuration files.
 | 
			
		||||
 | 
			
		||||
      "Object" form shall mean any form resulting from mechanical
 | 
			
		||||
      transformation or translation of a Source form, including but
 | 
			
		||||
      not limited to compiled object code, generated documentation,
 | 
			
		||||
      and conversions to other media types.
 | 
			
		||||
 | 
			
		||||
      "Work" shall mean the work of authorship, whether in Source or
 | 
			
		||||
      Object form, made available under the License, as indicated by a
 | 
			
		||||
      copyright notice that is included in or attached to the work
 | 
			
		||||
      (an example is provided in the Appendix below).
 | 
			
		||||
 | 
			
		||||
      "Derivative Works" shall mean any work, whether in Source or Object
 | 
			
		||||
      form, that is based on (or derived from) the Work and for which the
 | 
			
		||||
      editorial revisions, annotations, elaborations, or other modifications
 | 
			
		||||
      represent, as a whole, an original work of authorship. For the purposes
 | 
			
		||||
      of this License, Derivative Works shall not include works that remain
 | 
			
		||||
      separable from, or merely link (or bind by name) to the interfaces of,
 | 
			
		||||
      the Work and Derivative Works thereof.
 | 
			
		||||
 | 
			
		||||
      "Contribution" shall mean any work of authorship, including
 | 
			
		||||
      the original version of the Work and any modifications or additions
 | 
			
		||||
      to that Work or Derivative Works thereof, that is intentionally
 | 
			
		||||
      submitted to Licensor for inclusion in the Work by the copyright owner
 | 
			
		||||
      or by an individual or Legal Entity authorized to submit on behalf of
 | 
			
		||||
      the copyright owner. For the purposes of this definition, "submitted"
 | 
			
		||||
      means any form of electronic, verbal, or written communication sent
 | 
			
		||||
      to the Licensor or its representatives, including but not limited to
 | 
			
		||||
      communication on electronic mailing lists, source code control systems,
 | 
			
		||||
      and issue tracking systems that are managed by, or on behalf of, the
 | 
			
		||||
      Licensor for the purpose of discussing and improving the Work, but
 | 
			
		||||
      excluding communication that is conspicuously marked or otherwise
 | 
			
		||||
      designated in writing by the copyright owner as "Not a Contribution."
 | 
			
		||||
 | 
			
		||||
      "Contributor" shall mean Licensor and any individual or Legal Entity
 | 
			
		||||
      on behalf of whom a Contribution has been received by Licensor and
 | 
			
		||||
      subsequently incorporated within the Work.
 | 
			
		||||
 | 
			
		||||
   2. Grant of Copyright License. Subject to the terms and conditions of
 | 
			
		||||
      this License, each Contributor hereby grants to You a perpetual,
 | 
			
		||||
      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
 | 
			
		||||
      copyright license to reproduce, prepare Derivative Works of,
 | 
			
		||||
      publicly display, publicly perform, sublicense, and distribute the
 | 
			
		||||
      Work and such Derivative Works in Source or Object form.
 | 
			
		||||
 | 
			
		||||
   3. Grant of Patent License. Subject to the terms and conditions of
 | 
			
		||||
      this License, each Contributor hereby grants to You a perpetual,
 | 
			
		||||
      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
 | 
			
		||||
      (except as stated in this section) patent license to make, have made,
 | 
			
		||||
      use, offer to sell, sell, import, and otherwise transfer the Work,
 | 
			
		||||
      where such license applies only to those patent claims licensable
 | 
			
		||||
      by such Contributor that are necessarily infringed by their
 | 
			
		||||
      Contribution(s) alone or by combination of their Contribution(s)
 | 
			
		||||
      with the Work to which such Contribution(s) was submitted. If You
 | 
			
		||||
      institute patent litigation against any entity (including a
 | 
			
		||||
      cross-claim or counterclaim in a lawsuit) alleging that the Work
 | 
			
		||||
      or a Contribution incorporated within the Work constitutes direct
 | 
			
		||||
      or contributory patent infringement, then any patent licenses
 | 
			
		||||
      granted to You under this License for that Work shall terminate
 | 
			
		||||
      as of the date such litigation is filed.
 | 
			
		||||
 | 
			
		||||
   4. Redistribution. You may reproduce and distribute copies of the
 | 
			
		||||
      Work or Derivative Works thereof in any medium, with or without
 | 
			
		||||
      modifications, and in Source or Object form, provided that You
 | 
			
		||||
      meet the following conditions:
 | 
			
		||||
 | 
			
		||||
      (a) You must give any other recipients of the Work or
 | 
			
		||||
          Derivative Works a copy of this License; and
 | 
			
		||||
 | 
			
		||||
      (b) You must cause any modified files to carry prominent notices
 | 
			
		||||
          stating that You changed the files; and
 | 
			
		||||
 | 
			
		||||
      (c) You must retain, in the Source form of any Derivative Works
 | 
			
		||||
          that You distribute, all copyright, patent, trademark, and
 | 
			
		||||
          attribution notices from the Source form of the Work,
 | 
			
		||||
          excluding those notices that do not pertain to any part of
 | 
			
		||||
          the Derivative Works; and
 | 
			
		||||
 | 
			
		||||
      (d) If the Work includes a "NOTICE" text file as part of its
 | 
			
		||||
          distribution, then any Derivative Works that You distribute must
 | 
			
		||||
          include a readable copy of the attribution notices contained
 | 
			
		||||
          within such NOTICE file, excluding those notices that do not
 | 
			
		||||
          pertain to any part of the Derivative Works, in at least one
 | 
			
		||||
          of the following places: within a NOTICE text file distributed
 | 
			
		||||
          as part of the Derivative Works; within the Source form or
 | 
			
		||||
          documentation, if provided along with the Derivative Works; or,
 | 
			
		||||
          within a display generated by the Derivative Works, if and
 | 
			
		||||
          wherever such third-party notices normally appear. The contents
 | 
			
		||||
          of the NOTICE file are for informational purposes only and
 | 
			
		||||
          do not modify the License. You may add Your own attribution
 | 
			
		||||
          notices within Derivative Works that You distribute, alongside
 | 
			
		||||
          or as an addendum to the NOTICE text from the Work, provided
 | 
			
		||||
          that such additional attribution notices cannot be construed
 | 
			
		||||
          as modifying the License.
 | 
			
		||||
 | 
			
		||||
      You may add Your own copyright statement to Your modifications and
 | 
			
		||||
      may provide additional or different license terms and conditions
 | 
			
		||||
      for use, reproduction, or distribution of Your modifications, or
 | 
			
		||||
      for any such Derivative Works as a whole, provided Your use,
 | 
			
		||||
      reproduction, and distribution of the Work otherwise complies with
 | 
			
		||||
      the conditions stated in this License.
 | 
			
		||||
 | 
			
		||||
   5. Submission of Contributions. Unless You explicitly state otherwise,
 | 
			
		||||
      any Contribution intentionally submitted for inclusion in the Work
 | 
			
		||||
      by You to the Licensor shall be under the terms and conditions of
 | 
			
		||||
      this License, without any additional terms or conditions.
 | 
			
		||||
      Notwithstanding the above, nothing herein shall supersede or modify
 | 
			
		||||
      the terms of any separate license agreement you may have executed
 | 
			
		||||
      with Licensor regarding such Contributions.
 | 
			
		||||
 | 
			
		||||
   6. Trademarks. This License does not grant permission to use the trade
 | 
			
		||||
      names, trademarks, service marks, or product names of the Licensor,
 | 
			
		||||
      except as required for reasonable and customary use in describing the
 | 
			
		||||
      origin of the Work and reproducing the content of the NOTICE file.
 | 
			
		||||
 | 
			
		||||
   7. Disclaimer of Warranty. Unless required by applicable law or
 | 
			
		||||
      agreed to in writing, Licensor provides the Work (and each
 | 
			
		||||
      Contributor provides its Contributions) on an "AS IS" BASIS,
 | 
			
		||||
      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
 | 
			
		||||
      implied, including, without limitation, any warranties or conditions
 | 
			
		||||
      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
 | 
			
		||||
      PARTICULAR PURPOSE. You are solely responsible for determining the
 | 
			
		||||
      appropriateness of using or redistributing the Work and assume any
 | 
			
		||||
      risks associated with Your exercise of permissions under this License.
 | 
			
		||||
 | 
			
		||||
   8. Limitation of Liability. In no event and under no legal theory,
 | 
			
		||||
      whether in tort (including negligence), contract, or otherwise,
 | 
			
		||||
      unless required by applicable law (such as deliberate and grossly
 | 
			
		||||
      negligent acts) or agreed to in writing, shall any Contributor be
 | 
			
		||||
      liable to You for damages, including any direct, indirect, special,
 | 
			
		||||
      incidental, or consequential damages of any character arising as a
 | 
			
		||||
      result of this License or out of the use or inability to use the
 | 
			
		||||
      Work (including but not limited to damages for loss of goodwill,
 | 
			
		||||
      work stoppage, computer failure or malfunction, or any and all
 | 
			
		||||
      other commercial damages or losses), even if such Contributor
 | 
			
		||||
      has been advised of the possibility of such damages.
 | 
			
		||||
 | 
			
		||||
   9. Accepting Warranty or Additional Liability. While redistributing
 | 
			
		||||
      the Work or Derivative Works thereof, You may choose to offer,
 | 
			
		||||
      and charge a fee for, acceptance of support, warranty, indemnity,
 | 
			
		||||
      or other liability obligations and/or rights consistent with this
 | 
			
		||||
      License. However, in accepting such obligations, You may act only
 | 
			
		||||
      on Your own behalf and on Your sole responsibility, not on behalf
 | 
			
		||||
      of any other Contributor, and only if You agree to indemnify,
 | 
			
		||||
      defend, and hold each Contributor harmless for any liability
 | 
			
		||||
      incurred by, or claims asserted against, such Contributor by reason
 | 
			
		||||
      of your accepting any such warranty or additional liability.
 | 
			
		||||
 | 
			
		||||
   END OF TERMS AND CONDITIONS
 | 
			
		||||
 | 
			
		||||
   APPENDIX: How to apply the Apache License to your work.
 | 
			
		||||
 | 
			
		||||
      To apply the Apache License to your work, attach the following
 | 
			
		||||
      boilerplate notice, with the fields enclosed by brackets "{}"
 | 
			
		||||
      replaced with your own identifying information. (Don't include
 | 
			
		||||
      the brackets!)  The text should be enclosed in the appropriate
 | 
			
		||||
      comment syntax for the file format. We also recommend that a
 | 
			
		||||
      file or class name and description of purpose be included on the
 | 
			
		||||
      same "printed page" as the copyright notice for easier
 | 
			
		||||
      identification within third-party archives.
 | 
			
		||||
 | 
			
		||||
   Copyright {yyyy} {name of copyright owner}
 | 
			
		||||
 | 
			
		||||
   Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
   you may not use this file except in compliance with the License.
 | 
			
		||||
   You may obtain a copy of the License at
 | 
			
		||||
 | 
			
		||||
       http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 | 
			
		||||
   Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
   distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
   See the License for the specific language governing permissions and
 | 
			
		||||
   limitations under the License.
 | 
			
		||||
= vendor/github.com/heketi/heketi/LICENSE 6c4db32a2fa8717faffa1d4f10136f47  -
 | 
			
		||||
================================================================================
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
================================================================================
 | 
			
		||||
= vendor/github.com/heketi/heketi/pkg/utils licensed under: =
 | 
			
		||||
 | 
			
		||||
Apache License
 | 
			
		||||
                           Version 2.0, January 2004
 | 
			
		||||
                        http://www.apache.org/licenses/
 | 
			
		||||
 | 
			
		||||
   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
 | 
			
		||||
 | 
			
		||||
   1. Definitions.
 | 
			
		||||
 | 
			
		||||
      "License" shall mean the terms and conditions for use, reproduction,
 | 
			
		||||
      and distribution as defined by Sections 1 through 9 of this document.
 | 
			
		||||
 | 
			
		||||
      "Licensor" shall mean the copyright owner or entity authorized by
 | 
			
		||||
      the copyright owner that is granting the License.
 | 
			
		||||
 | 
			
		||||
      "Legal Entity" shall mean the union of the acting entity and all
 | 
			
		||||
      other entities that control, are controlled by, or are under common
 | 
			
		||||
      control with that entity. For the purposes of this definition,
 | 
			
		||||
      "control" means (i) the power, direct or indirect, to cause the
 | 
			
		||||
      direction or management of such entity, whether by contract or
 | 
			
		||||
      otherwise, or (ii) ownership of fifty percent (50%) or more of the
 | 
			
		||||
      outstanding shares, or (iii) beneficial ownership of such entity.
 | 
			
		||||
 | 
			
		||||
      "You" (or "Your") shall mean an individual or Legal Entity
 | 
			
		||||
      exercising permissions granted by this License.
 | 
			
		||||
 | 
			
		||||
      "Source" form shall mean the preferred form for making modifications,
 | 
			
		||||
      including but not limited to software source code, documentation
 | 
			
		||||
      source, and configuration files.
 | 
			
		||||
 | 
			
		||||
      "Object" form shall mean any form resulting from mechanical
 | 
			
		||||
      transformation or translation of a Source form, including but
 | 
			
		||||
      not limited to compiled object code, generated documentation,
 | 
			
		||||
      and conversions to other media types.
 | 
			
		||||
 | 
			
		||||
      "Work" shall mean the work of authorship, whether in Source or
 | 
			
		||||
      Object form, made available under the License, as indicated by a
 | 
			
		||||
      copyright notice that is included in or attached to the work
 | 
			
		||||
      (an example is provided in the Appendix below).
 | 
			
		||||
 | 
			
		||||
      "Derivative Works" shall mean any work, whether in Source or Object
 | 
			
		||||
      form, that is based on (or derived from) the Work and for which the
 | 
			
		||||
      editorial revisions, annotations, elaborations, or other modifications
 | 
			
		||||
      represent, as a whole, an original work of authorship. For the purposes
 | 
			
		||||
      of this License, Derivative Works shall not include works that remain
 | 
			
		||||
      separable from, or merely link (or bind by name) to the interfaces of,
 | 
			
		||||
      the Work and Derivative Works thereof.
 | 
			
		||||
 | 
			
		||||
      "Contribution" shall mean any work of authorship, including
 | 
			
		||||
      the original version of the Work and any modifications or additions
 | 
			
		||||
      to that Work or Derivative Works thereof, that is intentionally
 | 
			
		||||
      submitted to Licensor for inclusion in the Work by the copyright owner
 | 
			
		||||
      or by an individual or Legal Entity authorized to submit on behalf of
 | 
			
		||||
      the copyright owner. For the purposes of this definition, "submitted"
 | 
			
		||||
      means any form of electronic, verbal, or written communication sent
 | 
			
		||||
      to the Licensor or its representatives, including but not limited to
 | 
			
		||||
      communication on electronic mailing lists, source code control systems,
 | 
			
		||||
      and issue tracking systems that are managed by, or on behalf of, the
 | 
			
		||||
      Licensor for the purpose of discussing and improving the Work, but
 | 
			
		||||
      excluding communication that is conspicuously marked or otherwise
 | 
			
		||||
      designated in writing by the copyright owner as "Not a Contribution."
 | 
			
		||||
 | 
			
		||||
      "Contributor" shall mean Licensor and any individual or Legal Entity
 | 
			
		||||
      on behalf of whom a Contribution has been received by Licensor and
 | 
			
		||||
      subsequently incorporated within the Work.
 | 
			
		||||
 | 
			
		||||
   2. Grant of Copyright License. Subject to the terms and conditions of
 | 
			
		||||
      this License, each Contributor hereby grants to You a perpetual,
 | 
			
		||||
      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
 | 
			
		||||
      copyright license to reproduce, prepare Derivative Works of,
 | 
			
		||||
      publicly display, publicly perform, sublicense, and distribute the
 | 
			
		||||
      Work and such Derivative Works in Source or Object form.
 | 
			
		||||
 | 
			
		||||
   3. Grant of Patent License. Subject to the terms and conditions of
 | 
			
		||||
      this License, each Contributor hereby grants to You a perpetual,
 | 
			
		||||
      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
 | 
			
		||||
      (except as stated in this section) patent license to make, have made,
 | 
			
		||||
      use, offer to sell, sell, import, and otherwise transfer the Work,
 | 
			
		||||
      where such license applies only to those patent claims licensable
 | 
			
		||||
      by such Contributor that are necessarily infringed by their
 | 
			
		||||
      Contribution(s) alone or by combination of their Contribution(s)
 | 
			
		||||
      with the Work to which such Contribution(s) was submitted. If You
 | 
			
		||||
      institute patent litigation against any entity (including a
 | 
			
		||||
      cross-claim or counterclaim in a lawsuit) alleging that the Work
 | 
			
		||||
      or a Contribution incorporated within the Work constitutes direct
 | 
			
		||||
      or contributory patent infringement, then any patent licenses
 | 
			
		||||
      granted to You under this License for that Work shall terminate
 | 
			
		||||
      as of the date such litigation is filed.
 | 
			
		||||
 | 
			
		||||
   4. Redistribution. You may reproduce and distribute copies of the
 | 
			
		||||
      Work or Derivative Works thereof in any medium, with or without
 | 
			
		||||
      modifications, and in Source or Object form, provided that You
 | 
			
		||||
      meet the following conditions:
 | 
			
		||||
 | 
			
		||||
      (a) You must give any other recipients of the Work or
 | 
			
		||||
          Derivative Works a copy of this License; and
 | 
			
		||||
 | 
			
		||||
      (b) You must cause any modified files to carry prominent notices
 | 
			
		||||
          stating that You changed the files; and
 | 
			
		||||
 | 
			
		||||
      (c) You must retain, in the Source form of any Derivative Works
 | 
			
		||||
          that You distribute, all copyright, patent, trademark, and
 | 
			
		||||
          attribution notices from the Source form of the Work,
 | 
			
		||||
          excluding those notices that do not pertain to any part of
 | 
			
		||||
          the Derivative Works; and
 | 
			
		||||
 | 
			
		||||
      (d) If the Work includes a "NOTICE" text file as part of its
 | 
			
		||||
          distribution, then any Derivative Works that You distribute must
 | 
			
		||||
          include a readable copy of the attribution notices contained
 | 
			
		||||
          within such NOTICE file, excluding those notices that do not
 | 
			
		||||
          pertain to any part of the Derivative Works, in at least one
 | 
			
		||||
          of the following places: within a NOTICE text file distributed
 | 
			
		||||
          as part of the Derivative Works; within the Source form or
 | 
			
		||||
          documentation, if provided along with the Derivative Works; or,
 | 
			
		||||
          within a display generated by the Derivative Works, if and
 | 
			
		||||
          wherever such third-party notices normally appear. The contents
 | 
			
		||||
          of the NOTICE file are for informational purposes only and
 | 
			
		||||
          do not modify the License. You may add Your own attribution
 | 
			
		||||
          notices within Derivative Works that You distribute, alongside
 | 
			
		||||
          or as an addendum to the NOTICE text from the Work, provided
 | 
			
		||||
          that such additional attribution notices cannot be construed
 | 
			
		||||
          as modifying the License.
 | 
			
		||||
 | 
			
		||||
      You may add Your own copyright statement to Your modifications and
 | 
			
		||||
      may provide additional or different license terms and conditions
 | 
			
		||||
      for use, reproduction, or distribution of Your modifications, or
 | 
			
		||||
      for any such Derivative Works as a whole, provided Your use,
 | 
			
		||||
      reproduction, and distribution of the Work otherwise complies with
 | 
			
		||||
      the conditions stated in this License.
 | 
			
		||||
 | 
			
		||||
   5. Submission of Contributions. Unless You explicitly state otherwise,
 | 
			
		||||
      any Contribution intentionally submitted for inclusion in the Work
 | 
			
		||||
      by You to the Licensor shall be under the terms and conditions of
 | 
			
		||||
      this License, without any additional terms or conditions.
 | 
			
		||||
      Notwithstanding the above, nothing herein shall supersede or modify
 | 
			
		||||
      the terms of any separate license agreement you may have executed
 | 
			
		||||
      with Licensor regarding such Contributions.
 | 
			
		||||
 | 
			
		||||
   6. Trademarks. This License does not grant permission to use the trade
 | 
			
		||||
      names, trademarks, service marks, or product names of the Licensor,
 | 
			
		||||
      except as required for reasonable and customary use in describing the
 | 
			
		||||
      origin of the Work and reproducing the content of the NOTICE file.
 | 
			
		||||
 | 
			
		||||
   7. Disclaimer of Warranty. Unless required by applicable law or
 | 
			
		||||
      agreed to in writing, Licensor provides the Work (and each
 | 
			
		||||
      Contributor provides its Contributions) on an "AS IS" BASIS,
 | 
			
		||||
      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
 | 
			
		||||
      implied, including, without limitation, any warranties or conditions
 | 
			
		||||
      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
 | 
			
		||||
      PARTICULAR PURPOSE. You are solely responsible for determining the
 | 
			
		||||
      appropriateness of using or redistributing the Work and assume any
 | 
			
		||||
      risks associated with Your exercise of permissions under this License.
 | 
			
		||||
 | 
			
		||||
   8. Limitation of Liability. In no event and under no legal theory,
 | 
			
		||||
      whether in tort (including negligence), contract, or otherwise,
 | 
			
		||||
      unless required by applicable law (such as deliberate and grossly
 | 
			
		||||
      negligent acts) or agreed to in writing, shall any Contributor be
 | 
			
		||||
      liable to You for damages, including any direct, indirect, special,
 | 
			
		||||
      incidental, or consequential damages of any character arising as a
 | 
			
		||||
      result of this License or out of the use or inability to use the
 | 
			
		||||
      Work (including but not limited to damages for loss of goodwill,
 | 
			
		||||
      work stoppage, computer failure or malfunction, or any and all
 | 
			
		||||
      other commercial damages or losses), even if such Contributor
 | 
			
		||||
      has been advised of the possibility of such damages.
 | 
			
		||||
 | 
			
		||||
   9. Accepting Warranty or Additional Liability. While redistributing
 | 
			
		||||
      the Work or Derivative Works thereof, You may choose to offer,
 | 
			
		||||
      and charge a fee for, acceptance of support, warranty, indemnity,
 | 
			
		||||
      or other liability obligations and/or rights consistent with this
 | 
			
		||||
      License. However, in accepting such obligations, You may act only
 | 
			
		||||
      on Your own behalf and on Your sole responsibility, not on behalf
 | 
			
		||||
      of any other Contributor, and only if You agree to indemnify,
 | 
			
		||||
      defend, and hold each Contributor harmless for any liability
 | 
			
		||||
      incurred by, or claims asserted against, such Contributor by reason
 | 
			
		||||
      of your accepting any such warranty or additional liability.
 | 
			
		||||
 | 
			
		||||
   END OF TERMS AND CONDITIONS
 | 
			
		||||
 | 
			
		||||
   APPENDIX: How to apply the Apache License to your work.
 | 
			
		||||
 | 
			
		||||
      To apply the Apache License to your work, attach the following
 | 
			
		||||
      boilerplate notice, with the fields enclosed by brackets "{}"
 | 
			
		||||
      replaced with your own identifying information. (Don't include
 | 
			
		||||
      the brackets!)  The text should be enclosed in the appropriate
 | 
			
		||||
      comment syntax for the file format. We also recommend that a
 | 
			
		||||
      file or class name and description of purpose be included on the
 | 
			
		||||
      same "printed page" as the copyright notice for easier
 | 
			
		||||
      identification within third-party archives.
 | 
			
		||||
 | 
			
		||||
   Copyright {yyyy} {name of copyright owner}
 | 
			
		||||
 | 
			
		||||
   Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
   you may not use this file except in compliance with the License.
 | 
			
		||||
   You may obtain a copy of the License at
 | 
			
		||||
 | 
			
		||||
       http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 | 
			
		||||
   Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
   distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
   See the License for the specific language governing permissions and
 | 
			
		||||
   limitations under the License.
 | 
			
		||||
= vendor/github.com/heketi/heketi/LICENSE 6c4db32a2fa8717faffa1d4f10136f47  -
 | 
			
		||||
================================================================================
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
================================================================================
 | 
			
		||||
= vendor/github.com/imdario/mergo licensed under: =
 | 
			
		||||
 | 
			
		||||
@@ -47429,6 +48053,214 @@ SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 | 
			
		||||
================================================================================
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
================================================================================
 | 
			
		||||
= vendor/github.com/lpabon/godbc licensed under: =
 | 
			
		||||
 | 
			
		||||
Apache License
 | 
			
		||||
                           Version 2.0, January 2004
 | 
			
		||||
                        http://www.apache.org/licenses/
 | 
			
		||||
 | 
			
		||||
   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
 | 
			
		||||
 | 
			
		||||
   1. Definitions.
 | 
			
		||||
 | 
			
		||||
      "License" shall mean the terms and conditions for use, reproduction,
 | 
			
		||||
      and distribution as defined by Sections 1 through 9 of this document.
 | 
			
		||||
 | 
			
		||||
      "Licensor" shall mean the copyright owner or entity authorized by
 | 
			
		||||
      the copyright owner that is granting the License.
 | 
			
		||||
 | 
			
		||||
      "Legal Entity" shall mean the union of the acting entity and all
 | 
			
		||||
      other entities that control, are controlled by, or are under common
 | 
			
		||||
      control with that entity. For the purposes of this definition,
 | 
			
		||||
      "control" means (i) the power, direct or indirect, to cause the
 | 
			
		||||
      direction or management of such entity, whether by contract or
 | 
			
		||||
      otherwise, or (ii) ownership of fifty percent (50%) or more of the
 | 
			
		||||
      outstanding shares, or (iii) beneficial ownership of such entity.
 | 
			
		||||
 | 
			
		||||
      "You" (or "Your") shall mean an individual or Legal Entity
 | 
			
		||||
      exercising permissions granted by this License.
 | 
			
		||||
 | 
			
		||||
      "Source" form shall mean the preferred form for making modifications,
 | 
			
		||||
      including but not limited to software source code, documentation
 | 
			
		||||
      source, and configuration files.
 | 
			
		||||
 | 
			
		||||
      "Object" form shall mean any form resulting from mechanical
 | 
			
		||||
      transformation or translation of a Source form, including but
 | 
			
		||||
      not limited to compiled object code, generated documentation,
 | 
			
		||||
      and conversions to other media types.
 | 
			
		||||
 | 
			
		||||
      "Work" shall mean the work of authorship, whether in Source or
 | 
			
		||||
      Object form, made available under the License, as indicated by a
 | 
			
		||||
      copyright notice that is included in or attached to the work
 | 
			
		||||
      (an example is provided in the Appendix below).
 | 
			
		||||
 | 
			
		||||
      "Derivative Works" shall mean any work, whether in Source or Object
 | 
			
		||||
      form, that is based on (or derived from) the Work and for which the
 | 
			
		||||
      editorial revisions, annotations, elaborations, or other modifications
 | 
			
		||||
      represent, as a whole, an original work of authorship. For the purposes
 | 
			
		||||
      of this License, Derivative Works shall not include works that remain
 | 
			
		||||
      separable from, or merely link (or bind by name) to the interfaces of,
 | 
			
		||||
      the Work and Derivative Works thereof.
 | 
			
		||||
 | 
			
		||||
      "Contribution" shall mean any work of authorship, including
 | 
			
		||||
      the original version of the Work and any modifications or additions
 | 
			
		||||
      to that Work or Derivative Works thereof, that is intentionally
 | 
			
		||||
      submitted to Licensor for inclusion in the Work by the copyright owner
 | 
			
		||||
      or by an individual or Legal Entity authorized to submit on behalf of
 | 
			
		||||
      the copyright owner. For the purposes of this definition, "submitted"
 | 
			
		||||
      means any form of electronic, verbal, or written communication sent
 | 
			
		||||
      to the Licensor or its representatives, including but not limited to
 | 
			
		||||
      communication on electronic mailing lists, source code control systems,
 | 
			
		||||
      and issue tracking systems that are managed by, or on behalf of, the
 | 
			
		||||
      Licensor for the purpose of discussing and improving the Work, but
 | 
			
		||||
      excluding communication that is conspicuously marked or otherwise
 | 
			
		||||
      designated in writing by the copyright owner as "Not a Contribution."
 | 
			
		||||
 | 
			
		||||
      "Contributor" shall mean Licensor and any individual or Legal Entity
 | 
			
		||||
      on behalf of whom a Contribution has been received by Licensor and
 | 
			
		||||
      subsequently incorporated within the Work.
 | 
			
		||||
 | 
			
		||||
   2. Grant of Copyright License. Subject to the terms and conditions of
 | 
			
		||||
      this License, each Contributor hereby grants to You a perpetual,
 | 
			
		||||
      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
 | 
			
		||||
      copyright license to reproduce, prepare Derivative Works of,
 | 
			
		||||
      publicly display, publicly perform, sublicense, and distribute the
 | 
			
		||||
      Work and such Derivative Works in Source or Object form.
 | 
			
		||||
 | 
			
		||||
   3. Grant of Patent License. Subject to the terms and conditions of
 | 
			
		||||
      this License, each Contributor hereby grants to You a perpetual,
 | 
			
		||||
      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
 | 
			
		||||
      (except as stated in this section) patent license to make, have made,
 | 
			
		||||
      use, offer to sell, sell, import, and otherwise transfer the Work,
 | 
			
		||||
      where such license applies only to those patent claims licensable
 | 
			
		||||
      by such Contributor that are necessarily infringed by their
 | 
			
		||||
      Contribution(s) alone or by combination of their Contribution(s)
 | 
			
		||||
      with the Work to which such Contribution(s) was submitted. If You
 | 
			
		||||
      institute patent litigation against any entity (including a
 | 
			
		||||
      cross-claim or counterclaim in a lawsuit) alleging that the Work
 | 
			
		||||
      or a Contribution incorporated within the Work constitutes direct
 | 
			
		||||
      or contributory patent infringement, then any patent licenses
 | 
			
		||||
      granted to You under this License for that Work shall terminate
 | 
			
		||||
      as of the date such litigation is filed.
 | 
			
		||||
 | 
			
		||||
   4. Redistribution. You may reproduce and distribute copies of the
 | 
			
		||||
      Work or Derivative Works thereof in any medium, with or without
 | 
			
		||||
      modifications, and in Source or Object form, provided that You
 | 
			
		||||
      meet the following conditions:
 | 
			
		||||
 | 
			
		||||
      (a) You must give any other recipients of the Work or
 | 
			
		||||
          Derivative Works a copy of this License; and
 | 
			
		||||
 | 
			
		||||
      (b) You must cause any modified files to carry prominent notices
 | 
			
		||||
          stating that You changed the files; and
 | 
			
		||||
 | 
			
		||||
      (c) You must retain, in the Source form of any Derivative Works
 | 
			
		||||
          that You distribute, all copyright, patent, trademark, and
 | 
			
		||||
          attribution notices from the Source form of the Work,
 | 
			
		||||
          excluding those notices that do not pertain to any part of
 | 
			
		||||
          the Derivative Works; and
 | 
			
		||||
 | 
			
		||||
      (d) If the Work includes a "NOTICE" text file as part of its
 | 
			
		||||
          distribution, then any Derivative Works that You distribute must
 | 
			
		||||
          include a readable copy of the attribution notices contained
 | 
			
		||||
          within such NOTICE file, excluding those notices that do not
 | 
			
		||||
          pertain to any part of the Derivative Works, in at least one
 | 
			
		||||
          of the following places: within a NOTICE text file distributed
 | 
			
		||||
          as part of the Derivative Works; within the Source form or
 | 
			
		||||
          documentation, if provided along with the Derivative Works; or,
 | 
			
		||||
          within a display generated by the Derivative Works, if and
 | 
			
		||||
          wherever such third-party notices normally appear. The contents
 | 
			
		||||
          of the NOTICE file are for informational purposes only and
 | 
			
		||||
          do not modify the License. You may add Your own attribution
 | 
			
		||||
          notices within Derivative Works that You distribute, alongside
 | 
			
		||||
          or as an addendum to the NOTICE text from the Work, provided
 | 
			
		||||
          that such additional attribution notices cannot be construed
 | 
			
		||||
          as modifying the License.
 | 
			
		||||
 | 
			
		||||
      You may add Your own copyright statement to Your modifications and
 | 
			
		||||
      may provide additional or different license terms and conditions
 | 
			
		||||
      for use, reproduction, or distribution of Your modifications, or
 | 
			
		||||
      for any such Derivative Works as a whole, provided Your use,
 | 
			
		||||
      reproduction, and distribution of the Work otherwise complies with
 | 
			
		||||
      the conditions stated in this License.
 | 
			
		||||
 | 
			
		||||
   5. Submission of Contributions. Unless You explicitly state otherwise,
 | 
			
		||||
      any Contribution intentionally submitted for inclusion in the Work
 | 
			
		||||
      by You to the Licensor shall be under the terms and conditions of
 | 
			
		||||
      this License, without any additional terms or conditions.
 | 
			
		||||
      Notwithstanding the above, nothing herein shall supersede or modify
 | 
			
		||||
      the terms of any separate license agreement you may have executed
 | 
			
		||||
      with Licensor regarding such Contributions.
 | 
			
		||||
 | 
			
		||||
   6. Trademarks. This License does not grant permission to use the trade
 | 
			
		||||
      names, trademarks, service marks, or product names of the Licensor,
 | 
			
		||||
      except as required for reasonable and customary use in describing the
 | 
			
		||||
      origin of the Work and reproducing the content of the NOTICE file.
 | 
			
		||||
 | 
			
		||||
   7. Disclaimer of Warranty. Unless required by applicable law or
 | 
			
		||||
      agreed to in writing, Licensor provides the Work (and each
 | 
			
		||||
      Contributor provides its Contributions) on an "AS IS" BASIS,
 | 
			
		||||
      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
 | 
			
		||||
      implied, including, without limitation, any warranties or conditions
 | 
			
		||||
      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
 | 
			
		||||
      PARTICULAR PURPOSE. You are solely responsible for determining the
 | 
			
		||||
      appropriateness of using or redistributing the Work and assume any
 | 
			
		||||
      risks associated with Your exercise of permissions under this License.
 | 
			
		||||
 | 
			
		||||
   8. Limitation of Liability. In no event and under no legal theory,
 | 
			
		||||
      whether in tort (including negligence), contract, or otherwise,
 | 
			
		||||
      unless required by applicable law (such as deliberate and grossly
 | 
			
		||||
      negligent acts) or agreed to in writing, shall any Contributor be
 | 
			
		||||
      liable to You for damages, including any direct, indirect, special,
 | 
			
		||||
      incidental, or consequential damages of any character arising as a
 | 
			
		||||
      result of this License or out of the use or inability to use the
 | 
			
		||||
      Work (including but not limited to damages for loss of goodwill,
 | 
			
		||||
      work stoppage, computer failure or malfunction, or any and all
 | 
			
		||||
      other commercial damages or losses), even if such Contributor
 | 
			
		||||
      has been advised of the possibility of such damages.
 | 
			
		||||
 | 
			
		||||
   9. Accepting Warranty or Additional Liability. While redistributing
 | 
			
		||||
      the Work or Derivative Works thereof, You may choose to offer,
 | 
			
		||||
      and charge a fee for, acceptance of support, warranty, indemnity,
 | 
			
		||||
      or other liability obligations and/or rights consistent with this
 | 
			
		||||
      License. However, in accepting such obligations, You may act only
 | 
			
		||||
      on Your own behalf and on Your sole responsibility, not on behalf
 | 
			
		||||
      of any other Contributor, and only if You agree to indemnify,
 | 
			
		||||
      defend, and hold each Contributor harmless for any liability
 | 
			
		||||
      incurred by, or claims asserted against, such Contributor by reason
 | 
			
		||||
      of your accepting any such warranty or additional liability.
 | 
			
		||||
 | 
			
		||||
   END OF TERMS AND CONDITIONS
 | 
			
		||||
 | 
			
		||||
   APPENDIX: How to apply the Apache License to your work.
 | 
			
		||||
 | 
			
		||||
      To apply the Apache License to your work, attach the following
 | 
			
		||||
      boilerplate notice, with the fields enclosed by brackets "{}"
 | 
			
		||||
      replaced with your own identifying information. (Don't include
 | 
			
		||||
      the brackets!)  The text should be enclosed in the appropriate
 | 
			
		||||
      comment syntax for the file format. We also recommend that a
 | 
			
		||||
      file or class name and description of purpose be included on the
 | 
			
		||||
      same "printed page" as the copyright notice for easier
 | 
			
		||||
      identification within third-party archives.
 | 
			
		||||
 | 
			
		||||
   Copyright {yyyy} {name of copyright owner}
 | 
			
		||||
 | 
			
		||||
   Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
   you may not use this file except in compliance with the License.
 | 
			
		||||
   You may obtain a copy of the License at
 | 
			
		||||
 | 
			
		||||
       http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 | 
			
		||||
   Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
   distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
   See the License for the specific language governing permissions and
 | 
			
		||||
   limitations under the License.
 | 
			
		||||
= vendor/github.com/lpabon/godbc/LICENSE 6c4db32a2fa8717faffa1d4f10136f47  -
 | 
			
		||||
================================================================================
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
================================================================================
 | 
			
		||||
= vendor/github.com/mailru/easyjson/buffer licensed under: =
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -28,6 +28,7 @@ import (
 | 
			
		||||
	_ "k8s.io/kubernetes/pkg/cloudprovider/providers"
 | 
			
		||||
 | 
			
		||||
	// Volume plugins
 | 
			
		||||
	"github.com/golang/glog"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/cloudprovider"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/cloudprovider/providers/aws"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/cloudprovider/providers/gce"
 | 
			
		||||
@@ -39,11 +40,10 @@ import (
 | 
			
		||||
	"k8s.io/kubernetes/pkg/volume/cinder"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/volume/flexvolume"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/volume/gce_pd"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/volume/glusterfs"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/volume/host_path"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/volume/nfs"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/volume/vsphere_volume"
 | 
			
		||||
 | 
			
		||||
	"github.com/golang/glog"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// ProbeAttachableVolumePlugins collects all volume plugins for the attach/
 | 
			
		||||
@@ -97,6 +97,7 @@ func ProbeControllerVolumePlugins(cloud cloudprovider.Interface, config componen
 | 
			
		||||
		glog.Fatalf("Could not create NFS recycler pod from file %s: %+v", config.PersistentVolumeRecyclerConfiguration.PodTemplateFilePathNFS, err)
 | 
			
		||||
	}
 | 
			
		||||
	allPlugins = append(allPlugins, nfs.ProbeVolumePlugins(nfsConfig)...)
 | 
			
		||||
	allPlugins = append(allPlugins, glusterfs.ProbeVolumePlugins()...)
 | 
			
		||||
 | 
			
		||||
	if cloud != nil {
 | 
			
		||||
		switch {
 | 
			
		||||
 
 | 
			
		||||
@@ -81,6 +81,28 @@ parameters:
 | 
			
		||||
* `type`: `pd-standard` or `pd-ssd`. Default: `pd-ssd`
 | 
			
		||||
* `zone`: GCE zone. If not specified, a random zone in the same region as controller-manager will be chosen.
 | 
			
		||||
 | 
			
		||||
#### GLUSTERFS
 | 
			
		||||
 | 
			
		||||
```yaml
 | 
			
		||||
apiVersion: extensions/v1beta1
 | 
			
		||||
kind: StorageClass
 | 
			
		||||
metadata:
 | 
			
		||||
  name: slow
 | 
			
		||||
provisioner: kubernetes.io/glusterfs
 | 
			
		||||
parameters:
 | 
			
		||||
  endpoint: "glusterfs-cluster"
 | 
			
		||||
  resturl: "http://127.0.0.1:8081"
 | 
			
		||||
  restauthenabled: "true"
 | 
			
		||||
  restuser: "admin"
 | 
			
		||||
  restuserkey: "password"
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
* `endpoint`: `glusterfs-cluster` is the endpoint/service name which includes GlusterFS trusted pool IP addresses and this parameter is mandatory.
 | 
			
		||||
* `resturl` : Gluster REST service url which provision gluster volumes on demand. The format should be `IPaddress:Port` and this is a mandatory parameter for GlusterFS dynamic provisioner.
 | 
			
		||||
* `restauthenabled` : Gluster REST service authentication boolean is required if the authentication is enabled on the REST server. If this value is 'true', 'restuser' and 'restuserkey' have to be filled.
 | 
			
		||||
* `restuser` : Gluster REST service user who has access to create volumes in the Gluster Trusted Pool.
 | 
			
		||||
* `restuserkey` : Gluster REST service user's password which will be used for authentication to the REST server.
 | 
			
		||||
 | 
			
		||||
### User provisioning requests
 | 
			
		||||
 | 
			
		||||
Users request dynamically provisioned storage by including a storage class in their `PersistentVolumeClaim`.
 | 
			
		||||
 
 | 
			
		||||
@@ -0,0 +1,11 @@
 | 
			
		||||
apiVersion: extensions/v1beta1
 | 
			
		||||
kind: StorageClass
 | 
			
		||||
metadata:
 | 
			
		||||
  name: slow
 | 
			
		||||
provisioner: kubernetes.io/glusterfs
 | 
			
		||||
parameters:
 | 
			
		||||
  endpoint: "glusterfs-cluster"
 | 
			
		||||
  resturl: "http://127.0.0.1:8081"
 | 
			
		||||
  restauthenabled: "true"
 | 
			
		||||
  restuser: "admin"
 | 
			
		||||
  restuserkey: "password"
 | 
			
		||||
@@ -18,33 +18,43 @@ package glusterfs
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"fmt"
 | 
			
		||||
	"os"
 | 
			
		||||
	"path"
 | 
			
		||||
 | 
			
		||||
	"github.com/golang/glog"
 | 
			
		||||
	gcli "github.com/heketi/heketi/client/api/go-client"
 | 
			
		||||
	gapi "github.com/heketi/heketi/pkg/glusterfs/api"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/api"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/api/resource"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/types"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/util/exec"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/util/mount"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/util/strings"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/volume"
 | 
			
		||||
	"os"
 | 
			
		||||
	"path"
 | 
			
		||||
	"strconv"
 | 
			
		||||
	dstrings "strings"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// This is the primary entrypoint for volume plugins.
 | 
			
		||||
func ProbeVolumePlugins() []volume.VolumePlugin {
 | 
			
		||||
	return []volume.VolumePlugin{&glusterfsPlugin{nil, exec.New()}}
 | 
			
		||||
	return []volume.VolumePlugin{&glusterfsPlugin{nil, exec.New(), new(glusterfsClusterConf)}}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type glusterfsPlugin struct {
 | 
			
		||||
	host        volume.VolumeHost
 | 
			
		||||
	exe         exec.Interface
 | 
			
		||||
	clusterconf *glusterfsClusterConf
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var _ volume.VolumePlugin = &glusterfsPlugin{}
 | 
			
		||||
var _ volume.PersistentVolumePlugin = &glusterfsPlugin{}
 | 
			
		||||
var _ volume.DeletableVolumePlugin = &glusterfsPlugin{}
 | 
			
		||||
var _ volume.ProvisionableVolumePlugin = &glusterfsPlugin{}
 | 
			
		||||
var _ volume.Provisioner = &glusterfsVolumeProvisioner{}
 | 
			
		||||
var _ volume.Deleter = &glusterfsVolumeDeleter{}
 | 
			
		||||
 | 
			
		||||
const (
 | 
			
		||||
	glusterfsPluginName = "kubernetes.io/glusterfs"
 | 
			
		||||
	volprefix           = "vol_"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func (plugin *glusterfsPlugin) Init(host volume.VolumeHost) error {
 | 
			
		||||
@@ -315,3 +325,158 @@ func getVolumeSource(
 | 
			
		||||
 | 
			
		||||
	return nil, false, fmt.Errorf("Spec does not reference a Gluster volume type")
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (plugin *glusterfsPlugin) NewProvisioner(options volume.VolumeOptions) (volume.Provisioner, error) {
 | 
			
		||||
	if len(options.AccessModes) == 0 {
 | 
			
		||||
		options.AccessModes = plugin.GetAccessModes()
 | 
			
		||||
	}
 | 
			
		||||
	return plugin.newProvisionerInternal(options)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (plugin *glusterfsPlugin) newProvisionerInternal(options volume.VolumeOptions) (volume.Provisioner, error) {
 | 
			
		||||
	return &glusterfsVolumeProvisioner{
 | 
			
		||||
		glusterfsMounter: &glusterfsMounter{
 | 
			
		||||
			glusterfs: &glusterfs{
 | 
			
		||||
				plugin: plugin,
 | 
			
		||||
			},
 | 
			
		||||
		},
 | 
			
		||||
		options: options,
 | 
			
		||||
	}, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type glusterfsClusterConf struct {
 | 
			
		||||
	glusterep          string
 | 
			
		||||
	glusterRestvolpath string
 | 
			
		||||
	glusterRestUrl     string
 | 
			
		||||
	glusterRestAuth    bool
 | 
			
		||||
	glusterRestUser    string
 | 
			
		||||
	glusterRestUserKey string
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type glusterfsVolumeProvisioner struct {
 | 
			
		||||
	*glusterfsMounter
 | 
			
		||||
	*glusterfsClusterConf
 | 
			
		||||
	options volume.VolumeOptions
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (plugin *glusterfsPlugin) NewDeleter(spec *volume.Spec) (volume.Deleter, error) {
 | 
			
		||||
	return plugin.newDeleterInternal(spec)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (plugin *glusterfsPlugin) newDeleterInternal(spec *volume.Spec) (volume.Deleter, error) {
 | 
			
		||||
	if spec.PersistentVolume != nil && spec.PersistentVolume.Spec.Glusterfs == nil {
 | 
			
		||||
		return nil, fmt.Errorf("spec.PersistentVolumeSource.Spec.Glusterfs is nil")
 | 
			
		||||
	}
 | 
			
		||||
	return &glusterfsVolumeDeleter{
 | 
			
		||||
		glusterfsMounter: &glusterfsMounter{
 | 
			
		||||
			glusterfs: &glusterfs{
 | 
			
		||||
				volName: spec.Name(),
 | 
			
		||||
				plugin:  plugin,
 | 
			
		||||
			},
 | 
			
		||||
			path: spec.PersistentVolume.Spec.Glusterfs.Path,
 | 
			
		||||
		}}, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type glusterfsVolumeDeleter struct {
 | 
			
		||||
	*glusterfsMounter
 | 
			
		||||
	*glusterfsClusterConf
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (d *glusterfsVolumeDeleter) GetPath() string {
 | 
			
		||||
	name := glusterfsPluginName
 | 
			
		||||
	return d.plugin.host.GetPodVolumeDir(d.glusterfsMounter.glusterfs.pod.UID, strings.EscapeQualifiedNameForDisk(name), d.glusterfsMounter.glusterfs.volName)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (d *glusterfsVolumeDeleter) Delete() error {
 | 
			
		||||
	var err error
 | 
			
		||||
	glog.V(2).Infof("glusterfs: delete volume :%s ", d.glusterfsMounter.path)
 | 
			
		||||
	volumetodel := d.glusterfsMounter.path
 | 
			
		||||
	d.glusterfsClusterConf = d.plugin.clusterconf
 | 
			
		||||
	newvolumetodel := dstrings.TrimPrefix(volumetodel, volprefix)
 | 
			
		||||
	cli := gcli.NewClient(d.glusterRestUrl, d.glusterRestUser, d.glusterRestUserKey)
 | 
			
		||||
	if cli == nil {
 | 
			
		||||
		glog.Errorf("glusterfs: failed to create gluster rest client")
 | 
			
		||||
		return fmt.Errorf("glusterfs: failed to create gluster rest client, REST server authentication failed")
 | 
			
		||||
	}
 | 
			
		||||
	err = cli.VolumeDelete(newvolumetodel)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		glog.V(4).Infof("glusterfs: error when deleting the volume :%s", err)
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	glog.V(2).Infof("glusterfs: volume %s deleted successfully", volumetodel)
 | 
			
		||||
	return nil
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (r *glusterfsVolumeProvisioner) Provision() (*api.PersistentVolume, error) {
 | 
			
		||||
	var err error
 | 
			
		||||
	if r.options.Selector != nil {
 | 
			
		||||
		glog.V(4).Infof("glusterfs: not able to parse your claim Selector")
 | 
			
		||||
		return nil, fmt.Errorf("glusterfs: not able to parse your claim Selector")
 | 
			
		||||
	}
 | 
			
		||||
	glog.V(4).Infof("glusterfs: Provison VolumeOptions %v", r.options)
 | 
			
		||||
	for k, v := range r.options.Parameters {
 | 
			
		||||
		switch dstrings.ToLower(k) {
 | 
			
		||||
		case "endpoint":
 | 
			
		||||
			r.plugin.clusterconf.glusterep = v
 | 
			
		||||
		case "path":
 | 
			
		||||
			r.plugin.clusterconf.glusterRestvolpath = v
 | 
			
		||||
		case "resturl":
 | 
			
		||||
			r.plugin.clusterconf.glusterRestUrl = v
 | 
			
		||||
		case "restauthenabled":
 | 
			
		||||
			r.plugin.clusterconf.glusterRestAuth, err = strconv.ParseBool(v)
 | 
			
		||||
		case "restuser":
 | 
			
		||||
			r.plugin.clusterconf.glusterRestUser = v
 | 
			
		||||
		case "restuserkey":
 | 
			
		||||
			r.plugin.clusterconf.glusterRestUserKey = v
 | 
			
		||||
		default:
 | 
			
		||||
			return nil, fmt.Errorf("glusterfs: invalid option %q for volume plugin %s", k, r.plugin.GetPluginName())
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
	glog.V(4).Infof("glusterfs: storage class parameters in plugin clusterconf %v", r.plugin.clusterconf)
 | 
			
		||||
	if !r.plugin.clusterconf.glusterRestAuth {
 | 
			
		||||
		r.plugin.clusterconf.glusterRestUser = ""
 | 
			
		||||
		r.plugin.clusterconf.glusterRestUserKey = ""
 | 
			
		||||
	}
 | 
			
		||||
	r.glusterfsClusterConf = r.plugin.clusterconf
 | 
			
		||||
	glusterfs, sizeGB, err := r.CreateVolume()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		glog.Errorf("glusterfs: create volume err: %s.", err)
 | 
			
		||||
		return nil, fmt.Errorf("glusterfs: create volume err: %s.", err)
 | 
			
		||||
	}
 | 
			
		||||
	pv := new(api.PersistentVolume)
 | 
			
		||||
	pv.Spec.PersistentVolumeSource.Glusterfs = glusterfs
 | 
			
		||||
	pv.Spec.PersistentVolumeReclaimPolicy = r.options.PersistentVolumeReclaimPolicy
 | 
			
		||||
	pv.Spec.AccessModes = r.options.AccessModes
 | 
			
		||||
	pv.Spec.Capacity = api.ResourceList{
 | 
			
		||||
		api.ResourceName(api.ResourceStorage): resource.MustParse(fmt.Sprintf("%dGi", sizeGB)),
 | 
			
		||||
	}
 | 
			
		||||
	return pv, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (p *glusterfsVolumeProvisioner) CreateVolume() (r *api.GlusterfsVolumeSource, size int, err error) {
 | 
			
		||||
	volSizeBytes := p.options.Capacity.Value()
 | 
			
		||||
	sz := int(volume.RoundUpSize(volSizeBytes, 1024*1024*1024))
 | 
			
		||||
	glog.V(2).Infof("glusterfs: create volume of size:%d bytes", volSizeBytes)
 | 
			
		||||
	if p.glusterfsClusterConf.glusterRestUrl == "" {
 | 
			
		||||
		glog.Errorf("glusterfs : rest server endpoint is empty")
 | 
			
		||||
		return nil, 0, fmt.Errorf("failed to create gluster REST client, REST URL is empty")
 | 
			
		||||
	}
 | 
			
		||||
	cli := gcli.NewClient(p.glusterRestUrl, p.glusterRestUser, p.glusterRestUserKey)
 | 
			
		||||
	if cli == nil {
 | 
			
		||||
		glog.Errorf("glusterfs: failed to create gluster rest client")
 | 
			
		||||
		return nil, 0, fmt.Errorf("failed to create gluster REST client, REST server authentication failed")
 | 
			
		||||
	}
 | 
			
		||||
	volumeReq := &gapi.VolumeCreateRequest{Size: sz}
 | 
			
		||||
	volume, err := cli.VolumeCreate(volumeReq)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		glog.Errorf("glusterfs: error creating volume %s ", err)
 | 
			
		||||
		return nil, 0, fmt.Errorf("error creating volume %v", err)
 | 
			
		||||
	}
 | 
			
		||||
	glog.V(1).Infof("glusterfs: volume with size :%d and name:%s created", volume.Size, volume.Name)
 | 
			
		||||
	return &api.GlusterfsVolumeSource{
 | 
			
		||||
		EndpointsName: p.glusterfsClusterConf.glusterep,
 | 
			
		||||
		Path:          volume.Name,
 | 
			
		||||
		ReadOnly:      false,
 | 
			
		||||
	}, sz, nil
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										201
									
								
								vendor/github.com/heketi/heketi/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										201
									
								
								vendor/github.com/heketi/heketi/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,201 @@
 | 
			
		||||
Apache License
 | 
			
		||||
                           Version 2.0, January 2004
 | 
			
		||||
                        http://www.apache.org/licenses/
 | 
			
		||||
 | 
			
		||||
   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
 | 
			
		||||
 | 
			
		||||
   1. Definitions.
 | 
			
		||||
 | 
			
		||||
      "License" shall mean the terms and conditions for use, reproduction,
 | 
			
		||||
      and distribution as defined by Sections 1 through 9 of this document.
 | 
			
		||||
 | 
			
		||||
      "Licensor" shall mean the copyright owner or entity authorized by
 | 
			
		||||
      the copyright owner that is granting the License.
 | 
			
		||||
 | 
			
		||||
      "Legal Entity" shall mean the union of the acting entity and all
 | 
			
		||||
      other entities that control, are controlled by, or are under common
 | 
			
		||||
      control with that entity. For the purposes of this definition,
 | 
			
		||||
      "control" means (i) the power, direct or indirect, to cause the
 | 
			
		||||
      direction or management of such entity, whether by contract or
 | 
			
		||||
      otherwise, or (ii) ownership of fifty percent (50%) or more of the
 | 
			
		||||
      outstanding shares, or (iii) beneficial ownership of such entity.
 | 
			
		||||
 | 
			
		||||
      "You" (or "Your") shall mean an individual or Legal Entity
 | 
			
		||||
      exercising permissions granted by this License.
 | 
			
		||||
 | 
			
		||||
      "Source" form shall mean the preferred form for making modifications,
 | 
			
		||||
      including but not limited to software source code, documentation
 | 
			
		||||
      source, and configuration files.
 | 
			
		||||
 | 
			
		||||
      "Object" form shall mean any form resulting from mechanical
 | 
			
		||||
      transformation or translation of a Source form, including but
 | 
			
		||||
      not limited to compiled object code, generated documentation,
 | 
			
		||||
      and conversions to other media types.
 | 
			
		||||
 | 
			
		||||
      "Work" shall mean the work of authorship, whether in Source or
 | 
			
		||||
      Object form, made available under the License, as indicated by a
 | 
			
		||||
      copyright notice that is included in or attached to the work
 | 
			
		||||
      (an example is provided in the Appendix below).
 | 
			
		||||
 | 
			
		||||
      "Derivative Works" shall mean any work, whether in Source or Object
 | 
			
		||||
      form, that is based on (or derived from) the Work and for which the
 | 
			
		||||
      editorial revisions, annotations, elaborations, or other modifications
 | 
			
		||||
      represent, as a whole, an original work of authorship. For the purposes
 | 
			
		||||
      of this License, Derivative Works shall not include works that remain
 | 
			
		||||
      separable from, or merely link (or bind by name) to the interfaces of,
 | 
			
		||||
      the Work and Derivative Works thereof.
 | 
			
		||||
 | 
			
		||||
      "Contribution" shall mean any work of authorship, including
 | 
			
		||||
      the original version of the Work and any modifications or additions
 | 
			
		||||
      to that Work or Derivative Works thereof, that is intentionally
 | 
			
		||||
      submitted to Licensor for inclusion in the Work by the copyright owner
 | 
			
		||||
      or by an individual or Legal Entity authorized to submit on behalf of
 | 
			
		||||
      the copyright owner. For the purposes of this definition, "submitted"
 | 
			
		||||
      means any form of electronic, verbal, or written communication sent
 | 
			
		||||
      to the Licensor or its representatives, including but not limited to
 | 
			
		||||
      communication on electronic mailing lists, source code control systems,
 | 
			
		||||
      and issue tracking systems that are managed by, or on behalf of, the
 | 
			
		||||
      Licensor for the purpose of discussing and improving the Work, but
 | 
			
		||||
      excluding communication that is conspicuously marked or otherwise
 | 
			
		||||
      designated in writing by the copyright owner as "Not a Contribution."
 | 
			
		||||
 | 
			
		||||
      "Contributor" shall mean Licensor and any individual or Legal Entity
 | 
			
		||||
      on behalf of whom a Contribution has been received by Licensor and
 | 
			
		||||
      subsequently incorporated within the Work.
 | 
			
		||||
 | 
			
		||||
   2. Grant of Copyright License. Subject to the terms and conditions of
 | 
			
		||||
      this License, each Contributor hereby grants to You a perpetual,
 | 
			
		||||
      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
 | 
			
		||||
      copyright license to reproduce, prepare Derivative Works of,
 | 
			
		||||
      publicly display, publicly perform, sublicense, and distribute the
 | 
			
		||||
      Work and such Derivative Works in Source or Object form.
 | 
			
		||||
 | 
			
		||||
   3. Grant of Patent License. Subject to the terms and conditions of
 | 
			
		||||
      this License, each Contributor hereby grants to You a perpetual,
 | 
			
		||||
      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
 | 
			
		||||
      (except as stated in this section) patent license to make, have made,
 | 
			
		||||
      use, offer to sell, sell, import, and otherwise transfer the Work,
 | 
			
		||||
      where such license applies only to those patent claims licensable
 | 
			
		||||
      by such Contributor that are necessarily infringed by their
 | 
			
		||||
      Contribution(s) alone or by combination of their Contribution(s)
 | 
			
		||||
      with the Work to which such Contribution(s) was submitted. If You
 | 
			
		||||
      institute patent litigation against any entity (including a
 | 
			
		||||
      cross-claim or counterclaim in a lawsuit) alleging that the Work
 | 
			
		||||
      or a Contribution incorporated within the Work constitutes direct
 | 
			
		||||
      or contributory patent infringement, then any patent licenses
 | 
			
		||||
      granted to You under this License for that Work shall terminate
 | 
			
		||||
      as of the date such litigation is filed.
 | 
			
		||||
 | 
			
		||||
   4. Redistribution. You may reproduce and distribute copies of the
 | 
			
		||||
      Work or Derivative Works thereof in any medium, with or without
 | 
			
		||||
      modifications, and in Source or Object form, provided that You
 | 
			
		||||
      meet the following conditions:
 | 
			
		||||
 | 
			
		||||
      (a) You must give any other recipients of the Work or
 | 
			
		||||
          Derivative Works a copy of this License; and
 | 
			
		||||
 | 
			
		||||
      (b) You must cause any modified files to carry prominent notices
 | 
			
		||||
          stating that You changed the files; and
 | 
			
		||||
 | 
			
		||||
      (c) You must retain, in the Source form of any Derivative Works
 | 
			
		||||
          that You distribute, all copyright, patent, trademark, and
 | 
			
		||||
          attribution notices from the Source form of the Work,
 | 
			
		||||
          excluding those notices that do not pertain to any part of
 | 
			
		||||
          the Derivative Works; and
 | 
			
		||||
 | 
			
		||||
      (d) If the Work includes a "NOTICE" text file as part of its
 | 
			
		||||
          distribution, then any Derivative Works that You distribute must
 | 
			
		||||
          include a readable copy of the attribution notices contained
 | 
			
		||||
          within such NOTICE file, excluding those notices that do not
 | 
			
		||||
          pertain to any part of the Derivative Works, in at least one
 | 
			
		||||
          of the following places: within a NOTICE text file distributed
 | 
			
		||||
          as part of the Derivative Works; within the Source form or
 | 
			
		||||
          documentation, if provided along with the Derivative Works; or,
 | 
			
		||||
          within a display generated by the Derivative Works, if and
 | 
			
		||||
          wherever such third-party notices normally appear. The contents
 | 
			
		||||
          of the NOTICE file are for informational purposes only and
 | 
			
		||||
          do not modify the License. You may add Your own attribution
 | 
			
		||||
          notices within Derivative Works that You distribute, alongside
 | 
			
		||||
          or as an addendum to the NOTICE text from the Work, provided
 | 
			
		||||
          that such additional attribution notices cannot be construed
 | 
			
		||||
          as modifying the License.
 | 
			
		||||
 | 
			
		||||
      You may add Your own copyright statement to Your modifications and
 | 
			
		||||
      may provide additional or different license terms and conditions
 | 
			
		||||
      for use, reproduction, or distribution of Your modifications, or
 | 
			
		||||
      for any such Derivative Works as a whole, provided Your use,
 | 
			
		||||
      reproduction, and distribution of the Work otherwise complies with
 | 
			
		||||
      the conditions stated in this License.
 | 
			
		||||
 | 
			
		||||
   5. Submission of Contributions. Unless You explicitly state otherwise,
 | 
			
		||||
      any Contribution intentionally submitted for inclusion in the Work
 | 
			
		||||
      by You to the Licensor shall be under the terms and conditions of
 | 
			
		||||
      this License, without any additional terms or conditions.
 | 
			
		||||
      Notwithstanding the above, nothing herein shall supersede or modify
 | 
			
		||||
      the terms of any separate license agreement you may have executed
 | 
			
		||||
      with Licensor regarding such Contributions.
 | 
			
		||||
 | 
			
		||||
   6. Trademarks. This License does not grant permission to use the trade
 | 
			
		||||
      names, trademarks, service marks, or product names of the Licensor,
 | 
			
		||||
      except as required for reasonable and customary use in describing the
 | 
			
		||||
      origin of the Work and reproducing the content of the NOTICE file.
 | 
			
		||||
 | 
			
		||||
   7. Disclaimer of Warranty. Unless required by applicable law or
 | 
			
		||||
      agreed to in writing, Licensor provides the Work (and each
 | 
			
		||||
      Contributor provides its Contributions) on an "AS IS" BASIS,
 | 
			
		||||
      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
 | 
			
		||||
      implied, including, without limitation, any warranties or conditions
 | 
			
		||||
      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
 | 
			
		||||
      PARTICULAR PURPOSE. You are solely responsible for determining the
 | 
			
		||||
      appropriateness of using or redistributing the Work and assume any
 | 
			
		||||
      risks associated with Your exercise of permissions under this License.
 | 
			
		||||
 | 
			
		||||
   8. Limitation of Liability. In no event and under no legal theory,
 | 
			
		||||
      whether in tort (including negligence), contract, or otherwise,
 | 
			
		||||
      unless required by applicable law (such as deliberate and grossly
 | 
			
		||||
      negligent acts) or agreed to in writing, shall any Contributor be
 | 
			
		||||
      liable to You for damages, including any direct, indirect, special,
 | 
			
		||||
      incidental, or consequential damages of any character arising as a
 | 
			
		||||
      result of this License or out of the use or inability to use the
 | 
			
		||||
      Work (including but not limited to damages for loss of goodwill,
 | 
			
		||||
      work stoppage, computer failure or malfunction, or any and all
 | 
			
		||||
      other commercial damages or losses), even if such Contributor
 | 
			
		||||
      has been advised of the possibility of such damages.
 | 
			
		||||
 | 
			
		||||
   9. Accepting Warranty or Additional Liability. While redistributing
 | 
			
		||||
      the Work or Derivative Works thereof, You may choose to offer,
 | 
			
		||||
      and charge a fee for, acceptance of support, warranty, indemnity,
 | 
			
		||||
      or other liability obligations and/or rights consistent with this
 | 
			
		||||
      License. However, in accepting such obligations, You may act only
 | 
			
		||||
      on Your own behalf and on Your sole responsibility, not on behalf
 | 
			
		||||
      of any other Contributor, and only if You agree to indemnify,
 | 
			
		||||
      defend, and hold each Contributor harmless for any liability
 | 
			
		||||
      incurred by, or claims asserted against, such Contributor by reason
 | 
			
		||||
      of your accepting any such warranty or additional liability.
 | 
			
		||||
 | 
			
		||||
   END OF TERMS AND CONDITIONS
 | 
			
		||||
 | 
			
		||||
   APPENDIX: How to apply the Apache License to your work.
 | 
			
		||||
 | 
			
		||||
      To apply the Apache License to your work, attach the following
 | 
			
		||||
      boilerplate notice, with the fields enclosed by brackets "{}"
 | 
			
		||||
      replaced with your own identifying information. (Don't include
 | 
			
		||||
      the brackets!)  The text should be enclosed in the appropriate
 | 
			
		||||
      comment syntax for the file format. We also recommend that a
 | 
			
		||||
      file or class name and description of purpose be included on the
 | 
			
		||||
      same "printed page" as the copyright notice for easier
 | 
			
		||||
      identification within third-party archives.
 | 
			
		||||
 | 
			
		||||
   Copyright {yyyy} {name of copyright owner}
 | 
			
		||||
 | 
			
		||||
   Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
   you may not use this file except in compliance with the License.
 | 
			
		||||
   You may obtain a copy of the License at
 | 
			
		||||
 | 
			
		||||
       http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 | 
			
		||||
   Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
   distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
   See the License for the specific language governing permissions and
 | 
			
		||||
   limitations under the License.
 | 
			
		||||
							
								
								
									
										53
									
								
								vendor/github.com/heketi/heketi/client/api/go-client/backup.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								vendor/github.com/heketi/heketi/client/api/go-client/backup.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,53 @@
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2016 The heketi Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
//
 | 
			
		||||
 | 
			
		||||
package client
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"io"
 | 
			
		||||
	"net/http"
 | 
			
		||||
 | 
			
		||||
	"github.com/heketi/heketi/pkg/utils"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func (c *Client) BackupDb(w io.Writer) error {
 | 
			
		||||
	// Create a request
 | 
			
		||||
	req, err := http.NewRequest("GET", c.host+"/backup/db", nil)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Send request
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusOK {
 | 
			
		||||
		return utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Read data from response
 | 
			
		||||
	defer r.Body.Close()
 | 
			
		||||
	_, err = io.Copy(w, r.Body)
 | 
			
		||||
 | 
			
		||||
	return err
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										180
									
								
								vendor/github.com/heketi/heketi/client/api/go-client/client.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										180
									
								
								vendor/github.com/heketi/heketi/client/api/go-client/client.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,180 @@
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2015 The heketi Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
//
 | 
			
		||||
 | 
			
		||||
package client
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"crypto/sha256"
 | 
			
		||||
	"encoding/hex"
 | 
			
		||||
	"net/http"
 | 
			
		||||
	"time"
 | 
			
		||||
 | 
			
		||||
	jwt "github.com/dgrijalva/jwt-go"
 | 
			
		||||
	"github.com/heketi/heketi/pkg/utils"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
const (
 | 
			
		||||
	MAX_CONCURRENT_REQUESTS = 32
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// Client object
 | 
			
		||||
type Client struct {
 | 
			
		||||
	host     string
 | 
			
		||||
	key      string
 | 
			
		||||
	user     string
 | 
			
		||||
	throttle chan bool
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Creates a new client to access a Heketi server
 | 
			
		||||
func NewClient(host, user, key string) *Client {
 | 
			
		||||
	c := &Client{}
 | 
			
		||||
 | 
			
		||||
	c.key = key
 | 
			
		||||
	c.host = host
 | 
			
		||||
	c.user = user
 | 
			
		||||
 | 
			
		||||
	// Maximum concurrent requests
 | 
			
		||||
	c.throttle = make(chan bool, MAX_CONCURRENT_REQUESTS)
 | 
			
		||||
 | 
			
		||||
	return c
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Create a client to access a Heketi server without authentication enabled
 | 
			
		||||
func NewClientNoAuth(host string) *Client {
 | 
			
		||||
	return NewClient(host, "", "")
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Simple Hello test to check if the server is up
 | 
			
		||||
func (c *Client) Hello() error {
 | 
			
		||||
	// Create request
 | 
			
		||||
	req, err := http.NewRequest("GET", c.host+"/hello", nil)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Get info
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusOK {
 | 
			
		||||
		return utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Make sure we do not run out of fds by throttling the requests
 | 
			
		||||
func (c *Client) do(req *http.Request) (*http.Response, error) {
 | 
			
		||||
	c.throttle <- true
 | 
			
		||||
	defer func() {
 | 
			
		||||
		<-c.throttle
 | 
			
		||||
	}()
 | 
			
		||||
 | 
			
		||||
	httpClient := &http.Client{}
 | 
			
		||||
	httpClient.CheckRedirect = c.checkRedirect
 | 
			
		||||
	return httpClient.Do(req)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// This function is called by the http package if it detects that it needs to
 | 
			
		||||
// be redirected.  This happens when the server returns a 303 HTTP Status.
 | 
			
		||||
// Here we create a new token before it makes the next request.
 | 
			
		||||
func (c *Client) checkRedirect(req *http.Request, via []*http.Request) error {
 | 
			
		||||
	return c.setToken(req)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Wait for the job to finish, waiting waitTime on every loop
 | 
			
		||||
func (c *Client) waitForResponseWithTimer(r *http.Response,
 | 
			
		||||
	waitTime time.Duration) (*http.Response, error) {
 | 
			
		||||
 | 
			
		||||
	// Get temp resource
 | 
			
		||||
	location, err := r.Location()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	for {
 | 
			
		||||
		// Create request
 | 
			
		||||
		req, err := http.NewRequest("GET", location.String(), nil)
 | 
			
		||||
		if err != nil {
 | 
			
		||||
			return nil, err
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		// Set token
 | 
			
		||||
		err = c.setToken(req)
 | 
			
		||||
		if err != nil {
 | 
			
		||||
			return nil, err
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		// Wait for response
 | 
			
		||||
		r, err = c.do(req)
 | 
			
		||||
		if err != nil {
 | 
			
		||||
			return nil, err
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		// Check if the request is pending
 | 
			
		||||
		if r.Header.Get("X-Pending") == "true" {
 | 
			
		||||
			if r.StatusCode != http.StatusOK {
 | 
			
		||||
				return nil, utils.GetErrorFromResponse(r)
 | 
			
		||||
			}
 | 
			
		||||
			time.Sleep(waitTime)
 | 
			
		||||
		} else {
 | 
			
		||||
			return r, nil
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Create JSON Web Token
 | 
			
		||||
func (c *Client) setToken(r *http.Request) error {
 | 
			
		||||
 | 
			
		||||
	// Create qsh hash
 | 
			
		||||
	qshstring := r.Method + "&" + r.URL.Path
 | 
			
		||||
	hash := sha256.New()
 | 
			
		||||
	hash.Write([]byte(qshstring))
 | 
			
		||||
 | 
			
		||||
	// Create Token
 | 
			
		||||
	token := jwt.NewWithClaims(jwt.SigningMethodHS256, jwt.MapClaims{
 | 
			
		||||
		// Set issuer
 | 
			
		||||
		"iss": c.user,
 | 
			
		||||
 | 
			
		||||
		// Set issued at time
 | 
			
		||||
		"iat": time.Now().Unix(),
 | 
			
		||||
 | 
			
		||||
		// Set expiration
 | 
			
		||||
		"exp": time.Now().Add(time.Minute * 5).Unix(),
 | 
			
		||||
 | 
			
		||||
		// Set qsh
 | 
			
		||||
		"qsh": hex.EncodeToString(hash.Sum(nil)),
 | 
			
		||||
	})
 | 
			
		||||
 | 
			
		||||
	// Sign the token
 | 
			
		||||
	signedtoken, err := token.SignedString([]byte(c.key))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Save it in the header
 | 
			
		||||
	r.Header.Set("Authorization", "bearer "+signedtoken)
 | 
			
		||||
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										152
									
								
								vendor/github.com/heketi/heketi/client/api/go-client/cluster.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										152
									
								
								vendor/github.com/heketi/heketi/client/api/go-client/cluster.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,152 @@
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2015 The heketi Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
//
 | 
			
		||||
 | 
			
		||||
package client
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"bytes"
 | 
			
		||||
	"github.com/heketi/heketi/pkg/glusterfs/api"
 | 
			
		||||
	"github.com/heketi/heketi/pkg/utils"
 | 
			
		||||
	"net/http"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func (c *Client) ClusterCreate() (*api.ClusterInfoResponse, error) {
 | 
			
		||||
 | 
			
		||||
	// Create a request
 | 
			
		||||
	req, err := http.NewRequest("POST", c.host+"/clusters", bytes.NewBuffer([]byte(`{}`)))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	req.Header.Set("Content-Type", "application/json")
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Send request
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusCreated {
 | 
			
		||||
		return nil, utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Read JSON response
 | 
			
		||||
	var cluster api.ClusterInfoResponse
 | 
			
		||||
	err = utils.GetJsonFromResponse(r, &cluster)
 | 
			
		||||
	r.Body.Close()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return &cluster, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *Client) ClusterInfo(id string) (*api.ClusterInfoResponse, error) {
 | 
			
		||||
 | 
			
		||||
	// Create request
 | 
			
		||||
	req, err := http.NewRequest("GET", c.host+"/clusters/"+id, nil)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Get info
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusOK {
 | 
			
		||||
		return nil, utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Read JSON response
 | 
			
		||||
	var cluster api.ClusterInfoResponse
 | 
			
		||||
	err = utils.GetJsonFromResponse(r, &cluster)
 | 
			
		||||
	r.Body.Close()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return &cluster, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *Client) ClusterList() (*api.ClusterListResponse, error) {
 | 
			
		||||
 | 
			
		||||
	// Create request
 | 
			
		||||
	req, err := http.NewRequest("GET", c.host+"/clusters", nil)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Get info
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusOK {
 | 
			
		||||
		return nil, utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Read JSON response
 | 
			
		||||
	var clusters api.ClusterListResponse
 | 
			
		||||
	err = utils.GetJsonFromResponse(r, &clusters)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return &clusters, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *Client) ClusterDelete(id string) error {
 | 
			
		||||
 | 
			
		||||
	// Create DELETE request
 | 
			
		||||
	req, err := http.NewRequest("DELETE", c.host+"/clusters/"+id, nil)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Send request
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusOK {
 | 
			
		||||
		return utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										171
									
								
								vendor/github.com/heketi/heketi/client/api/go-client/device.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										171
									
								
								vendor/github.com/heketi/heketi/client/api/go-client/device.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,171 @@
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2015 The heketi Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
//
 | 
			
		||||
 | 
			
		||||
package client
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"bytes"
 | 
			
		||||
	"encoding/json"
 | 
			
		||||
	"github.com/heketi/heketi/pkg/glusterfs/api"
 | 
			
		||||
	"github.com/heketi/heketi/pkg/utils"
 | 
			
		||||
	"net/http"
 | 
			
		||||
	"time"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func (c *Client) DeviceAdd(request *api.DeviceAddRequest) error {
 | 
			
		||||
	// Marshal request to JSON
 | 
			
		||||
	buffer, err := json.Marshal(request)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Create a request
 | 
			
		||||
	req, err := http.NewRequest("POST", c.host+"/devices", bytes.NewBuffer(buffer))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	req.Header.Set("Content-Type", "application/json")
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Send request
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusAccepted {
 | 
			
		||||
		return utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Wait for response
 | 
			
		||||
	r, err = c.waitForResponseWithTimer(r, time.Second)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusNoContent {
 | 
			
		||||
		return utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *Client) DeviceInfo(id string) (*api.DeviceInfoResponse, error) {
 | 
			
		||||
 | 
			
		||||
	// Create request
 | 
			
		||||
	req, err := http.NewRequest("GET", c.host+"/devices/"+id, nil)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Get info
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusOK {
 | 
			
		||||
		return nil, utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Read JSON response
 | 
			
		||||
	var device api.DeviceInfoResponse
 | 
			
		||||
	err = utils.GetJsonFromResponse(r, &device)
 | 
			
		||||
	r.Body.Close()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return &device, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *Client) DeviceDelete(id string) error {
 | 
			
		||||
 | 
			
		||||
	// Create a request
 | 
			
		||||
	req, err := http.NewRequest("DELETE", c.host+"/devices/"+id, nil)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Send request
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusAccepted {
 | 
			
		||||
		return utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Wait for response
 | 
			
		||||
	r, err = c.waitForResponseWithTimer(r, time.Second)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusNoContent {
 | 
			
		||||
		return utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *Client) DeviceState(id string,
 | 
			
		||||
	request *api.StateRequest) error {
 | 
			
		||||
 | 
			
		||||
	// Marshal request to JSON
 | 
			
		||||
	buffer, err := json.Marshal(request)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Create a request
 | 
			
		||||
	req, err := http.NewRequest("POST",
 | 
			
		||||
		c.host+"/devices/"+id+"/state",
 | 
			
		||||
		bytes.NewBuffer(buffer))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	req.Header.Set("Content-Type", "application/json")
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Get info
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusOK {
 | 
			
		||||
		return utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										178
									
								
								vendor/github.com/heketi/heketi/client/api/go-client/node.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										178
									
								
								vendor/github.com/heketi/heketi/client/api/go-client/node.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,178 @@
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2015 The heketi Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
//
 | 
			
		||||
 | 
			
		||||
package client
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"bytes"
 | 
			
		||||
	"encoding/json"
 | 
			
		||||
	"github.com/heketi/heketi/pkg/glusterfs/api"
 | 
			
		||||
	"github.com/heketi/heketi/pkg/utils"
 | 
			
		||||
	"net/http"
 | 
			
		||||
	"time"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func (c *Client) NodeAdd(request *api.NodeAddRequest) (*api.NodeInfoResponse, error) {
 | 
			
		||||
 | 
			
		||||
	// Marshal request to JSON
 | 
			
		||||
	buffer, err := json.Marshal(request)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Create a request
 | 
			
		||||
	req, err := http.NewRequest("POST", c.host+"/nodes", bytes.NewBuffer(buffer))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	req.Header.Set("Content-Type", "application/json")
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Send request
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusAccepted {
 | 
			
		||||
		return nil, utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Wait for response
 | 
			
		||||
	r, err = c.waitForResponseWithTimer(r, time.Millisecond*250)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusOK {
 | 
			
		||||
		return nil, utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Read JSON response
 | 
			
		||||
	var node api.NodeInfoResponse
 | 
			
		||||
	err = utils.GetJsonFromResponse(r, &node)
 | 
			
		||||
	r.Body.Close()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return &node, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *Client) NodeInfo(id string) (*api.NodeInfoResponse, error) {
 | 
			
		||||
 | 
			
		||||
	// Create request
 | 
			
		||||
	req, err := http.NewRequest("GET", c.host+"/nodes/"+id, nil)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Get info
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusOK {
 | 
			
		||||
		return nil, utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Read JSON response
 | 
			
		||||
	var node api.NodeInfoResponse
 | 
			
		||||
	err = utils.GetJsonFromResponse(r, &node)
 | 
			
		||||
	r.Body.Close()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return &node, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *Client) NodeDelete(id string) error {
 | 
			
		||||
 | 
			
		||||
	// Create a request
 | 
			
		||||
	req, err := http.NewRequest("DELETE", c.host+"/nodes/"+id, nil)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Send request
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusAccepted {
 | 
			
		||||
		return utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Wait for response
 | 
			
		||||
	r, err = c.waitForResponseWithTimer(r, time.Millisecond*250)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusNoContent {
 | 
			
		||||
		return utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *Client) NodeState(id string, request *api.StateRequest) error {
 | 
			
		||||
	// Marshal request to JSON
 | 
			
		||||
	buffer, err := json.Marshal(request)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Create a request
 | 
			
		||||
	req, err := http.NewRequest("POST",
 | 
			
		||||
		c.host+"/nodes/"+id+"/state",
 | 
			
		||||
		bytes.NewBuffer(buffer))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	req.Header.Set("Content-Type", "application/json")
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Get info
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusOK {
 | 
			
		||||
		return utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										66
									
								
								vendor/github.com/heketi/heketi/client/api/go-client/topology.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								vendor/github.com/heketi/heketi/client/api/go-client/topology.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,66 @@
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2015 The heketi Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
//
 | 
			
		||||
 | 
			
		||||
package client
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"github.com/heketi/heketi/pkg/glusterfs/api"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func (c *Client) TopologyInfo() (*api.TopologyInfoResponse, error) {
 | 
			
		||||
	topo := &api.TopologyInfoResponse{
 | 
			
		||||
		ClusterList: make([]api.Cluster, 0),
 | 
			
		||||
	}
 | 
			
		||||
	clusterlist, err := c.ClusterList()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	for _, cluster := range clusterlist.Clusters {
 | 
			
		||||
		clusteri, err := c.ClusterInfo(cluster)
 | 
			
		||||
		if err != nil {
 | 
			
		||||
			return nil, err
 | 
			
		||||
		}
 | 
			
		||||
		cluster := api.Cluster{
 | 
			
		||||
			Id:      clusteri.Id,
 | 
			
		||||
			Volumes: make([]api.VolumeInfoResponse, 0),
 | 
			
		||||
			Nodes:   make([]api.NodeInfoResponse, 0),
 | 
			
		||||
		}
 | 
			
		||||
		cluster.Id = clusteri.Id
 | 
			
		||||
 | 
			
		||||
		// Iterate over the volume list in the cluster
 | 
			
		||||
		for _, volumes := range clusteri.Volumes {
 | 
			
		||||
			volumesi, err := c.VolumeInfo(volumes)
 | 
			
		||||
			if err != nil {
 | 
			
		||||
				return nil, err
 | 
			
		||||
			}
 | 
			
		||||
			if volumesi.Cluster == cluster.Id {
 | 
			
		||||
				cluster.Volumes = append(cluster.Volumes, *volumesi)
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		// Iterate over the nodes in the cluster
 | 
			
		||||
		for _, node := range clusteri.Nodes {
 | 
			
		||||
			nodei, err := c.NodeInfo(string(node))
 | 
			
		||||
			if err != nil {
 | 
			
		||||
				return nil, err
 | 
			
		||||
			}
 | 
			
		||||
			cluster.Nodes = append(cluster.Nodes, *nodei)
 | 
			
		||||
		}
 | 
			
		||||
		topo.ClusterList = append(topo.ClusterList, cluster)
 | 
			
		||||
	}
 | 
			
		||||
	return topo, nil
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										237
									
								
								vendor/github.com/heketi/heketi/client/api/go-client/volume.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										237
									
								
								vendor/github.com/heketi/heketi/client/api/go-client/volume.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,237 @@
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2015 The heketi Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
//
 | 
			
		||||
 | 
			
		||||
package client
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"bytes"
 | 
			
		||||
	"encoding/json"
 | 
			
		||||
	"net/http"
 | 
			
		||||
	"time"
 | 
			
		||||
 | 
			
		||||
	"github.com/heketi/heketi/pkg/glusterfs/api"
 | 
			
		||||
	"github.com/heketi/heketi/pkg/utils"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func (c *Client) VolumeCreate(request *api.VolumeCreateRequest) (
 | 
			
		||||
	*api.VolumeInfoResponse, error) {
 | 
			
		||||
 | 
			
		||||
	// Marshal request to JSON
 | 
			
		||||
	buffer, err := json.Marshal(request)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Create a request
 | 
			
		||||
	req, err := http.NewRequest("POST",
 | 
			
		||||
		c.host+"/volumes",
 | 
			
		||||
		bytes.NewBuffer(buffer))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	req.Header.Set("Content-Type", "application/json")
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Send request
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusAccepted {
 | 
			
		||||
		return nil, utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Wait for response
 | 
			
		||||
	r, err = c.waitForResponseWithTimer(r, time.Second)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusOK {
 | 
			
		||||
		return nil, utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Read JSON response
 | 
			
		||||
	var volume api.VolumeInfoResponse
 | 
			
		||||
	err = utils.GetJsonFromResponse(r, &volume)
 | 
			
		||||
	r.Body.Close()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return &volume, nil
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *Client) VolumeExpand(id string, request *api.VolumeExpandRequest) (
 | 
			
		||||
	*api.VolumeInfoResponse, error) {
 | 
			
		||||
 | 
			
		||||
	// Marshal request to JSON
 | 
			
		||||
	buffer, err := json.Marshal(request)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Create a request
 | 
			
		||||
	req, err := http.NewRequest("POST",
 | 
			
		||||
		c.host+"/volumes/"+id+"/expand",
 | 
			
		||||
		bytes.NewBuffer(buffer))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	req.Header.Set("Content-Type", "application/json")
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Send request
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusAccepted {
 | 
			
		||||
		return nil, utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Wait for response
 | 
			
		||||
	r, err = c.waitForResponseWithTimer(r, time.Second)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusOK {
 | 
			
		||||
		return nil, utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Read JSON response
 | 
			
		||||
	var volume api.VolumeInfoResponse
 | 
			
		||||
	err = utils.GetJsonFromResponse(r, &volume)
 | 
			
		||||
	r.Body.Close()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return &volume, nil
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *Client) VolumeList() (*api.VolumeListResponse, error) {
 | 
			
		||||
 | 
			
		||||
	// Create request
 | 
			
		||||
	req, err := http.NewRequest("GET", c.host+"/volumes", nil)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Get info
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusOK {
 | 
			
		||||
		return nil, utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Read JSON response
 | 
			
		||||
	var volumes api.VolumeListResponse
 | 
			
		||||
	err = utils.GetJsonFromResponse(r, &volumes)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return &volumes, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *Client) VolumeInfo(id string) (*api.VolumeInfoResponse, error) {
 | 
			
		||||
 | 
			
		||||
	// Create request
 | 
			
		||||
	req, err := http.NewRequest("GET", c.host+"/volumes/"+id, nil)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Get info
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusOK {
 | 
			
		||||
		return nil, utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Read JSON response
 | 
			
		||||
	var volume api.VolumeInfoResponse
 | 
			
		||||
	err = utils.GetJsonFromResponse(r, &volume)
 | 
			
		||||
	r.Body.Close()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return &volume, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *Client) VolumeDelete(id string) error {
 | 
			
		||||
 | 
			
		||||
	// Create a request
 | 
			
		||||
	req, err := http.NewRequest("DELETE", c.host+"/volumes/"+id, nil)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Set token
 | 
			
		||||
	err = c.setToken(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Send request
 | 
			
		||||
	r, err := c.do(req)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusAccepted {
 | 
			
		||||
		return utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Wait for response
 | 
			
		||||
	r, err = c.waitForResponseWithTimer(r, time.Second)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	if r.StatusCode != http.StatusNoContent {
 | 
			
		||||
		return utils.GetErrorFromResponse(r)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										251
									
								
								vendor/github.com/heketi/heketi/pkg/glusterfs/api/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										251
									
								
								vendor/github.com/heketi/heketi/pkg/glusterfs/api/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,251 @@
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2016 The heketi Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
//
 | 
			
		||||
 | 
			
		||||
//
 | 
			
		||||
// Please see https://github.com/heketi/heketi/wiki/API
 | 
			
		||||
// for documentation
 | 
			
		||||
//
 | 
			
		||||
package api
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"fmt"
 | 
			
		||||
	"sort"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// State
 | 
			
		||||
type EntryState string
 | 
			
		||||
 | 
			
		||||
const (
 | 
			
		||||
	EntryStateUnknown EntryState = ""
 | 
			
		||||
	EntryStateOnline  EntryState = "online"
 | 
			
		||||
	EntryStateOffline EntryState = "offline"
 | 
			
		||||
	EntryStateFailed  EntryState = "failed"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
type DurabilityType string
 | 
			
		||||
 | 
			
		||||
const (
 | 
			
		||||
	DurabilityReplicate      DurabilityType = "replicate"
 | 
			
		||||
	DurabilityDistributeOnly DurabilityType = "none"
 | 
			
		||||
	DurabilityEC             DurabilityType = "disperse"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// Common
 | 
			
		||||
type StateRequest struct {
 | 
			
		||||
	State EntryState `json:"state"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Storage values in KB
 | 
			
		||||
type StorageSize struct {
 | 
			
		||||
	Total uint64 `json:"total"`
 | 
			
		||||
	Free  uint64 `json:"free"`
 | 
			
		||||
	Used  uint64 `json:"used"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type HostAddresses struct {
 | 
			
		||||
	Manage  sort.StringSlice `json:"manage"`
 | 
			
		||||
	Storage sort.StringSlice `json:"storage"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Brick
 | 
			
		||||
type BrickInfo struct {
 | 
			
		||||
	Id       string `json:"id"`
 | 
			
		||||
	Path     string `json:"path"`
 | 
			
		||||
	DeviceId string `json:"device"`
 | 
			
		||||
	NodeId   string `json:"node"`
 | 
			
		||||
 | 
			
		||||
	// Size in KB
 | 
			
		||||
	Size uint64 `json:"size"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Device
 | 
			
		||||
type Device struct {
 | 
			
		||||
	Name string `json:"name"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type DeviceAddRequest struct {
 | 
			
		||||
	Device
 | 
			
		||||
	NodeId string `json:"node"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type DeviceInfo struct {
 | 
			
		||||
	Device
 | 
			
		||||
	Storage StorageSize `json:"storage"`
 | 
			
		||||
	Id      string      `json:"id"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type DeviceInfoResponse struct {
 | 
			
		||||
	DeviceInfo
 | 
			
		||||
	State  EntryState  `json:"state"`
 | 
			
		||||
	Bricks []BrickInfo `json:"bricks"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Node
 | 
			
		||||
type NodeAddRequest struct {
 | 
			
		||||
	Zone      int           `json:"zone"`
 | 
			
		||||
	Hostnames HostAddresses `json:"hostnames"`
 | 
			
		||||
	ClusterId string        `json:"cluster"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type NodeInfo struct {
 | 
			
		||||
	NodeAddRequest
 | 
			
		||||
	Id string `json:"id"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type NodeInfoResponse struct {
 | 
			
		||||
	NodeInfo
 | 
			
		||||
	State       EntryState           `json:"state"`
 | 
			
		||||
	DevicesInfo []DeviceInfoResponse `json:"devices"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Cluster
 | 
			
		||||
type Cluster struct {
 | 
			
		||||
	Volumes []VolumeInfoResponse `json:"volumes"`
 | 
			
		||||
	Nodes   []NodeInfoResponse   `json:"nodes"`
 | 
			
		||||
	Id      string               `json:"id"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type TopologyInfoResponse struct {
 | 
			
		||||
	ClusterList []Cluster `json:"clusters"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type ClusterInfoResponse struct {
 | 
			
		||||
	Id      string           `json:"id"`
 | 
			
		||||
	Nodes   sort.StringSlice `json:"nodes"`
 | 
			
		||||
	Volumes sort.StringSlice `json:"volumes"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type ClusterListResponse struct {
 | 
			
		||||
	Clusters []string `json:"clusters"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Durabilities
 | 
			
		||||
type ReplicaDurability struct {
 | 
			
		||||
	Replica int `json:"replica,omitempty"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type DisperseDurability struct {
 | 
			
		||||
	Data       int `json:"data,omitempty"`
 | 
			
		||||
	Redundancy int `json:"redundancy,omitempty"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Volume
 | 
			
		||||
type VolumeDurabilityInfo struct {
 | 
			
		||||
	Type      DurabilityType     `json:"type,omitempty"`
 | 
			
		||||
	Replicate ReplicaDurability  `json:"replicate,omitempty"`
 | 
			
		||||
	Disperse  DisperseDurability `json:"disperse,omitempty"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type VolumeCreateRequest struct {
 | 
			
		||||
	// Size in GB
 | 
			
		||||
	Size       int                  `json:"size"`
 | 
			
		||||
	Clusters   []string             `json:"clusters,omitempty"`
 | 
			
		||||
	Name       string               `json:"name"`
 | 
			
		||||
	Durability VolumeDurabilityInfo `json:"durability,omitempty"`
 | 
			
		||||
	Snapshot   struct {
 | 
			
		||||
		Enable bool    `json:"enable"`
 | 
			
		||||
		Factor float32 `json:"factor"`
 | 
			
		||||
	} `json:"snapshot"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type VolumeInfo struct {
 | 
			
		||||
	VolumeCreateRequest
 | 
			
		||||
	Id      string `json:"id"`
 | 
			
		||||
	Cluster string `json:"cluster"`
 | 
			
		||||
	Mount   struct {
 | 
			
		||||
		GlusterFS struct {
 | 
			
		||||
			Hosts      []string          `json:"hosts"`
 | 
			
		||||
			MountPoint string            `json:"device"`
 | 
			
		||||
			Options    map[string]string `json:"options"`
 | 
			
		||||
		} `json:"glusterfs"`
 | 
			
		||||
	} `json:"mount"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type VolumeInfoResponse struct {
 | 
			
		||||
	VolumeInfo
 | 
			
		||||
	Bricks []BrickInfo `json:"bricks"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type VolumeListResponse struct {
 | 
			
		||||
	Volumes []string `json:"volumes"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type VolumeExpandRequest struct {
 | 
			
		||||
	Size int `json:"expand_size"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Constructors
 | 
			
		||||
 | 
			
		||||
func NewVolumeInfoResponse() *VolumeInfoResponse {
 | 
			
		||||
 | 
			
		||||
	info := &VolumeInfoResponse{}
 | 
			
		||||
	info.Mount.GlusterFS.Options = make(map[string]string)
 | 
			
		||||
	info.Bricks = make([]BrickInfo, 0)
 | 
			
		||||
 | 
			
		||||
	return info
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// String functions
 | 
			
		||||
func (v *VolumeInfoResponse) String() string {
 | 
			
		||||
	s := fmt.Sprintf("Name: %v\n"+
 | 
			
		||||
		"Size: %v\n"+
 | 
			
		||||
		"Volume Id: %v\n"+
 | 
			
		||||
		"Cluster Id: %v\n"+
 | 
			
		||||
		"Mount: %v\n"+
 | 
			
		||||
		"Mount Options: backup-volfile-servers=%v\n"+
 | 
			
		||||
		"Durability Type: %v\n",
 | 
			
		||||
		v.Name,
 | 
			
		||||
		v.Size,
 | 
			
		||||
		v.Id,
 | 
			
		||||
		v.Cluster,
 | 
			
		||||
		v.Mount.GlusterFS.MountPoint,
 | 
			
		||||
		v.Mount.GlusterFS.Options["backup-volfile-servers"],
 | 
			
		||||
		v.Durability.Type)
 | 
			
		||||
 | 
			
		||||
	switch v.Durability.Type {
 | 
			
		||||
	case DurabilityEC:
 | 
			
		||||
		s += fmt.Sprintf("Disperse Data: %v\n"+
 | 
			
		||||
			"Disperse Redundancy: %v\n",
 | 
			
		||||
			v.Durability.Disperse.Data,
 | 
			
		||||
			v.Durability.Disperse.Redundancy)
 | 
			
		||||
	case DurabilityReplicate:
 | 
			
		||||
		s += fmt.Sprintf("Distributed+Replica: %v\n",
 | 
			
		||||
			v.Durability.Replicate.Replica)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if v.Snapshot.Enable {
 | 
			
		||||
		s += fmt.Sprintf("Snapshot Factor: %.2f\n",
 | 
			
		||||
			v.Snapshot.Factor)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/*
 | 
			
		||||
		s += "\nBricks:\n"
 | 
			
		||||
		for _, b := range v.Bricks {
 | 
			
		||||
			s += fmt.Sprintf("Id: %v\n"+
 | 
			
		||||
				"Path: %v\n"+
 | 
			
		||||
				"Size (GiB): %v\n"+
 | 
			
		||||
				"Node: %v\n"+
 | 
			
		||||
				"Device: %v\n\n",
 | 
			
		||||
				b.Id,
 | 
			
		||||
				b.Path,
 | 
			
		||||
				b.Size/(1024*1024),
 | 
			
		||||
				b.NodeId,
 | 
			
		||||
				b.DeviceId)
 | 
			
		||||
		}
 | 
			
		||||
	*/
 | 
			
		||||
 | 
			
		||||
	return s
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										43
									
								
								vendor/github.com/heketi/heketi/pkg/utils/bodystring.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								vendor/github.com/heketi/heketi/pkg/utils/bodystring.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,43 @@
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2015 The heketi Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
//
 | 
			
		||||
 | 
			
		||||
package utils
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"errors"
 | 
			
		||||
	"io"
 | 
			
		||||
	"io/ioutil"
 | 
			
		||||
	"net/http"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// Return the body from a response as a string
 | 
			
		||||
func GetStringFromResponse(r *http.Response) (string, error) {
 | 
			
		||||
	body, err := ioutil.ReadAll(io.LimitReader(r.Body, r.ContentLength))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return "", err
 | 
			
		||||
	}
 | 
			
		||||
	r.Body.Close()
 | 
			
		||||
	return string(body), nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Return the body from a response as an error
 | 
			
		||||
func GetErrorFromResponse(r *http.Response) error {
 | 
			
		||||
	s, err := GetStringFromResponse(r)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	return errors.New(s)
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										50
									
								
								vendor/github.com/heketi/heketi/pkg/utils/jsonutils.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								vendor/github.com/heketi/heketi/pkg/utils/jsonutils.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,50 @@
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2015 The heketi Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
//
 | 
			
		||||
 | 
			
		||||
package utils
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"encoding/json"
 | 
			
		||||
	"io"
 | 
			
		||||
	"io/ioutil"
 | 
			
		||||
	"net/http"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func jsonFromBody(r io.Reader, v interface{}) error {
 | 
			
		||||
 | 
			
		||||
	// Check body
 | 
			
		||||
	body, err := ioutil.ReadAll(r)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	if err := json.Unmarshal(body, v); err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Unmarshal JSON from request
 | 
			
		||||
func GetJsonFromRequest(r *http.Request, v interface{}) error {
 | 
			
		||||
	defer r.Body.Close()
 | 
			
		||||
	return jsonFromBody(r.Body, v)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Unmarshal JSON from response
 | 
			
		||||
func GetJsonFromResponse(r *http.Response, v interface{}) error {
 | 
			
		||||
	defer r.Body.Close()
 | 
			
		||||
	return jsonFromBody(r.Body, v)
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										151
									
								
								vendor/github.com/heketi/heketi/pkg/utils/log.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										151
									
								
								vendor/github.com/heketi/heketi/pkg/utils/log.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,151 @@
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2015 The heketi Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
//
 | 
			
		||||
 | 
			
		||||
package utils
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"fmt"
 | 
			
		||||
	"io"
 | 
			
		||||
	"log"
 | 
			
		||||
	"os"
 | 
			
		||||
	"runtime"
 | 
			
		||||
	"strings"
 | 
			
		||||
 | 
			
		||||
	"github.com/lpabon/godbc"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
type LogLevel int
 | 
			
		||||
 | 
			
		||||
// Log levels
 | 
			
		||||
const (
 | 
			
		||||
	LEVEL_NOLOG LogLevel = iota
 | 
			
		||||
	LEVEL_CRITICAL
 | 
			
		||||
	LEVEL_ERROR
 | 
			
		||||
	LEVEL_WARNING
 | 
			
		||||
	LEVEL_INFO
 | 
			
		||||
	LEVEL_DEBUG
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
var (
 | 
			
		||||
	stderr io.Writer = os.Stderr
 | 
			
		||||
	stdout io.Writer = os.Stdout
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
type Logger struct {
 | 
			
		||||
	critlog, errorlog, infolog *log.Logger
 | 
			
		||||
	debuglog, warninglog       *log.Logger
 | 
			
		||||
 | 
			
		||||
	level LogLevel
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func logWithLongFile(l *log.Logger, format string, v ...interface{}) {
 | 
			
		||||
	_, file, line, _ := runtime.Caller(2)
 | 
			
		||||
 | 
			
		||||
	// Shorten the path.
 | 
			
		||||
	// From
 | 
			
		||||
	// /builddir/build/BUILD/heketi-3f4a5b1b6edff87232e8b24533c53b4151ebd9c7/src/github.com/heketi/heketi/apps/glusterfs/volume_entry.go
 | 
			
		||||
	// to
 | 
			
		||||
	// src/github.com/heketi/heketi/apps/glusterfs/volume_entry.go
 | 
			
		||||
	i := strings.Index(file, "/src/")
 | 
			
		||||
	if i == -1 {
 | 
			
		||||
		i = 0
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	l.Print(fmt.Sprintf("%v:%v: ", file[i:], line) +
 | 
			
		||||
		fmt.Sprintf(format, v...))
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Create a new logger
 | 
			
		||||
func NewLogger(prefix string, level LogLevel) *Logger {
 | 
			
		||||
	godbc.Require(level >= 0, level)
 | 
			
		||||
	godbc.Require(level <= LEVEL_DEBUG, level)
 | 
			
		||||
 | 
			
		||||
	l := &Logger{}
 | 
			
		||||
 | 
			
		||||
	if level == LEVEL_NOLOG {
 | 
			
		||||
		l.level = LEVEL_DEBUG
 | 
			
		||||
	} else {
 | 
			
		||||
		l.level = level
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	l.critlog = log.New(stderr, prefix+" CRITICAL ", log.LstdFlags)
 | 
			
		||||
	l.errorlog = log.New(stderr, prefix+" ERROR ", log.LstdFlags)
 | 
			
		||||
	l.warninglog = log.New(stdout, prefix+" WARNING ", log.LstdFlags)
 | 
			
		||||
	l.infolog = log.New(stdout, prefix+" INFO ", log.LstdFlags)
 | 
			
		||||
	l.debuglog = log.New(stdout, prefix+" DEBUG ", log.LstdFlags)
 | 
			
		||||
 | 
			
		||||
	godbc.Ensure(l.critlog != nil)
 | 
			
		||||
	godbc.Ensure(l.errorlog != nil)
 | 
			
		||||
	godbc.Ensure(l.warninglog != nil)
 | 
			
		||||
	godbc.Ensure(l.infolog != nil)
 | 
			
		||||
	godbc.Ensure(l.debuglog != nil)
 | 
			
		||||
 | 
			
		||||
	return l
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Return current level
 | 
			
		||||
func (l *Logger) Level() LogLevel {
 | 
			
		||||
	return l.level
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Set level
 | 
			
		||||
func (l *Logger) SetLevel(level LogLevel) {
 | 
			
		||||
	l.level = level
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Log critical information
 | 
			
		||||
func (l *Logger) Critical(format string, v ...interface{}) {
 | 
			
		||||
	if l.level >= LEVEL_CRITICAL {
 | 
			
		||||
		logWithLongFile(l.critlog, format, v...)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Log error string
 | 
			
		||||
func (l *Logger) LogError(format string, v ...interface{}) {
 | 
			
		||||
	if l.level >= LEVEL_ERROR {
 | 
			
		||||
		logWithLongFile(l.errorlog, format, v...)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Log error variable
 | 
			
		||||
func (l *Logger) Err(err error) error {
 | 
			
		||||
	if l.level >= LEVEL_ERROR {
 | 
			
		||||
		logWithLongFile(l.errorlog, "%v", err)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return err
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Log warning information
 | 
			
		||||
func (l *Logger) Warning(format string, v ...interface{}) {
 | 
			
		||||
	if l.level >= LEVEL_WARNING {
 | 
			
		||||
		l.warninglog.Printf(format, v...)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Log string
 | 
			
		||||
func (l *Logger) Info(format string, v ...interface{}) {
 | 
			
		||||
	if l.level >= LEVEL_INFO {
 | 
			
		||||
		l.infolog.Printf(format, v...)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Log string as debug
 | 
			
		||||
func (l *Logger) Debug(format string, v ...interface{}) {
 | 
			
		||||
	if l.level >= LEVEL_DEBUG {
 | 
			
		||||
		logWithLongFile(l.debuglog, format, v...)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										40
									
								
								vendor/github.com/heketi/heketi/pkg/utils/sortedstrings.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								vendor/github.com/heketi/heketi/pkg/utils/sortedstrings.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,40 @@
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2015 The heketi Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
//
 | 
			
		||||
 | 
			
		||||
package utils
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"sort"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// Check if a sorted string list has a string
 | 
			
		||||
func SortedStringHas(s sort.StringSlice, x string) bool {
 | 
			
		||||
	index := s.Search(x)
 | 
			
		||||
	if index == len(s) {
 | 
			
		||||
		return false
 | 
			
		||||
	}
 | 
			
		||||
	return s[s.Search(x)] == x
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Delete a string from a sorted string list
 | 
			
		||||
func SortedStringsDelete(s sort.StringSlice, x string) sort.StringSlice {
 | 
			
		||||
	index := s.Search(x)
 | 
			
		||||
	if len(s) != index && s[index] == x {
 | 
			
		||||
		s = append(s[:index], s[index+1:]...)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return s
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										75
									
								
								vendor/github.com/heketi/heketi/pkg/utils/statusgroup.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								vendor/github.com/heketi/heketi/pkg/utils/statusgroup.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,75 @@
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2015 The heketi Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
//
 | 
			
		||||
 | 
			
		||||
package utils
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"sync"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
type StatusGroup struct {
 | 
			
		||||
	wg      sync.WaitGroup
 | 
			
		||||
	results chan error
 | 
			
		||||
	err     error
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Create a new goroutine error status collector
 | 
			
		||||
func NewStatusGroup() *StatusGroup {
 | 
			
		||||
	s := &StatusGroup{}
 | 
			
		||||
	s.results = make(chan error, 1)
 | 
			
		||||
 | 
			
		||||
	return s
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Adds to the number of goroutines it should wait
 | 
			
		||||
func (s *StatusGroup) Add(delta int) {
 | 
			
		||||
	s.wg.Add(delta)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Removes the number of pending goroutines by one
 | 
			
		||||
func (s *StatusGroup) Done() {
 | 
			
		||||
	s.wg.Done()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Goroutine can return an error back to caller
 | 
			
		||||
func (s *StatusGroup) Err(err error) {
 | 
			
		||||
	s.results <- err
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Returns an error if any of the spawned goroutines
 | 
			
		||||
// return an error.  Only the last error is saved.
 | 
			
		||||
// This function must be called last after the last
 | 
			
		||||
// s.Register() function
 | 
			
		||||
func (s *StatusGroup) Result() error {
 | 
			
		||||
 | 
			
		||||
	// This goroutine will wait until all
 | 
			
		||||
	// other privously spawned goroutines finish.
 | 
			
		||||
	// Once they finish, it will close the channel
 | 
			
		||||
	go func() {
 | 
			
		||||
		s.wg.Wait()
 | 
			
		||||
		close(s.results)
 | 
			
		||||
	}()
 | 
			
		||||
 | 
			
		||||
	// Read from the channel until close
 | 
			
		||||
	for err := range s.results {
 | 
			
		||||
		// Only save the last one
 | 
			
		||||
		if err != nil {
 | 
			
		||||
			s.err = err
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return s.err
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										51
									
								
								vendor/github.com/heketi/heketi/pkg/utils/stringset.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								vendor/github.com/heketi/heketi/pkg/utils/stringset.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,51 @@
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2015 The heketi Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
//
 | 
			
		||||
 | 
			
		||||
package utils
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"sort"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
type StringSet struct {
 | 
			
		||||
	Set sort.StringSlice
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Create a string set.
 | 
			
		||||
//
 | 
			
		||||
// A string set is a list where each element appears only once
 | 
			
		||||
func NewStringSet() *StringSet {
 | 
			
		||||
	return &StringSet{
 | 
			
		||||
		Set: make(sort.StringSlice, 0),
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Add a string to the string set
 | 
			
		||||
func (s *StringSet) Add(v string) {
 | 
			
		||||
	if !SortedStringHas(s.Set, v) {
 | 
			
		||||
		s.Set = append(s.Set, v)
 | 
			
		||||
		s.Set.Sort()
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Return string list
 | 
			
		||||
func (s *StringSet) Strings() []string {
 | 
			
		||||
	return s.Set
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (s *StringSet) Len() int {
 | 
			
		||||
	return len(s.Set)
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										40
									
								
								vendor/github.com/heketi/heketi/pkg/utils/stringstack.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								vendor/github.com/heketi/heketi/pkg/utils/stringstack.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,40 @@
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2015 The heketi Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
//
 | 
			
		||||
 | 
			
		||||
package utils
 | 
			
		||||
 | 
			
		||||
type StringStack struct {
 | 
			
		||||
	list []string
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func NewStringStack() *StringStack {
 | 
			
		||||
	a := &StringStack{}
 | 
			
		||||
	a.list = make([]string, 0)
 | 
			
		||||
	return a
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (a *StringStack) IsEmpty() bool {
 | 
			
		||||
	return len(a.list) == 0
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (a *StringStack) Pop() (x string) {
 | 
			
		||||
	x, a.list = a.list[0], a.list[1:len(a.list)]
 | 
			
		||||
	return
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (a *StringStack) Push(x string) {
 | 
			
		||||
	a.list = append(a.list, x)
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										34
									
								
								vendor/github.com/heketi/heketi/pkg/utils/uuid.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								vendor/github.com/heketi/heketi/pkg/utils/uuid.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,34 @@
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2015 The heketi Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
 | 
			
		||||
package utils
 | 
			
		||||
 | 
			
		||||
// From http://www.ashishbanerjee.com/home/go/go-generate-uuid
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"crypto/rand"
 | 
			
		||||
	"encoding/hex"
 | 
			
		||||
	"github.com/lpabon/godbc"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// Return a 16-byte uuid
 | 
			
		||||
func GenUUID() string {
 | 
			
		||||
	uuid := make([]byte, 16)
 | 
			
		||||
	n, err := rand.Read(uuid)
 | 
			
		||||
	godbc.Check(n == len(uuid), n, len(uuid))
 | 
			
		||||
	godbc.Check(err == nil, err)
 | 
			
		||||
 | 
			
		||||
	return hex.EncodeToString(uuid)
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										23
									
								
								vendor/github.com/lpabon/godbc/.gitignore
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								vendor/github.com/lpabon/godbc/.gitignore
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,23 @@
 | 
			
		||||
# Compiled Object files, Static and Dynamic libs (Shared Objects)
 | 
			
		||||
*.o
 | 
			
		||||
*.a
 | 
			
		||||
*.so
 | 
			
		||||
 | 
			
		||||
# Folders
 | 
			
		||||
_obj
 | 
			
		||||
_test
 | 
			
		||||
 | 
			
		||||
# Architecture specific extensions/prefixes
 | 
			
		||||
*.[568vq]
 | 
			
		||||
[568vq].out
 | 
			
		||||
 | 
			
		||||
*.cgo1.go
 | 
			
		||||
*.cgo2.c
 | 
			
		||||
_cgo_defun.c
 | 
			
		||||
_cgo_gotypes.go
 | 
			
		||||
_cgo_export.*
 | 
			
		||||
 | 
			
		||||
_testmain.go
 | 
			
		||||
 | 
			
		||||
*.exe
 | 
			
		||||
*.test
 | 
			
		||||
							
								
								
									
										13
									
								
								vendor/github.com/lpabon/godbc/.travis.yml
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								vendor/github.com/lpabon/godbc/.travis.yml
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,13 @@
 | 
			
		||||
language: go
 | 
			
		||||
 | 
			
		||||
go:
 | 
			
		||||
    - 1.1
 | 
			
		||||
    - 1.2
 | 
			
		||||
    - tip
 | 
			
		||||
 | 
			
		||||
install:
 | 
			
		||||
    - go get github.com/stretchr/testify
 | 
			
		||||
 | 
			
		||||
script:
 | 
			
		||||
    - go test
 | 
			
		||||
    - go test -tags 'prod'
 | 
			
		||||
							
								
								
									
										1
									
								
								vendor/github.com/lpabon/godbc/AUTHORS
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								vendor/github.com/lpabon/godbc/AUTHORS
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1 @@
 | 
			
		||||
lpabon@redhat.com
 | 
			
		||||
							
								
								
									
										201
									
								
								vendor/github.com/lpabon/godbc/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										201
									
								
								vendor/github.com/lpabon/godbc/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,201 @@
 | 
			
		||||
Apache License
 | 
			
		||||
                           Version 2.0, January 2004
 | 
			
		||||
                        http://www.apache.org/licenses/
 | 
			
		||||
 | 
			
		||||
   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
 | 
			
		||||
 | 
			
		||||
   1. Definitions.
 | 
			
		||||
 | 
			
		||||
      "License" shall mean the terms and conditions for use, reproduction,
 | 
			
		||||
      and distribution as defined by Sections 1 through 9 of this document.
 | 
			
		||||
 | 
			
		||||
      "Licensor" shall mean the copyright owner or entity authorized by
 | 
			
		||||
      the copyright owner that is granting the License.
 | 
			
		||||
 | 
			
		||||
      "Legal Entity" shall mean the union of the acting entity and all
 | 
			
		||||
      other entities that control, are controlled by, or are under common
 | 
			
		||||
      control with that entity. For the purposes of this definition,
 | 
			
		||||
      "control" means (i) the power, direct or indirect, to cause the
 | 
			
		||||
      direction or management of such entity, whether by contract or
 | 
			
		||||
      otherwise, or (ii) ownership of fifty percent (50%) or more of the
 | 
			
		||||
      outstanding shares, or (iii) beneficial ownership of such entity.
 | 
			
		||||
 | 
			
		||||
      "You" (or "Your") shall mean an individual or Legal Entity
 | 
			
		||||
      exercising permissions granted by this License.
 | 
			
		||||
 | 
			
		||||
      "Source" form shall mean the preferred form for making modifications,
 | 
			
		||||
      including but not limited to software source code, documentation
 | 
			
		||||
      source, and configuration files.
 | 
			
		||||
 | 
			
		||||
      "Object" form shall mean any form resulting from mechanical
 | 
			
		||||
      transformation or translation of a Source form, including but
 | 
			
		||||
      not limited to compiled object code, generated documentation,
 | 
			
		||||
      and conversions to other media types.
 | 
			
		||||
 | 
			
		||||
      "Work" shall mean the work of authorship, whether in Source or
 | 
			
		||||
      Object form, made available under the License, as indicated by a
 | 
			
		||||
      copyright notice that is included in or attached to the work
 | 
			
		||||
      (an example is provided in the Appendix below).
 | 
			
		||||
 | 
			
		||||
      "Derivative Works" shall mean any work, whether in Source or Object
 | 
			
		||||
      form, that is based on (or derived from) the Work and for which the
 | 
			
		||||
      editorial revisions, annotations, elaborations, or other modifications
 | 
			
		||||
      represent, as a whole, an original work of authorship. For the purposes
 | 
			
		||||
      of this License, Derivative Works shall not include works that remain
 | 
			
		||||
      separable from, or merely link (or bind by name) to the interfaces of,
 | 
			
		||||
      the Work and Derivative Works thereof.
 | 
			
		||||
 | 
			
		||||
      "Contribution" shall mean any work of authorship, including
 | 
			
		||||
      the original version of the Work and any modifications or additions
 | 
			
		||||
      to that Work or Derivative Works thereof, that is intentionally
 | 
			
		||||
      submitted to Licensor for inclusion in the Work by the copyright owner
 | 
			
		||||
      or by an individual or Legal Entity authorized to submit on behalf of
 | 
			
		||||
      the copyright owner. For the purposes of this definition, "submitted"
 | 
			
		||||
      means any form of electronic, verbal, or written communication sent
 | 
			
		||||
      to the Licensor or its representatives, including but not limited to
 | 
			
		||||
      communication on electronic mailing lists, source code control systems,
 | 
			
		||||
      and issue tracking systems that are managed by, or on behalf of, the
 | 
			
		||||
      Licensor for the purpose of discussing and improving the Work, but
 | 
			
		||||
      excluding communication that is conspicuously marked or otherwise
 | 
			
		||||
      designated in writing by the copyright owner as "Not a Contribution."
 | 
			
		||||
 | 
			
		||||
      "Contributor" shall mean Licensor and any individual or Legal Entity
 | 
			
		||||
      on behalf of whom a Contribution has been received by Licensor and
 | 
			
		||||
      subsequently incorporated within the Work.
 | 
			
		||||
 | 
			
		||||
   2. Grant of Copyright License. Subject to the terms and conditions of
 | 
			
		||||
      this License, each Contributor hereby grants to You a perpetual,
 | 
			
		||||
      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
 | 
			
		||||
      copyright license to reproduce, prepare Derivative Works of,
 | 
			
		||||
      publicly display, publicly perform, sublicense, and distribute the
 | 
			
		||||
      Work and such Derivative Works in Source or Object form.
 | 
			
		||||
 | 
			
		||||
   3. Grant of Patent License. Subject to the terms and conditions of
 | 
			
		||||
      this License, each Contributor hereby grants to You a perpetual,
 | 
			
		||||
      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
 | 
			
		||||
      (except as stated in this section) patent license to make, have made,
 | 
			
		||||
      use, offer to sell, sell, import, and otherwise transfer the Work,
 | 
			
		||||
      where such license applies only to those patent claims licensable
 | 
			
		||||
      by such Contributor that are necessarily infringed by their
 | 
			
		||||
      Contribution(s) alone or by combination of their Contribution(s)
 | 
			
		||||
      with the Work to which such Contribution(s) was submitted. If You
 | 
			
		||||
      institute patent litigation against any entity (including a
 | 
			
		||||
      cross-claim or counterclaim in a lawsuit) alleging that the Work
 | 
			
		||||
      or a Contribution incorporated within the Work constitutes direct
 | 
			
		||||
      or contributory patent infringement, then any patent licenses
 | 
			
		||||
      granted to You under this License for that Work shall terminate
 | 
			
		||||
      as of the date such litigation is filed.
 | 
			
		||||
 | 
			
		||||
   4. Redistribution. You may reproduce and distribute copies of the
 | 
			
		||||
      Work or Derivative Works thereof in any medium, with or without
 | 
			
		||||
      modifications, and in Source or Object form, provided that You
 | 
			
		||||
      meet the following conditions:
 | 
			
		||||
 | 
			
		||||
      (a) You must give any other recipients of the Work or
 | 
			
		||||
          Derivative Works a copy of this License; and
 | 
			
		||||
 | 
			
		||||
      (b) You must cause any modified files to carry prominent notices
 | 
			
		||||
          stating that You changed the files; and
 | 
			
		||||
 | 
			
		||||
      (c) You must retain, in the Source form of any Derivative Works
 | 
			
		||||
          that You distribute, all copyright, patent, trademark, and
 | 
			
		||||
          attribution notices from the Source form of the Work,
 | 
			
		||||
          excluding those notices that do not pertain to any part of
 | 
			
		||||
          the Derivative Works; and
 | 
			
		||||
 | 
			
		||||
      (d) If the Work includes a "NOTICE" text file as part of its
 | 
			
		||||
          distribution, then any Derivative Works that You distribute must
 | 
			
		||||
          include a readable copy of the attribution notices contained
 | 
			
		||||
          within such NOTICE file, excluding those notices that do not
 | 
			
		||||
          pertain to any part of the Derivative Works, in at least one
 | 
			
		||||
          of the following places: within a NOTICE text file distributed
 | 
			
		||||
          as part of the Derivative Works; within the Source form or
 | 
			
		||||
          documentation, if provided along with the Derivative Works; or,
 | 
			
		||||
          within a display generated by the Derivative Works, if and
 | 
			
		||||
          wherever such third-party notices normally appear. The contents
 | 
			
		||||
          of the NOTICE file are for informational purposes only and
 | 
			
		||||
          do not modify the License. You may add Your own attribution
 | 
			
		||||
          notices within Derivative Works that You distribute, alongside
 | 
			
		||||
          or as an addendum to the NOTICE text from the Work, provided
 | 
			
		||||
          that such additional attribution notices cannot be construed
 | 
			
		||||
          as modifying the License.
 | 
			
		||||
 | 
			
		||||
      You may add Your own copyright statement to Your modifications and
 | 
			
		||||
      may provide additional or different license terms and conditions
 | 
			
		||||
      for use, reproduction, or distribution of Your modifications, or
 | 
			
		||||
      for any such Derivative Works as a whole, provided Your use,
 | 
			
		||||
      reproduction, and distribution of the Work otherwise complies with
 | 
			
		||||
      the conditions stated in this License.
 | 
			
		||||
 | 
			
		||||
   5. Submission of Contributions. Unless You explicitly state otherwise,
 | 
			
		||||
      any Contribution intentionally submitted for inclusion in the Work
 | 
			
		||||
      by You to the Licensor shall be under the terms and conditions of
 | 
			
		||||
      this License, without any additional terms or conditions.
 | 
			
		||||
      Notwithstanding the above, nothing herein shall supersede or modify
 | 
			
		||||
      the terms of any separate license agreement you may have executed
 | 
			
		||||
      with Licensor regarding such Contributions.
 | 
			
		||||
 | 
			
		||||
   6. Trademarks. This License does not grant permission to use the trade
 | 
			
		||||
      names, trademarks, service marks, or product names of the Licensor,
 | 
			
		||||
      except as required for reasonable and customary use in describing the
 | 
			
		||||
      origin of the Work and reproducing the content of the NOTICE file.
 | 
			
		||||
 | 
			
		||||
   7. Disclaimer of Warranty. Unless required by applicable law or
 | 
			
		||||
      agreed to in writing, Licensor provides the Work (and each
 | 
			
		||||
      Contributor provides its Contributions) on an "AS IS" BASIS,
 | 
			
		||||
      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
 | 
			
		||||
      implied, including, without limitation, any warranties or conditions
 | 
			
		||||
      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
 | 
			
		||||
      PARTICULAR PURPOSE. You are solely responsible for determining the
 | 
			
		||||
      appropriateness of using or redistributing the Work and assume any
 | 
			
		||||
      risks associated with Your exercise of permissions under this License.
 | 
			
		||||
 | 
			
		||||
   8. Limitation of Liability. In no event and under no legal theory,
 | 
			
		||||
      whether in tort (including negligence), contract, or otherwise,
 | 
			
		||||
      unless required by applicable law (such as deliberate and grossly
 | 
			
		||||
      negligent acts) or agreed to in writing, shall any Contributor be
 | 
			
		||||
      liable to You for damages, including any direct, indirect, special,
 | 
			
		||||
      incidental, or consequential damages of any character arising as a
 | 
			
		||||
      result of this License or out of the use or inability to use the
 | 
			
		||||
      Work (including but not limited to damages for loss of goodwill,
 | 
			
		||||
      work stoppage, computer failure or malfunction, or any and all
 | 
			
		||||
      other commercial damages or losses), even if such Contributor
 | 
			
		||||
      has been advised of the possibility of such damages.
 | 
			
		||||
 | 
			
		||||
   9. Accepting Warranty or Additional Liability. While redistributing
 | 
			
		||||
      the Work or Derivative Works thereof, You may choose to offer,
 | 
			
		||||
      and charge a fee for, acceptance of support, warranty, indemnity,
 | 
			
		||||
      or other liability obligations and/or rights consistent with this
 | 
			
		||||
      License. However, in accepting such obligations, You may act only
 | 
			
		||||
      on Your own behalf and on Your sole responsibility, not on behalf
 | 
			
		||||
      of any other Contributor, and only if You agree to indemnify,
 | 
			
		||||
      defend, and hold each Contributor harmless for any liability
 | 
			
		||||
      incurred by, or claims asserted against, such Contributor by reason
 | 
			
		||||
      of your accepting any such warranty or additional liability.
 | 
			
		||||
 | 
			
		||||
   END OF TERMS AND CONDITIONS
 | 
			
		||||
 | 
			
		||||
   APPENDIX: How to apply the Apache License to your work.
 | 
			
		||||
 | 
			
		||||
      To apply the Apache License to your work, attach the following
 | 
			
		||||
      boilerplate notice, with the fields enclosed by brackets "{}"
 | 
			
		||||
      replaced with your own identifying information. (Don't include
 | 
			
		||||
      the brackets!)  The text should be enclosed in the appropriate
 | 
			
		||||
      comment syntax for the file format. We also recommend that a
 | 
			
		||||
      file or class name and description of purpose be included on the
 | 
			
		||||
      same "printed page" as the copyright notice for easier
 | 
			
		||||
      identification within third-party archives.
 | 
			
		||||
 | 
			
		||||
   Copyright {yyyy} {name of copyright owner}
 | 
			
		||||
 | 
			
		||||
   Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
   you may not use this file except in compliance with the License.
 | 
			
		||||
   You may obtain a copy of the License at
 | 
			
		||||
 | 
			
		||||
       http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 | 
			
		||||
   Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
   distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
   See the License for the specific language governing permissions and
 | 
			
		||||
   limitations under the License.
 | 
			
		||||
							
								
								
									
										21
									
								
								vendor/github.com/lpabon/godbc/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								vendor/github.com/lpabon/godbc/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,21 @@
 | 
			
		||||
[](https://travis-ci.org/lpabon/godbc)
 | 
			
		||||
 | 
			
		||||
# godbc
 | 
			
		||||
 | 
			
		||||
Design by contract for Go
 | 
			
		||||
 | 
			
		||||
# Installation
 | 
			
		||||
 | 
			
		||||
To install godbc, use `go get`:
 | 
			
		||||
 | 
			
		||||
    go get github.com/lpabon/godbc
 | 
			
		||||
 | 
			
		||||
Import the `godbc` package into your code using this template:
 | 
			
		||||
 | 
			
		||||
    import (
 | 
			
		||||
      "github.com/lpabon/godbc"
 | 
			
		||||
    )
 | 
			
		||||
 | 
			
		||||
# Documentation
 | 
			
		||||
 | 
			
		||||
Documentation is available at https://godoc.org/github.com/lpabon/godbc
 | 
			
		||||
							
								
								
									
										146
									
								
								vendor/github.com/lpabon/godbc/godbc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										146
									
								
								vendor/github.com/lpabon/godbc/godbc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,146 @@
 | 
			
		||||
//+build !prod
 | 
			
		||||
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2014 The godbc Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
 | 
			
		||||
// Design-by-Contract for Go
 | 
			
		||||
//
 | 
			
		||||
// Design by Contract is a programming methodology
 | 
			
		||||
// which binds the caller and the function called to a
 | 
			
		||||
// contract. The contract is represented using Hoare Triple:
 | 
			
		||||
//      {P} C {Q}
 | 
			
		||||
// where {P} is the precondition before executing command C,
 | 
			
		||||
// and {Q} is the postcondition.
 | 
			
		||||
//
 | 
			
		||||
// See Also
 | 
			
		||||
//
 | 
			
		||||
// * http://en.wikipedia.org/wiki/Design_by_contract
 | 
			
		||||
// * http://en.wikipedia.org/wiki/Hoare_logic
 | 
			
		||||
// * http://dlang.org/dbc.html
 | 
			
		||||
//
 | 
			
		||||
// Usage
 | 
			
		||||
//
 | 
			
		||||
// Godbc is enabled by default, but can be disabled for production
 | 
			
		||||
// builds by using the tag 'prod' in builds and tests as follows:
 | 
			
		||||
//		go build -tags 'prod'
 | 
			
		||||
// or
 | 
			
		||||
// 		go test -tags 'prod'
 | 
			
		||||
//
 | 
			
		||||
package godbc
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"errors"
 | 
			
		||||
	"fmt"
 | 
			
		||||
	"runtime"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// InvariantSimpleTester is an interface which provides a receiver to
 | 
			
		||||
// test the object
 | 
			
		||||
type InvariantSimpleTester interface {
 | 
			
		||||
	Invariant() bool
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// InvariantTester is an interface which provides not only an Invariant(),
 | 
			
		||||
// but also a receiver to print the structure
 | 
			
		||||
type InvariantTester interface {
 | 
			
		||||
	InvariantSimpleTester
 | 
			
		||||
	String() string
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// dbc_panic prints to the screen information of the failure followed
 | 
			
		||||
// by a call to panic()
 | 
			
		||||
func dbc_panic(dbc_func_name string, b bool, message ...interface{}) {
 | 
			
		||||
	if !b {
 | 
			
		||||
 | 
			
		||||
		// Get caller information which is the caller
 | 
			
		||||
		// of the caller of this function
 | 
			
		||||
		pc, file, line, _ := runtime.Caller(2)
 | 
			
		||||
		caller_func_info := runtime.FuncForPC(pc)
 | 
			
		||||
 | 
			
		||||
		error_string := fmt.Sprintf("%s:\n\r\tfunc (%s) 0x%x\n\r\tFile %s:%d",
 | 
			
		||||
			dbc_func_name,
 | 
			
		||||
			caller_func_info.Name(),
 | 
			
		||||
			pc,
 | 
			
		||||
			file,
 | 
			
		||||
			line)
 | 
			
		||||
 | 
			
		||||
		if len(message) > 0 {
 | 
			
		||||
			error_string += fmt.Sprintf("\n\r\tInfo: %+v", message)
 | 
			
		||||
		}
 | 
			
		||||
		err := errors.New(error_string)
 | 
			
		||||
 | 
			
		||||
		// Finally panic
 | 
			
		||||
		panic(err)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Require checks that the preconditions are satisfied before
 | 
			
		||||
// executing the function
 | 
			
		||||
//
 | 
			
		||||
// Example Code
 | 
			
		||||
//
 | 
			
		||||
// 		func Divide(a, b int) int {
 | 
			
		||||
//			godbc.Require(b != 0)
 | 
			
		||||
//			return a/b
 | 
			
		||||
// 		}
 | 
			
		||||
//
 | 
			
		||||
func Require(b bool, message ...interface{}) {
 | 
			
		||||
	dbc_panic("REQUIRE", b, message...)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Ensure checks the postconditions are satisfied before returning
 | 
			
		||||
// to the caller.
 | 
			
		||||
//
 | 
			
		||||
// Example Code
 | 
			
		||||
//
 | 
			
		||||
//		type Data struct {
 | 
			
		||||
//			a int
 | 
			
		||||
//		}
 | 
			
		||||
//
 | 
			
		||||
// 		func (*d Data) Set(a int) {
 | 
			
		||||
//			d.a = a
 | 
			
		||||
//			godbc.Ensure(d.a == a)
 | 
			
		||||
// 		}
 | 
			
		||||
//
 | 
			
		||||
func Ensure(b bool, message ...interface{}) {
 | 
			
		||||
	dbc_panic("ENSURE", b, message...)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Check provides a simple assert
 | 
			
		||||
func Check(b bool, message ...interface{}) {
 | 
			
		||||
	dbc_panic("CHECK", b, message...)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// InvariantSimple calls the objects Invariant() receiver to test
 | 
			
		||||
// the object for correctness.
 | 
			
		||||
//
 | 
			
		||||
// The caller object must provide an object that supports the
 | 
			
		||||
// interface InvariantSimpleTester and does not need to provide
 | 
			
		||||
// a String() receiver
 | 
			
		||||
func InvariantSimple(obj InvariantSimpleTester, message ...interface{}) {
 | 
			
		||||
	dbc_panic("INVARIANT", obj.Invariant(), message...)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Invariant calls the objects Invariant() receiver to test
 | 
			
		||||
// the object for correctness.
 | 
			
		||||
//
 | 
			
		||||
// The caller object must provide an object that supports the
 | 
			
		||||
// interface InvariantTester
 | 
			
		||||
//
 | 
			
		||||
// To see an example, please take a look at the godbc_test.go
 | 
			
		||||
func Invariant(obj InvariantTester, message ...interface{}) {
 | 
			
		||||
	m := append(message, obj)
 | 
			
		||||
	dbc_panic("INVARIANT", obj.Invariant(), m)
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										42
									
								
								vendor/github.com/lpabon/godbc/godbc_prod.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								vendor/github.com/lpabon/godbc/godbc_prod.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,42 @@
 | 
			
		||||
//+build prod
 | 
			
		||||
 | 
			
		||||
//
 | 
			
		||||
// Copyright (c) 2014 The godbc Authors
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
 | 
			
		||||
package godbc
 | 
			
		||||
 | 
			
		||||
type InvariantSimpleTester interface {
 | 
			
		||||
	Invariant() bool
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type InvariantTester interface {
 | 
			
		||||
	InvariantSimpleTester
 | 
			
		||||
	String() string
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func Require(b bool, message ...interface{}) {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func Ensure(b bool, message ...interface{}) {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func Check(b bool, message ...interface{}) {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func InvariantSimple(obj InvariantSimpleTester, message ...interface{}) {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func Invariant(obj InvariantTester, message ...interface{}) {
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user