Exemple #1
0
    def post(self):

        if UserManager.get_current_user() == None:
            self.redirect('/user-not-found')
            return

        delete_message = 'ok'

        project_key_string = self.request.get('project-key')

        if (project_key_string == '' or project_key_string == None):
            delete_message = 'No project key provided'
        else:

            project = Project.get_by_id(int(project_key_string))

            if UserManager.get_user_has_privilege_for_operation(project):

                project_key = ndb.Key(Project, project.key.integer_id())
                actions = Action.query(ancestor=project_key)

                # Start with the project
                to_delete = [project.key]

                # No find all its actions
                for action in actions:

                    # Add those to the list
                    to_delete.append(action.key)

                    # Now get all the action details
                    action_detail_key = ndb.Key(Project,
                                                project.key.integer_id(),
                                                Action,
                                                action.key.integer_id())

                    action_details = ActionDetail.query(
                        ancestor=action_detail_key)

                    for action_detail in action_details:
                        to_delete.append(action_detail.key)

                ndb.delete_multi(to_delete)

            else:
                delete_message = 'Permission denied.'

        template = JINJA_ENVIRONMENT.get_template(
            'templates/_endpoints/action-update.json')
        self.response.write(template.render({"message": delete_message}))
Exemple #2
0
  def post(self):

    if UserManager.get_current_user() == None:
      self.redirect('/user-not-found')
      return

    delete_message = 'ok'

    project_key_string = self.request.get('project-key')

    if (project_key_string == '' or project_key_string == None):
      delete_message = 'No project key provided'
    else:

      project = Project.get_by_id(int(project_key_string))

      if UserManager.get_user_has_privilege_for_operation(project):

        project_key = ndb.Key(Project, project.key.integer_id())
        actions = Action.query(ancestor=project_key)

        # Start with the project
        to_delete = [project.key]

        # No find all its actions
        for action in actions:

          # Add those to the list
          to_delete.append(action.key)

          # Now get all the action details
          action_detail_key = ndb.Key(
            Project, project.key.integer_id(),
            Action, action.key.integer_id()
          )

          action_details = ActionDetail.query(ancestor=action_detail_key)

          for action_detail in action_details:
            to_delete.append(action_detail.key)

        ndb.delete_multi(to_delete)

      else:
        delete_message = 'Permission denied.'

    template = JINJA_ENVIRONMENT.get_template('templates/_endpoints/action-update.json')
    self.response.write(template.render({
      "message": delete_message
    }))
Exemple #3
0
    def get(self, url):

        if UserManager.get_current_user() == None:
            self.redirect('/user-not-found')
            return

        search = re.search('^([0-9A-Za-z\-]+)/([0-9A-Za-z\-]+)/(json)?', url)
        project_key_string = search.group(1)
        action_key_string = search.group(2)
        is_json = (search.group(3) == 'json')

        action_key = ndb.Key(
            Project,
            int(project_key_string),
        )
        action_detail_key = ndb.Key(Project, int(project_key_string), Action,
                                    int(action_key_string))

        project = Project.get_by_id(int(project_key_string))

        if not UserManager.get_user_has_privilege_for_operation(project):
            self.redirect('/')
            return

        action = Action.get_by_id(int(action_key_string), parent=action_key)

        if (action == None):
            self.redirect('/project/%s/' % project_key_string)
            return

        template_path = 'templates/project/action-detail.html'

        if (is_json):
            template_path = 'templates/_endpoints/chart-data.json'

        actions = ActionDetail.query(
            ancestor=action_detail_key).order(-ActionDetail.date)

        data = {
            'action_name':
            action.name,
            'action_type':
            action.type,
            'action_label':
            action.label,
            'action_x_axis':
            action.x_axis,
            'action_y_axis':
            action.y_axis,
            'action_y_axis_max':
            action.y_axis_max,
            'action_upload_url':
            blobstore.create_upload_url('/action/import'),
            'action_key':
            action_key_string,
            'project_key':
            project_key_string,
            'project_secret':
            project.secret,
            'actions':
            actions,
            'can_use_speed_index':
            all(a.speed_index > -1 for a in actions),
            'sign_out_url':
            UserManager.get_signout_url(),
            'gravatar_url':
            UserManager.get_gravatar_url(),
            'user_email':
            UserManager.get_email(),
            'user_is_admin':
            UserManager.is_admin(),
            'data_url':
            '/project/' + url + 'json',
            'sections': [{
                "name": "Projects",
                "url": "/project/list"
            }, {
                "name": project.name,
                "url": "/project/%s/" % project_key_string
            }, {
                "name": action.name
            }]
        }

        def remap_extended_info(values):

            remapped_values = {}

            for v in values:

                if v.type not in remapped_values:
                    remapped_values[v.type] = []

                try:

                    value = {
                        'name': v.name,
                        'type': v.type,
                        'value': float(v.value)
                    }

                except Exception, e:

                    if value == None:
                        value = 0.0

                # print v
                remapped_values[v.type].append(value)

            if 'JavaScript' in remapped_values:
                remapped_values['JavaScript'] = (sorted(
                    remapped_values['JavaScript'],
                    key=lambda r: float(r['value']),
                    reverse=True))

            return remapped_values
Exemple #4
0
  def get (self, url):

    if UserManager.get_current_user() == None:
      self.redirect('/user-not-found')
      return

    search = re.search('^([0-9A-Za-z\-]+)/([0-9A-Za-z\-]+)/(json)?', url)
    project_key_string = search.group(1)
    action_key_string = search.group(2)
    is_json = (search.group(3) == 'json')

    action_key = ndb.Key(
      Project, int(project_key_string),
    )
    action_detail_key = ndb.Key(
      Project, int(project_key_string),
      Action, int(action_key_string)
    )

    project = Project.get_by_id(int(project_key_string))

    if not UserManager.get_user_has_privilege_for_operation(project):
      self.redirect('/')
      return

    action = Action.get_by_id(int(action_key_string),
      parent=action_key)

    if (action == None):
      self.redirect('/project/%s/' % project_key_string)
      return

    template_path = 'templates/project/action-detail.html'

    if (is_json):
      template_path = 'templates/_endpoints/chart-data.json'

    actions = ActionDetail.query(ancestor=action_detail_key).order(
        -ActionDetail.date)

    data = {
      'action_name': action.name,
      'action_type': action.type,
      'action_label': action.label,
      'action_x_axis': action.x_axis,
      'action_y_axis': action.y_axis,
      'action_y_axis_max': action.y_axis_max,
      'action_upload_url': blobstore.create_upload_url('/action/import'),
      'action_key': action_key_string,
      'project_key': project_key_string,
      'project_secret': project.secret,
      'actions': actions,
      'can_use_speed_index': all(a.speed_index > -1 for a in actions),
      'sign_out_url': UserManager.get_signout_url(),
      'gravatar_url': UserManager.get_gravatar_url(),
      'user_email': UserManager.get_email(),
      'user_is_admin': UserManager.is_admin(),
      'data_url': '/project/' + url + 'json',
      'sections': [{
        "name": "Projects",
        "url": "/project/list"
      },{
        "name": project.name,
        "url": "/project/%s/" % project_key_string
      }, {
        "name": action.name
      }]
    }

    def remap_extended_info(values):

      remapped_values = {}

      for v in values:

        if v.type not in remapped_values:
          remapped_values[v.type] = []

        try:

          value = {
            'name': v.name,
            'type': v.type,
            'value': float(v.value)
          }

        except Exception, e:

          if value == None:
            value = 0.0

        # print v
        remapped_values[v.type].append(value)

      if 'JavaScript' in remapped_values:
        remapped_values['JavaScript'] = (
          sorted(remapped_values['JavaScript'],
                key=lambda r: float(r['value']),
                reverse=True)
        )

      return remapped_values