| # Licensed to the Apache Software Foundation (ASF) under one |
| # or more contributor license agreements. See the NOTICE file |
| # distributed with this work for additional information |
| # regarding copyright ownership. The ASF licenses this file |
| # to you 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. |
| |
| import logging |
| |
| import oauth2 as oauth |
| from pylons import tmpl_context as c, app_globals as g |
| |
| from ming import schema as S |
| from ming.orm import FieldProperty, RelationProperty, ForeignIdProperty |
| from ming.orm.declarative import MappedClass |
| |
| from allura.lib import helpers as h |
| from .session import main_doc_session, main_orm_session |
| from .session import project_doc_session, project_orm_session |
| |
| log = logging.getLogger(__name__) |
| |
| class OAuthToken(MappedClass): |
| class __mongometa__: |
| session = main_orm_session |
| name='oauth_token' |
| indexes = [ 'api_key' ] |
| polymorphic_on='type' |
| polymorphic_identity=None |
| |
| _id = FieldProperty(S.ObjectId) |
| type=FieldProperty(str) |
| api_key = FieldProperty(str, if_missing=lambda:h.nonce(20)) |
| secret_key = FieldProperty(str, if_missing=h.cryptographic_nonce) |
| |
| def to_string(self): |
| return oauth.Token(self.api_key, self.secret_key).to_string() |
| |
| def as_token(self): |
| return oauth.Token(self.api_key, self.secret_key) |
| |
| class OAuthConsumerToken(OAuthToken): |
| class __mongometa__: |
| polymorphic_identity='consumer' |
| name='oauth_consumer_token' |
| unique_indexes = [ 'name' ] |
| |
| type = FieldProperty(str, if_missing='consumer') |
| user_id = ForeignIdProperty('User', if_missing=lambda:c.user._id) |
| name = FieldProperty(str) |
| description = FieldProperty(str) |
| |
| user = RelationProperty('User') |
| |
| @property |
| def description_html(self): |
| return g.markdown.convert(self.description) |
| |
| @property |
| def consumer(self): |
| '''OAuth compatible consumer object''' |
| return oauth.Consumer(self.api_key, self.secret_key) |
| |
| @classmethod |
| def for_user(cls, user=None): |
| if user is None: user = c.user |
| return cls.query.find(dict(user_id=user._id)).all() |
| |
| class OAuthRequestToken(OAuthToken): |
| class __mongometa__: |
| polymorphic_identity='request' |
| |
| type = FieldProperty(str, if_missing='request') |
| consumer_token_id = ForeignIdProperty('OAuthConsumerToken') |
| user_id = ForeignIdProperty('User', if_missing=lambda:c.user._id) |
| callback = FieldProperty(str) |
| validation_pin = FieldProperty(str) |
| |
| consumer_token = RelationProperty('OAuthConsumerToken') |
| |
| class OAuthAccessToken(OAuthToken): |
| class __mongometa__: |
| polymorphic_identity='access' |
| |
| type = FieldProperty(str, if_missing='access') |
| consumer_token_id = ForeignIdProperty('OAuthConsumerToken') |
| request_token_id = ForeignIdProperty('OAuthToken') |
| user_id = ForeignIdProperty('User', if_missing=lambda:c.user._id) |
| |
| user = RelationProperty('User') |
| consumer_token = RelationProperty('OAuthConsumerToken', via='consumer_token_id') |
| request_token = RelationProperty('OAuthToken', via='request_token_id') |
| |
| @classmethod |
| def for_user(cls, user=None): |
| if user is None: user = c.user |
| return cls.query.find(dict(user_id=user._id)).all() |
| |