google-cloud-gemserver 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 1c8bda7c5d0a26bc56b99d81b60ab98e87fc2977
4
+ data.tar.gz: 91cef6024bb375426a28ffe59f4c389d655ca382
5
+ SHA512:
6
+ metadata.gz: d647ffd4d5611143907984ba56016e3ae53edf4c30412ebb5feb804f4c9caedef32b8c0968c4e8544a1b060bcb787b150f1f509551d2a316276be070eccccd34
7
+ data.tar.gz: 223baeb4f3bce4ff4d73917c2a6afd890a32d02ed286008234202d55a01c76d9951853bf00ae6d5ab8945f5a5ca76492359ba39ee0511ad348a3aedf1f608da0
@@ -0,0 +1,7 @@
1
+ --no-private
2
+ --title=Google Cloud Gemserver
3
+ --markup markdown
4
+
5
+ ./lib/**/*.rb
6
+
7
+ README.md
@@ -0,0 +1,49 @@
1
+ # How to Contribute
2
+
3
+ We'd love to accept your patches and contributions to this project. There are
4
+ just a few small guidelines you need to follow.
5
+
6
+ ## Contributor License Agreement
7
+
8
+ Contributions to this project must be accompanied by a Contributor License
9
+ Agreement. You (or your employer) retain the copyright to your contribution,
10
+ this simply gives us permission to use and redistribute your contributions as
11
+ part of the project. Head over to <https://cla.developers.google.com/> to see
12
+ your current agreements on file or to sign a new one.
13
+
14
+ You generally only need to submit a CLA once, so if you've already submitted one
15
+ (even if it was for a different project), you probably don't need to do it
16
+ again.
17
+
18
+ ## Development
19
+
20
+ After checking out the repo, run `bin/setup` to install dependencies. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
21
+
22
+ To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).
23
+
24
+ ### Running tests
25
+
26
+ Note: you will need gemstash installed from
27
+ [source](https://github.com/bundler/gemstash) to run acceptance and integration
28
+ tests.
29
+
30
+ 1) Edit your app.yaml to use a separate database to run tests on otherwise
31
+ your existing private gems can get deleted.
32
+ 2) Generate a test-key with both read/write permissions (my-test-key).
33
+ 3) To run unit tests:
34
+ `bundle exec rake test`
35
+ 3) To run acceptance and performance tests:
36
+ Ensure cloud_sql_proxy is running and connected to the CloudSQL instance of
37
+ your testing gemserver (dev prefix) in app.yaml.
38
+ `bundle exec rake test host=test-gemserver-url.com key=my-test-key`
39
+ 4) To run integration tests:
40
+ Ensure cloud_sql_proxy is running and connected to the CloudSQL instance of
41
+ your testing gemserver (dev prefix) in app.yaml.
42
+ `bundle exec rake integration host=test-gemserver-url.com key=my-test-key`
43
+
44
+ ### Travis PR Builds
45
+
46
+ By default, unit tests will always run for every update to a PR. Acceptance and
47
+ integration tests will run after a PR is merged. If tests break, please submit a
48
+ separate PR to fix the issues.
49
+
data/LICENSE ADDED
@@ -0,0 +1,202 @@
1
+
2
+ Apache License
3
+ Version 2.0, January 2004
4
+ http://www.apache.org/licenses/
5
+
6
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
7
+
8
+ 1. Definitions.
9
+
10
+ "License" shall mean the terms and conditions for use, reproduction,
11
+ and distribution as defined by Sections 1 through 9 of this document.
12
+
13
+ "Licensor" shall mean the copyright owner or entity authorized by
14
+ the copyright owner that is granting the License.
15
+
16
+ "Legal Entity" shall mean the union of the acting entity and all
17
+ other entities that control, are controlled by, or are under common
18
+ control with that entity. For the purposes of this definition,
19
+ "control" means (i) the power, direct or indirect, to cause the
20
+ direction or management of such entity, whether by contract or
21
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
22
+ outstanding shares, or (iii) beneficial ownership of such entity.
23
+
24
+ "You" (or "Your") shall mean an individual or Legal Entity
25
+ exercising permissions granted by this License.
26
+
27
+ "Source" form shall mean the preferred form for making modifications,
28
+ including but not limited to software source code, documentation
29
+ source, and configuration files.
30
+
31
+ "Object" form shall mean any form resulting from mechanical
32
+ transformation or translation of a Source form, including but
33
+ not limited to compiled object code, generated documentation,
34
+ and conversions to other media types.
35
+
36
+ "Work" shall mean the work of authorship, whether in Source or
37
+ Object form, made available under the License, as indicated by a
38
+ copyright notice that is included in or attached to the work
39
+ (an example is provided in the Appendix below).
40
+
41
+ "Derivative Works" shall mean any work, whether in Source or Object
42
+ form, that is based on (or derived from) the Work and for which the
43
+ editorial revisions, annotations, elaborations, or other modifications
44
+ represent, as a whole, an original work of authorship. For the purposes
45
+ of this License, Derivative Works shall not include works that remain
46
+ separable from, or merely link (or bind by name) to the interfaces of,
47
+ the Work and Derivative Works thereof.
48
+
49
+ "Contribution" shall mean any work of authorship, including
50
+ the original version of the Work and any modifications or additions
51
+ to that Work or Derivative Works thereof, that is intentionally
52
+ submitted to Licensor for inclusion in the Work by the copyright owner
53
+ or by an individual or Legal Entity authorized to submit on behalf of
54
+ the copyright owner. For the purposes of this definition, "submitted"
55
+ means any form of electronic, verbal, or written communication sent
56
+ to the Licensor or its representatives, including but not limited to
57
+ communication on electronic mailing lists, source code control systems,
58
+ and issue tracking systems that are managed by, or on behalf of, the
59
+ Licensor for the purpose of discussing and improving the Work, but
60
+ excluding communication that is conspicuously marked or otherwise
61
+ designated in writing by the copyright owner as "Not a Contribution."
62
+
63
+ "Contributor" shall mean Licensor and any individual or Legal Entity
64
+ on behalf of whom a Contribution has been received by Licensor and
65
+ subsequently incorporated within the Work.
66
+
67
+ 2. Grant of Copyright License. Subject to the terms and conditions of
68
+ this License, each Contributor hereby grants to You a perpetual,
69
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
70
+ copyright license to reproduce, prepare Derivative Works of,
71
+ publicly display, publicly perform, sublicense, and distribute the
72
+ Work and such Derivative Works in Source or Object form.
73
+
74
+ 3. Grant of Patent License. Subject to the terms and conditions of
75
+ this License, each Contributor hereby grants to You a perpetual,
76
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
77
+ (except as stated in this section) patent license to make, have made,
78
+ use, offer to sell, sell, import, and otherwise transfer the Work,
79
+ where such license applies only to those patent claims licensable
80
+ by such Contributor that are necessarily infringed by their
81
+ Contribution(s) alone or by combination of their Contribution(s)
82
+ with the Work to which such Contribution(s) was submitted. If You
83
+ institute patent litigation against any entity (including a
84
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
85
+ or a Contribution incorporated within the Work constitutes direct
86
+ or contributory patent infringement, then any patent licenses
87
+ granted to You under this License for that Work shall terminate
88
+ as of the date such litigation is filed.
89
+
90
+ 4. Redistribution. You may reproduce and distribute copies of the
91
+ Work or Derivative Works thereof in any medium, with or without
92
+ modifications, and in Source or Object form, provided that You
93
+ meet the following conditions:
94
+
95
+ (a) You must give any other recipients of the Work or
96
+ Derivative Works a copy of this License; and
97
+
98
+ (b) You must cause any modified files to carry prominent notices
99
+ stating that You changed the files; and
100
+
101
+ (c) You must retain, in the Source form of any Derivative Works
102
+ that You distribute, all copyright, patent, trademark, and
103
+ attribution notices from the Source form of the Work,
104
+ excluding those notices that do not pertain to any part of
105
+ the Derivative Works; and
106
+
107
+ (d) If the Work includes a "NOTICE" text file as part of its
108
+ distribution, then any Derivative Works that You distribute must
109
+ include a readable copy of the attribution notices contained
110
+ within such NOTICE file, excluding those notices that do not
111
+ pertain to any part of the Derivative Works, in at least one
112
+ of the following places: within a NOTICE text file distributed
113
+ as part of the Derivative Works; within the Source form or
114
+ documentation, if provided along with the Derivative Works; or,
115
+ within a display generated by the Derivative Works, if and
116
+ wherever such third-party notices normally appear. The contents
117
+ of the NOTICE file are for informational purposes only and
118
+ do not modify the License. You may add Your own attribution
119
+ notices within Derivative Works that You distribute, alongside
120
+ or as an addendum to the NOTICE text from the Work, provided
121
+ that such additional attribution notices cannot be construed
122
+ as modifying the License.
123
+
124
+ You may add Your own copyright statement to Your modifications and
125
+ may provide additional or different license terms and conditions
126
+ for use, reproduction, or distribution of Your modifications, or
127
+ for any such Derivative Works as a whole, provided Your use,
128
+ reproduction, and distribution of the Work otherwise complies with
129
+ the conditions stated in this License.
130
+
131
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
132
+ any Contribution intentionally submitted for inclusion in the Work
133
+ by You to the Licensor shall be under the terms and conditions of
134
+ this License, without any additional terms or conditions.
135
+ Notwithstanding the above, nothing herein shall supersede or modify
136
+ the terms of any separate license agreement you may have executed
137
+ with Licensor regarding such Contributions.
138
+
139
+ 6. Trademarks. This License does not grant permission to use the trade
140
+ names, trademarks, service marks, or product names of the Licensor,
141
+ except as required for reasonable and customary use in describing the
142
+ origin of the Work and reproducing the content of the NOTICE file.
143
+
144
+ 7. Disclaimer of Warranty. Unless required by applicable law or
145
+ agreed to in writing, Licensor provides the Work (and each
146
+ Contributor provides its Contributions) on an "AS IS" BASIS,
147
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
148
+ implied, including, without limitation, any warranties or conditions
149
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
150
+ PARTICULAR PURPOSE. You are solely responsible for determining the
151
+ appropriateness of using or redistributing the Work and assume any
152
+ risks associated with Your exercise of permissions under this License.
153
+
154
+ 8. Limitation of Liability. In no event and under no legal theory,
155
+ whether in tort (including negligence), contract, or otherwise,
156
+ unless required by applicable law (such as deliberate and grossly
157
+ negligent acts) or agreed to in writing, shall any Contributor be
158
+ liable to You for damages, including any direct, indirect, special,
159
+ incidental, or consequential damages of any character arising as a
160
+ result of this License or out of the use or inability to use the
161
+ Work (including but not limited to damages for loss of goodwill,
162
+ work stoppage, computer failure or malfunction, or any and all
163
+ other commercial damages or losses), even if such Contributor
164
+ has been advised of the possibility of such damages.
165
+
166
+ 9. Accepting Warranty or Additional Liability. While redistributing
167
+ the Work or Derivative Works thereof, You may choose to offer,
168
+ and charge a fee for, acceptance of support, warranty, indemnity,
169
+ or other liability obligations and/or rights consistent with this
170
+ License. However, in accepting such obligations, You may act only
171
+ on Your own behalf and on Your sole responsibility, not on behalf
172
+ of any other Contributor, and only if You agree to indemnify,
173
+ defend, and hold each Contributor harmless for any liability
174
+ incurred by, or claims asserted against, such Contributor by reason
175
+ of your accepting any such warranty or additional liability.
176
+
177
+ END OF TERMS AND CONDITIONS
178
+
179
+ APPENDIX: How to apply the Apache License to your work.
180
+
181
+ To apply the Apache License to your work, attach the following
182
+ boilerplate notice, with the fields enclosed by brackets "[]"
183
+ replaced with your own identifying information. (Don't include
184
+ the brackets!) The text should be enclosed in the appropriate
185
+ comment syntax for the file format. We also recommend that a
186
+ file or class name and description of purpose be included on the
187
+ same "printed page" as the copyright notice for easier
188
+ identification within third-party archives.
189
+
190
+ Copyright [yyyy] [name of copyright owner]
191
+
192
+ Licensed under the Apache License, Version 2.0 (the "License");
193
+ you may not use this file except in compliance with the License.
194
+ You may obtain a copy of the License at
195
+
196
+ http://www.apache.org/licenses/LICENSE-2.0
197
+
198
+ Unless required by applicable law or agreed to in writing, software
199
+ distributed under the License is distributed on an "AS IS" BASIS,
200
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
201
+ See the License for the specific language governing permissions and
202
+ limitations under the License.
@@ -0,0 +1,179 @@
1
+ # Google::Cloud::Gemserver
2
+
3
+ [![Build Status](https://travis-ci.org/GoogleCloudPlatform/google-cloud-gemserver.svg?branch=master)](https://travis-ci.org/GoogleCloudPlatform/google-cloud-ruby)
4
+
5
+ This gem is a tool that lets you manage, interact with, and deploy a [private gem
6
+ server](https://github.com/bundler/gemstash) to a Google Cloud Platform project.
7
+ The gemserver acts as a private gem repository for your gems similar
8
+ to how rubygems.org works with the exception that pushing and installing gems
9
+ are protected operations.
10
+
11
+ ## Installation
12
+
13
+ Add this line to your application's Gemfile:
14
+
15
+ ```ruby
16
+ gem 'google-cloud-gemserver'
17
+ ```
18
+
19
+ And then execute:
20
+
21
+ $ bundle
22
+
23
+ Or install it yourself as:
24
+
25
+ $ gem install google-cloud-gemserver
26
+
27
+ ## Usage
28
+
29
+ ### Basic Prerequisites
30
+ 1) Create a Google Cloud Platform (GCP) project.
31
+ 2) Install and setup the [gcloud SDK](https://cloud.google.com/sdk/downloads). Currently, versions 161+ are supported.
32
+ 3) Authenticate gcloud by using a [service account](https://cloud.google.com/docs/authentication/getting-started) or [application default credentials](https://developers.google.com/identity/protocols/application-default-credentials).
33
+ Using a service account is the recommended method for authentication; application default credentials should only be used for development purporses. Read this [authentication guide](docs/authentication.md) for more information.
34
+ 4) Running acceptance or performance tests requires you to have the Cloud SQL proxy running with your Cloud SQL instance. Visit this [link](https://cloud.google.com/sql/docs/mysql/connect-admin-proxy) to learn how to install and run it (steps 3 and 5 can be skipped).
35
+
36
+ ### Typical Workflow
37
+ 1) Deploy a gemserver by running: `google-cloud-gemserver create --use-proj YOUR_PROJECT_ID`. This deploys the gemserver in a Google App Engine project as the default service. It also creates a new Cloud SQL instance with machine type db-f1-micro. Note that this machine type is only recommended for development / testing and is not under the Cloud SQL SLA coverage.
38
+ 2) Generate a key (referred to as my-key) by running `google-cloud-gemserver create-key --use-proj YOUR_PROJECT_ID` for your gemserver. By default, this generates a key with both read and write permissions. For more information about keys, read [this](docs/key.md).
39
+ 3) Add this key to your bundle config by running `bundle config http://gemserver-url.com/private/ my-key` where gemserver-url is the same as your project's url, e.g. http://my-project.appspot.com/private/. This is necessary to download gems.
40
+ 4) Add this key to your gem credentials as my-key (in ~/.gem/credentials): `:my-key: [KEY]` This is necessary to push gems (if the key has write permission).
41
+ 5) Push private gems to the gemserver as described [below](#pushing-gems).
42
+ 6) Download private gems by modifying your Gemfile as described
43
+ [below](#fetching-gems).
44
+
45
+ ### Pushing gems
46
+ Note: ensure `my-key` has the read permission and is added in your gem
47
+ credentials file (~/.gem/credentials)
48
+ `gem push my-gem --key my-key --host http://my-gemserver.com/private/`
49
+
50
+ ### Fetching gems
51
+ Note: ensure `my-key` has the read permission and is set in your bundle
52
+ config by running `bundle config http://my-gemserver.com/private/ my-key`
53
+
54
+ 1) Add `source "http://my-gemserver.com"` to the top of your Gemfile
55
+ 2) Add the following to your Gemfile:
56
+ ```
57
+ source "http://my-gemserver.com/private" do
58
+ gem "my-private-gem1"
59
+ (other private gems here)
60
+ end
61
+ ```
62
+ 3) Run `bundle install`
63
+
64
+ ### Yanking gems
65
+ Note: ensure `my-key` has the write permission and is added in your gem
66
+ credentials file (~/.gem/credentials)
67
+ `gem push my-gem --key my-key --host http://my-gemserver.com/private/`
68
+
69
+ 1) Run `gem yank --key my-key [GEM_NAME] --host
70
+ http://my-gemserver.com/private`
71
+
72
+ Gems can not be "unyanked" so once a gem has been yanked it cannot be pushed
73
+ to the gemserver again with the same name and version. It can be pushed if the
74
+ version number is changed, however.
75
+
76
+
77
+ ### Gemserver commands
78
+ * `google-cloud-gemserver config`
79
+
80
+ Usage:
81
+ google-cloud-gemserver config
82
+
83
+ Displays the config the current deployed gemserver is using (if one is running)
84
+
85
+ * `google-cloud-gemserver create`
86
+
87
+ Usage:
88
+ google-cloud-gemserver create
89
+
90
+ Options:
91
+ * -g, [--use-proj=USE_PROJ] # Existing project to deploy gemserver to
92
+ * -i, [--use-inst=USE_INST] # Existing project to deploy gemserver to
93
+
94
+ Creates and deploys the gem server then starts it
95
+
96
+ * `google-cloud-gemserver create-key`
97
+
98
+ Usage:
99
+ google-cloud-gemserver create-key
100
+
101
+ Options:
102
+ * -r, [--remote=REMOTE] # The gemserver URL, i.e. gemserver.com
103
+ * -p, [--permissions=PERMISSIONS] # Options: write, read, both. Default is
104
+ both.
105
+ * -g, [--use-proj=USE_PROJ] # The GCP project the gemserver was
106
+ deployed to.
107
+
108
+ Creates an authentication key
109
+
110
+ * `google-cloud-gemserver delete-key`
111
+
112
+ Usage:
113
+ google-cloud-gemserver delete-key
114
+
115
+ Options:
116
+ * -r, [--remote=REMOTE] # The gemserver URL, i.e. gemserver.com
117
+ * -k, [--key=KEY] # The key to delete
118
+ * -g, [--use-proj=USE_PROJ] # The GCP project the gemserver was
119
+ deployed to.
120
+
121
+ Deletes a given key
122
+
123
+ * `google-cloud-gemserver delete`
124
+
125
+ Usage:
126
+ google-cloud-gemserver delete
127
+
128
+ Options:
129
+ * -g, [--use-proj=USE_PROJ] # Project id of GCP project the gemserver was deployed to. Warning: parent project and CloudSQL instance will also be deleted
130
+
131
+ Delete a given gemserver
132
+
133
+ * `google-cloud-gemserver start`
134
+
135
+ Usage:
136
+ google-cloud-gemserver start
137
+
138
+ Starts the gem server. This will be run automatically after a deploy.
139
+ Running this locally will start the gemserver locally
140
+
141
+ * `google-cloud-gemserver stats`
142
+
143
+ Usage:
144
+ google-cloud-gemserver stats
145
+
146
+ Options:
147
+ * -r, [--remote=REMOTE] # The gemserver URL, i.e. gemserver.com
148
+ * -g, [--use-proj=USE_PROJ] # The GCP project the gemserver was
149
+ deployed to.
150
+
151
+ Displays statistics on the given gemserver
152
+
153
+ * `google-cloud-gemserver update`
154
+
155
+ Usage:
156
+ google-cloud-gemserver update
157
+
158
+ Redeploys the gemserver with the current config file and google-cloud-gemserver gem version (a deploy must have succeeded for 'update' to work)
159
+
160
+ * `google-cloud-gemserver gen-config`
161
+
162
+ Usage:
163
+ google-cloud-gemserver gen-config
164
+
165
+ Generates configuration files with default values
166
+
167
+ * `google-cloud-gemserver help`
168
+
169
+ Usage:
170
+ google-cloud-gemserver help [COMMAND]
171
+
172
+ Describe available commands or one specific command
173
+
174
+ More documentation can be found in the docs [directory](docs/).
175
+
176
+ ## Contributing
177
+
178
+ Detailed information can be found in [CONTRIBUTING.md](CONTRIBUTING.md).
179
+
@@ -0,0 +1,7 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "google/cloud/gemserver"
5
+
6
+ require "irb"
7
+ IRB.start(__FILE__)