Install now with expanded symlinks for those platforms that don't support them.
This commit is contained in:
14
Makefile
14
Makefile
@@ -14,9 +14,11 @@ prerelease:
|
|||||||
python2.4 runtests.py tests --exit_on_failure
|
python2.4 runtests.py tests --exit_on_failure
|
||||||
python2.6 runtests.py tests --exit_on_failure
|
python2.6 runtests.py tests --exit_on_failure
|
||||||
python2.7 runtests.py tests --exit_on_failure
|
python2.7 runtests.py tests --exit_on_failure
|
||||||
-rm -rf dist/*
|
-sudo rm -rf dist/
|
||||||
python setup.py clean
|
-sudo rm -rf snapshot/
|
||||||
python setup.py sdist --formats=gztar,zip
|
python expand-symlinks.py
|
||||||
|
cd snapshot; python setup.py clean
|
||||||
|
cd snapshot; python setup.py sdist --formats=gztar,zip
|
||||||
|
|
||||||
.PHONY: release
|
.PHONY: release
|
||||||
release: prerelease
|
release: prerelease
|
||||||
@@ -24,7 +26,7 @@ release: prerelease
|
|||||||
@echo "Are you sure you want to proceed? (yes/no)"
|
@echo "Are you sure you want to proceed? (yes/no)"
|
||||||
@read yn; [ "yes" == $$yn ]
|
@read yn; [ "yes" == $$yn ]
|
||||||
@echo "Here we go..."
|
@echo "Here we go..."
|
||||||
python setup.py sdist --formats=gztar,zip register upload
|
cd snapshot; python setup.py sdist --formats=gztar,zip register upload
|
||||||
wget "http://support.googlecode.com/svn/trunk/scripts/googlecode_upload.py" -O googlecode_upload.py
|
wget "http://support.googlecode.com/svn/trunk/scripts/googlecode_upload.py" -O googlecode_upload.py
|
||||||
python googlecode_upload.py --summary="Version $(shell python setup.py --version)" --project=google-api-python-client dist/*.tar.gz
|
python googlecode_upload.py --summary="Version $(shell python setup.py --version)" --project=google-api-python-client snapshot/dist/*.tar.gz
|
||||||
python googlecode_upload.py --summary="Version $(shell python setup.py --version)" --project=google-api-python-client dist/*.zip
|
python googlecode_upload.py --summary="Version $(shell python setup.py --version)" --project=google-api-python-client snapshot/dist/*.zip
|
||||||
|
|||||||
26
bin/enable-app-engine-project
Normal file → Executable file
26
bin/enable-app-engine-project
Normal file → Executable file
@@ -16,9 +16,12 @@
|
|||||||
|
|
||||||
"""Copy the sources for google-api-python-client into an App Engine project.
|
"""Copy the sources for google-api-python-client into an App Engine project.
|
||||||
|
|
||||||
Copies, or symbolically links the sources of the google-api-python-client
|
Copies the sources of the google-api-python-client
|
||||||
library into a Google App Engine project. This is necessary so that the
|
library into a Google App Engine project. This is necessary so that the
|
||||||
source can be uploaded when the application is deployed.
|
source can be uploaded when the application is deployed.
|
||||||
|
|
||||||
|
$ enable-app-engine-project [flags] directory
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
__author__ = 'jcgregorio@google.com (Joe Gregorio)'
|
__author__ = 'jcgregorio@google.com (Joe Gregorio)'
|
||||||
@@ -53,6 +56,15 @@ gflags.DEFINE_boolean('force', 'False',
|
|||||||
gflags.DEFINE_boolean('dry_run', 'False', 'Don\'t actually do anything.')
|
gflags.DEFINE_boolean('dry_run', 'False', 'Don\'t actually do anything.')
|
||||||
|
|
||||||
def find_source(module):
|
def find_source(module):
|
||||||
|
"""Find the absolute path for the source of a module.
|
||||||
|
|
||||||
|
Args:
|
||||||
|
module: str, Name of the module.
|
||||||
|
Returns:
|
||||||
|
A tuple of (isdir, location), a boolean indicating if it
|
||||||
|
is a directory (True) or a single file module (False), and
|
||||||
|
the absolute path of the source.
|
||||||
|
"""
|
||||||
isdir = False
|
isdir = False
|
||||||
location = ''
|
location = ''
|
||||||
m = __import__(module)
|
m = __import__(module)
|
||||||
@@ -71,7 +83,11 @@ def main(argv):
|
|||||||
try:
|
try:
|
||||||
argv = FLAGS(argv)
|
argv = FLAGS(argv)
|
||||||
except gflags.FlagsError, e:
|
except gflags.FlagsError, e:
|
||||||
print '%s\\nUsage: %s ARGS\\n%s' % (e, argv[0], FLAGS)
|
print '%s\nUsage: %s ARGS\n%s' % (e, argv[0], FLAGS)
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
if len(argv) == 1:
|
||||||
|
print 'Usage: %s ARGS\n%s' % (argv[0], FLAGS)
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
# Set the logging according to the command-line flag
|
# Set the logging according to the command-line flag
|
||||||
@@ -82,7 +98,7 @@ def main(argv):
|
|||||||
# Check if the supplied directory is an App Engine project by looking
|
# Check if the supplied directory is an App Engine project by looking
|
||||||
# for an app.yaml
|
# for an app.yaml
|
||||||
if not os.path.isfile(os.path.join(dir, 'app.yaml')):
|
if not os.path.isfile(os.path.join(dir, 'app.yaml')):
|
||||||
sys.exit('The given directory is not a Google App Engine project: %s', dir)
|
sys.exit('The given directory is not a Google App Engine project: %s' % dir)
|
||||||
|
|
||||||
|
|
||||||
# Build up the set of file or directory copying actions we need to do
|
# Build up the set of file or directory copying actions we need to do
|
||||||
@@ -105,10 +121,10 @@ def main(argv):
|
|||||||
if isdir:
|
if isdir:
|
||||||
results = copy_tree(src, dst, FLAGS.dry_run)
|
results = copy_tree(src, dst, FLAGS.dry_run)
|
||||||
for filename in results:
|
for filename in results:
|
||||||
logging.info('Copied to: %s' % filename)
|
print 'Copied: %s' % filename
|
||||||
else:
|
else:
|
||||||
filename, copied = copy_file(src, dst, FLAGS.dry_run)
|
filename, copied = copy_file(src, dst, FLAGS.dry_run)
|
||||||
logging.info('Copied to: %s Successfully: %s' % (filename, copied))
|
print 'Copied: %s Successfully: %s' % (filename, copied)
|
||||||
except DistutilsFileError, e:
|
except DistutilsFileError, e:
|
||||||
sys.exit(str(e))
|
sys.exit(str(e))
|
||||||
|
|
||||||
|
|||||||
3
expand-symlinks.py
Normal file
3
expand-symlinks.py
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
from distutils.dir_util import copy_tree
|
||||||
|
|
||||||
|
copy_tree('.', 'snapshot', verbose=True)
|
||||||
1
samples/appengine/oauth2client
Symbolic link
1
samples/appengine/oauth2client
Symbolic link
@@ -0,0 +1 @@
|
|||||||
|
../../oauth2client/
|
||||||
@@ -1 +0,0 @@
|
|||||||
../../../apiclient/
|
|
||||||
@@ -1,16 +0,0 @@
|
|||||||
application: m-buzz
|
|
||||||
version: 1
|
|
||||||
runtime: python
|
|
||||||
api_version: 1
|
|
||||||
|
|
||||||
handlers:
|
|
||||||
- url: /static
|
|
||||||
static_dir: static
|
|
||||||
|
|
||||||
- url: /google8f1adb368b7bd14c.html
|
|
||||||
upload: google8f1adb368b7bd14c.html
|
|
||||||
static_files: static/google8f1adb368b7bd14c.html
|
|
||||||
|
|
||||||
- url: .*
|
|
||||||
script: main.py
|
|
||||||
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
../../../gflags.py
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
../../../gflags_validators.py
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
../../../httplib2/
|
|
||||||
@@ -1,11 +0,0 @@
|
|||||||
indexes:
|
|
||||||
|
|
||||||
# AUTOGENERATED
|
|
||||||
|
|
||||||
# This index.yaml is automatically updated whenever the dev_appserver
|
|
||||||
# detects that a new type of query is run. If you want to manage the
|
|
||||||
# index.yaml file manually, remove the above marker line (the line
|
|
||||||
# saying "# AUTOGENERATED"). If you want to manage some indexes
|
|
||||||
# manually, move them above the marker line. The index.yaml file is
|
|
||||||
# automatically uploaded to the admin console when you next deploy
|
|
||||||
# your application using appcfg.py.
|
|
||||||
@@ -1,109 +0,0 @@
|
|||||||
#!/usr/bin/env python
|
|
||||||
#
|
|
||||||
# Copyright 2007 Google Inc.
|
|
||||||
#
|
|
||||||
# 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.
|
|
||||||
#
|
|
||||||
|
|
||||||
__author__ = 'jcgregorio@google.com (Joe Gregorio)'
|
|
||||||
|
|
||||||
|
|
||||||
import httplib2
|
|
||||||
import logging
|
|
||||||
import os
|
|
||||||
import pickle
|
|
||||||
|
|
||||||
from apiclient.discovery import build
|
|
||||||
from oauth2client.appengine import CredentialsProperty
|
|
||||||
from oauth2client.appengine import StorageByKeyName
|
|
||||||
from oauth2client.client import OAuth2WebServerFlow
|
|
||||||
from google.appengine.api import memcache
|
|
||||||
from google.appengine.api import users
|
|
||||||
from google.appengine.ext import db
|
|
||||||
from google.appengine.ext import webapp
|
|
||||||
from google.appengine.ext.webapp import template
|
|
||||||
from google.appengine.ext.webapp import util
|
|
||||||
from google.appengine.ext.webapp.util import login_required
|
|
||||||
|
|
||||||
|
|
||||||
class Credentials(db.Model):
|
|
||||||
credentials = CredentialsProperty()
|
|
||||||
|
|
||||||
|
|
||||||
class MainHandler(webapp.RequestHandler):
|
|
||||||
|
|
||||||
@login_required
|
|
||||||
def get(self):
|
|
||||||
user = users.get_current_user()
|
|
||||||
credentials = StorageByKeyName(
|
|
||||||
Credentials, user.user_id(), 'credentials').get()
|
|
||||||
|
|
||||||
if credentials is None or credentials.invalid == True:
|
|
||||||
flow = OAuth2WebServerFlow(
|
|
||||||
# Visit https://code.google.com/apis/console to
|
|
||||||
# generate your client_id, client_secret and to
|
|
||||||
# register your redirect_uri.
|
|
||||||
client_id='<YOUR CLIENT ID HERE>',
|
|
||||||
client_secret='<YOUR CLIENT SECRET HERE>',
|
|
||||||
scope='https://www.googleapis.com/auth/buzz',
|
|
||||||
user_agent='buzz-cmdline-sample/1.0',
|
|
||||||
domain='anonymous',
|
|
||||||
xoauth_displayname='Google App Engine Example App')
|
|
||||||
|
|
||||||
callback = self.request.relative_url('/auth_return')
|
|
||||||
authorize_url = flow.step1_get_authorize_url(callback)
|
|
||||||
memcache.set(user.user_id(), pickle.dumps(flow))
|
|
||||||
self.redirect(authorize_url)
|
|
||||||
else:
|
|
||||||
http = httplib2.Http()
|
|
||||||
http = credentials.authorize(http)
|
|
||||||
service = build("buzz", "v1", http=http)
|
|
||||||
activities = service.activities()
|
|
||||||
activitylist = activities.list(scope='@consumption',
|
|
||||||
userId='@me').execute()
|
|
||||||
path = os.path.join(os.path.dirname(__file__), 'welcome.html')
|
|
||||||
logout = users.create_logout_url('/')
|
|
||||||
self.response.out.write(
|
|
||||||
template.render(
|
|
||||||
path, {'activitylist': activitylist,
|
|
||||||
'logout': logout
|
|
||||||
}))
|
|
||||||
|
|
||||||
|
|
||||||
class OAuthHandler(webapp.RequestHandler):
|
|
||||||
|
|
||||||
@login_required
|
|
||||||
def get(self):
|
|
||||||
user = users.get_current_user()
|
|
||||||
flow = pickle.loads(memcache.get(user.user_id()))
|
|
||||||
if flow:
|
|
||||||
credentials = flow.step2_exchange(self.request.params)
|
|
||||||
StorageByKeyName(
|
|
||||||
Credentials, user.user_id(), 'credentials').put(credentials)
|
|
||||||
self.redirect("/")
|
|
||||||
else:
|
|
||||||
pass
|
|
||||||
|
|
||||||
|
|
||||||
def main():
|
|
||||||
application = webapp.WSGIApplication(
|
|
||||||
[
|
|
||||||
('/', MainHandler),
|
|
||||||
('/auth_return', OAuthHandler)
|
|
||||||
],
|
|
||||||
debug=True)
|
|
||||||
util.run_wsgi_app(application)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
main()
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
../../../oauth2client/
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
../../../simplejson/
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
../../../uritemplate/
|
|
||||||
@@ -1,29 +0,0 @@
|
|||||||
<html>
|
|
||||||
<head>
|
|
||||||
<title>Buzz Stuff</title>
|
|
||||||
<style type=text/css>
|
|
||||||
td { vertical-align: top; padding: 0.5em }
|
|
||||||
img { border:0 }
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<p><a href="{{ logout }}">Logout</a></p>
|
|
||||||
<table border=0>
|
|
||||||
{% for item in activitylist.items %}
|
|
||||||
<tr valign=top>
|
|
||||||
<td>
|
|
||||||
<a href="{{ item.actor.profileUrl }}"><img
|
|
||||||
src="{{ item.actor.thumbnailUrl }}"></a><br>
|
|
||||||
<a href="{{ item.actor.profileUrl }}">{{ item.actor.name }}</a></td>
|
|
||||||
<td>
|
|
||||||
{{ item.object.content }}
|
|
||||||
</td>
|
|
||||||
<td>
|
|
||||||
<a href="{{ item.object.links.alternate.0.href }}"><img
|
|
||||||
src="/static/go.png"></a>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
{% endfor %}
|
|
||||||
</table>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
Reference in New Issue
Block a user