當前位置: 首頁>>代碼示例>>Python>>正文


Python Project.get_by_id方法代碼示例

本文整理匯總了Python中models.Project.get_by_id方法的典型用法代碼示例。如果您正苦於以下問題:Python Project.get_by_id方法的具體用法?Python Project.get_by_id怎麽用?Python Project.get_by_id使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在models.Project的用法示例。


在下文中一共展示了Project.get_by_id方法的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: get

# 需要導入模塊: from models import Project [as 別名]
# 或者: from models.Project import get_by_id [as 別名]
 def get(self):
     account = get_account()
     placed_bids_ids = account.projects_bidded_on
     placed_bids = []
     for i in placed_bids_ids:
         project_id = int(i)
         project = Project.get_by_id(project_id)
         project_open = "open"
         frmtd_end_date = project.end_date
         winner_email = None
         if frmtd_end_date is not None:
             frmtd_end_date = frmtd_end_date.strftime('%b %d, %Y')
         if project.winner is not None:
             project_open = "Closed (Winner selected)"
             winner_account = Account.get_by_id(int(project.winner))
             if winner_account:
                 winner_email = winner_account.guser.email()
         projectJSON = {
             'projectid': project_id,
             'projectname': project.name,
             'bidders': project.bidders,
             'winner': project.winner,
             'winner_email': winner_email,
             'price': project.price,
             'bidcount': len(project.bidders),
             'enddate': frmtd_end_date,
             'additionalstatus': project_open,
             'complete': project.complete
         }
         placed_bids.append(projectJSON)
     self.response.headers['Content-Type'] = 'application/json'
     self.response.write(json.dumps(placed_bids))
開發者ID:N0tinuse,項目名稱:senior_project,代碼行數:34,代碼來源:info.py

示例2: copy_file_to_project

# 需要導入模塊: from models import Project [as 別名]
# 或者: from models.Project import get_by_id [as 別名]
def copy_file_to_project(filepath, project_id):
    """
    Copy file to project dir and return new filepath in project directory.

    :param filepath: The file path.
    :type filepath: String

    :param project_id: Project id from database.
    :type project_id: Integer

    :returns: The path for this file in project directory or empty string.
    :rtype: String

    """
    project_path = Project.get_by_id(project_id).dir
    file_project_path = search_file(os.path.basename(filepath), project_path)
    if file_project_path:
        return file_project_path
    result = ''
    try:
        shutil.copy2(filepath, project_path)
        result = os.path.join(project_path, os.path.basename(filepath))
    except (ValueError, IOError, OSError):
        LOGGER.exception('File copy error')
    return result
開發者ID:diwa-aalto,項目名稱:diwacs,代碼行數:27,代碼來源:filesystem.py

示例3: wrapper

# 需要導入模塊: from models import Project [as 別名]
# 或者: from models.Project import get_by_id [as 別名]
    def wrapper(self, project_id):
        project = Project.get_by_id(long(project_id))
        if project:
            user = users.get_current_user()
            if project.owner == user.user_id():
                nodes = Node.all()
                nodes.ancestor(project)
                nodes.order('title')
                nodes = tuple(nodes) # prevent re-execution when iterating

                request_node, current_node = self.request.get('node'), None
                if request_node: # self.request.get always return a string
                    try:
                        current_node_id = long(request_node)
                    except ValueError:
                        pass
                    else:
                        for node in nodes:
                            if node.key().id() == current_node_id:
                                current_node = node
                                break
                    if current_node is None:
                        self.redirect(project.permalink)
                        return

                f(self, user, project, nodes, current_node)
            else:
                self.error(403)
        else:
            self.redirect('/')
開發者ID:git2samus,項目名稱:tamarindo-web,代碼行數:32,代碼來源:project.py

示例4: project

# 需要導入模塊: from models import Project [as 別名]
# 或者: from models.Project import get_by_id [as 別名]
def project(request, context, id):
    project = Project.get_by_id(int(id))
    context['project']=project
    
    scraps = Scrap.all().filter("project =", project).order("-created")
    context['scraps'] = scraps
    
    return render_to_response( "project.html", context )
開發者ID:bmander,項目名稱:proje,代碼行數:10,代碼來源:views.py

示例5: _on_moved_project

# 需要導入模塊: from models import Project [as 別名]
# 或者: from models.Project import get_by_id [as 別名]
    def _on_moved_project(self, event):
        """
        On_modified event handler for project files.

        This should get called when a project file has been moved.

        - If the file exists in database:
            - If the target path is inside project directory, change the\
            path entry in database.
            - If the target path is outside project directory, set the\
            file as deleted (project.id = NULL).
        - If the file does not exist in database:
            - If the target path is inside the project directory, add the\
            file into the database.
            - If the target path is outside the project directory, do nothing.

        :param event: The event.
        :type event: :py:class:`watchdog.events.FileSystemEvent`

        """
        source = os.path.abspath(event.src_path)
        target = os.path.abspath(event.dest_path)
        try:
            project = Project.get_by_id(self.project_id)
            source_file = File.get('one', File.project == project,
                                   File.path == source)
            project_path = os.path.abspath(project.dir)
            if source_file is not None:
                # Case 1
                if target.startswith(project_path):
                    source_file.path = target
                    act_path = target
                    action = REVERSE_ACTIONS['Renamed to something']
                # Case 2
                else:
                    source_file.project_id = None
                    act_path = source
                    action = REVERSE_ACTIONS['Deleted']
                source_file.update()
                self._project_prototype(act_path, action)
            else:
                # Case 3
                if target.startswith(project_path):
                    action = REVERSE_ACTIONS['Created']
                    self._project_prototype(target, action)
                # Case 4, should never happen.
                else:
                    pass
        except Exception as excp:
            log_msg = ('Exception in Project file handler on_moved '
                       'callback: {exception!s}')
            log_msg = log_msg.format(exception=excp)
            _logger().exception(log_msg)
開發者ID:diwa-aalto,項目名稱:diwacs,代碼行數:55,代碼來源:handlers.py

示例6: show

# 需要導入模塊: from models import Project [as 別名]
# 或者: from models.Project import get_by_id [as 別名]
def show(project_id, path):
    """Project page route.
    
    Renders the single page app (SPA) for the project. The SPA will
    be the main interface of the user to Sirius.
    """
    
    project = Project.get_by_id(long(project_id))
    if (project == None):
        return abort(404)
    else:
        pjson = json.dumps(project.json(), ensure_ascii=False)
        return render_template('projects/show.html', project=project, project_json=pjson)
開發者ID:bruxr,項目名稱:Sirius2,代碼行數:15,代碼來源:projects.py

示例7: get

# 需要導入模塊: from models import Project [as 別名]
# 或者: from models.Project import get_by_id [as 別名]
 def get(self, id_or_slug):
     from models import Project
     completed_projects = Project.get_all_complete()
     ongoing_projects = Project.get_all_ongoing()
     try:
         id = int(id_or_slug, 10)
         project = Project.get_by_id(id)
     except ValueError:
         project = Project.get_by_slug(id_or_slug)
     self.render('project_information.html', 
         project=project,
         completed_projects=completed_projects,
         ongoing_projects=ongoing_projects)
開發者ID:aswadrangnekar,項目名稱:khandelwal,代碼行數:15,代碼來源:handlers.py

示例8: delete_project

# 需要導入模塊: from models import Project [as 別名]
# 或者: from models.Project import get_by_id [as 別名]
def delete_project( request, user, id ):
    project = Project.get_by_id(int(id))
    
    if project.user != user:
        return HttpResponseForbidden( "<html><body>That doesn't belong to you</body></html>" )
        
    # get nickname of user, to decrement their project_count
    nickname = Nickname.all().filter("user =", user).get()
    nickname.project_count -= 1
    nickname.put()
    
    project.delete()
    
    return HttpResponseRedirect( "/" )
開發者ID:bmander,項目名稱:proje,代碼行數:16,代碼來源:views.py

示例9: get

# 需要導入模塊: from models import Project [as 別名]
# 或者: from models.Project import get_by_id [as 別名]
 def get(self, project_id, bidder_id):
     project_id = int(project_id)
     project = Project.get_by_id(project_id)
     if project:
         bidder_id = int(bidder_id)
         if bidder_id in project.bidders:
             project.winner = bidder_id
             project.put()
             response = {'success': 'Winner chosen.'}
         else:
             response = {'error': 'Winner not in bidders list.'}
     else:
         response = {'error': 'No project of given id.'}
     self.response.headers['Content-Type'] = 'application/json'
     self.response.write(json.dumps(response))
開發者ID:N0tinuse,項目名稱:senior_project,代碼行數:17,代碼來源:actions.py

示例10: start_new_session

# 需要導入模塊: from models import Project [as 別名]
# 或者: from models.Project import get_by_id [as 別名]
def start_new_session(project_id, old_session_id=None):
    """
    Creates a session to the database and return a session object.

    :param project_id: Project id from database.
    :type project_id: Integer

    :param old_session_id: A session id of a session which will be continued.
    :type old_session_id: Integer

    """
    project = Project.get_by_id(project_id)
    try:
        old_session = Session.get_by_id(old_session_id)
    except NoResultFound:
        old_session = None
    return Session(project, old_session)
開發者ID:diwa-aalto,項目名稱:diwacs,代碼行數:19,代碼來源:session.py

示例11: _on_created_scanner

# 需要導入模塊: from models import Project [as 別名]
# 或者: from models.Project import get_by_id [as 別名]
    def _on_created_scanner(self, event):
        """
        On_created event handler for project scanned files.
        Logs to database.

        :param event: The event.
        :type event: an instance of :class:`watchdog.events.FileSystemEvent`

        """
        try:
            project = Project.get_by_id(self.project_id)
            if not project.dir:
                return
            file_path = event.src_path
            basename = os.path.basename(file_path)
            log_msg = 'On created at: {path} ({name})'
            log_msg = log_msg.format(path=project.dir, name=basename)
            _logger().debug(log_msg)
            new_path = os.path.join(project.dir, basename)
            try:
                # Let's build the directory path to the file.
                path_parts = os.path.dirname(file_path)
                path_parts = os.path.splitdrive(path_parts)[1]  # (drive, path)
                # Now it is for example: [this part]
                # C:[\Some\path\To\dir]\myfile.txt
                path_parts = path_parts.strip(os.path.sep)
                path_parts = path_parts.split(os.path.sep)
                # ['Some', 'path', 'To', 'dir']
                path_parts = [part.lower() for part in path_parts]
                # ['some', 'path', 'to', 'dir']
                if 'scan' in path_parts:
                    # The file is a subdirectory of "scan" folder in
                    # some sense.
                    sleep(60)
            except (IndexError, ValueError):
                pass
            shutil.copy2(file_path, new_path)
            self._project_prototype(new_path, REVERSE_ACTIONS['Created'])
        except Exception as excp:
            log_msg = 'Exception in SCAN HANDLER: {exception!s}'
            log_msg = log_msg.format(exception=excp)
            _logger().exception(log_msg)
開發者ID:diwa-aalto,項目名稱:diwacs,代碼行數:44,代碼來源:handlers.py

示例12: OpenProjectDir

# 需要導入模塊: from models import Project [as 別名]
# 或者: from models.Project import get_by_id [as 別名]
    def OpenProjectDir(self, event):
        """
        Opens project directory in windows explorer.

        :param event: The GraphicalUserInterface event.
        :type event: Event

        """
        project_id = self.diwa_state.current_project_id
        if project_id < 1:
            return
        file_path = unicode(Project.get_by_id(project_id).dir)
        if file_path:
            os.startfile(file_path, u'explore')
        else:
            log_msg = u'Failed explorer: {0}'
            log_msg = log_msg.format(file_path)
            LOGGER.exception(log_msg.encode('utf-8'))  # FIXME
            params = {'message': 'Could not open directory.'}
            show_modal_and_destroy(ErrorDialog, self, params)
        if event:
            event.Skip()
開發者ID:diwa-aalto,項目名稱:diwacs,代碼行數:24,代碼來源:diwacs.py

示例13: add_scrap

# 需要導入模塊: from models import Project [as 別名]
# 或者: from models.Project import get_by_id [as 別名]
def add_scrap(request, user):
    
    if not ('content' and 'projectid' in request.POST):
        return HttpResponseServerError( "You must include both content and a project id" )
    
    logging.info( str( request.POST ) );
    
    # get project_id
    projectid = int(request.POST['projectid'])
    
    # get project
    project = Project.get_by_id( projectid )
    
    if project is None:
        return HttpResponseNotFound( "Could not find project with id %s"%projectid )
    
    # project needs to be owned by the current user
    if project.user != user:
        return HttpResponseForbidden( "This project is owned by %s. You are %s. They're not the same."%(project.user, user) )
    
    # scrap content needs to be non-blank
    scrap_content = request.POST['content']
    if scrap_content.strip()=="":
        return HttpResponseServerError( "The scrap content needs to have <i>characters</i>" )
    
    # if it's a URL, file it away as a LinkScrap
    parsed_url = urlparse.urlparse( scrap_content )
    if parsed_url[0]!="" and parsed_url[1]!="":
        # get favicon, if possible
        favicon_url = parsed_url[0]+"://"+parsed_url[1]+"/favicon.ico"
        try:
            favicon_resp = urlfetch.fetch(favicon_url)
            
            if favicon_resp.status_code == 200:
                favicon = favicon_resp.content
            else:
                favicon = None
        except DownloadError:
            favicon = None
            
        # if it parses as a feed, file it away as a feed scrap
        parse_attempt = feedparser.parse(scrap_content)
        if parse_attempt.version != "":
            # if we're not already subscribed to this feed
            if FeedScrap.all().filter("content =", scrap_content).filter("project =", project).count()!=0:
                return HttpResponseServerError( "This feed has already been added to this project.Z" )
            
            scrap = FeedScrap( content = scrap_content, project=project, created=datetime.datetime.now(), creator=user, icon=favicon )
            scrap.put()
            
            for entry in parse_attempt.entries:
                if 'guid' in entry and 'link' in entry and ('updated' in entry or 'published' in entry):
                    if 'published' in entry:
                        created = datetime.datetime( *entry.published_parsed[:6] )
                    elif 'updated' in entry:
                        created = datetime.datetime( *entry.updated_parsed[:6] )
                        
                        
                    if FeedItemScrap.all().filter("project=", project).filter("guid =", entry.guid).count()==0:
                        feed_item_scrap = FeedItemScrap( content=entry.link,
                                                         project=project,
                                                         created=created,
                                                         creator=user,
                                                         icon=favicon,
                                                         feed=scrap,
                                                         guid=entry.guid )
                        feed_item_scrap.put()
                        logging.info( feed_item_scrap )
                                                     
        else:
            scrap = LinkScrap( content = scrap_content, project=project, created=datetime.datetime.now(), creator=user, icon=favicon )
            scrap.put()
    else:
        scrap = Scrap( content = scrap_content, project=project, creator=user, created=datetime.datetime.now() )
        scrap.put()
    
    project.updated = datetime.datetime.now()
    project.put()
        
    return render_to_response( "includes/scrap_div.html", {'scrap':scrap} )
開發者ID:bmander,項目名稱:proje,代碼行數:82,代碼來源:views.py


注:本文中的models.Project.get_by_id方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。