Ejemplo n.º 1
0
def create_project_quotas(project=None,
                          parsed_project_quotas=None,
                          session=None):
    project_quota = models.ProjectQuotas(
        project_id=project.id, parsed_project_quotas=parsed_project_quotas)
    project_quota_repo = repositories.get_project_quotas_repository()
    project_quota_repo.create_from(project_quota, session=session)
    return project_quota
Ejemplo n.º 2
0
def create_project_quotas(project=None, parsed_project_quotas=None,
                          session=None):
    project_quota = models.ProjectQuotas(
        project_id=project.id,
        parsed_project_quotas=parsed_project_quotas)
    project_quota_repo = repositories.get_project_quotas_repository()
    project_quota_repo.create_from(project_quota, session=session)
    return project_quota
Ejemplo n.º 3
0
 def __init__(self):
     self.repo = repo.get_project_quotas_repository()
Ejemplo n.º 4
0
class ProjectQuotas(base.BarbicanObject, base.BarbicanPersistentObject,
                    object_base.VersionedObjectDictCompat):
    fields = {
        'project_id': fields.StringField(nullable=True),
        'secrets': fields.IntegerField(nullable=True, default=None),
        'containers': fields.IntegerField(nullable=True, default=None),
        'consumers': fields.IntegerField(nullable=True, default=None),
        'orders': fields.IntegerField(nullable=True, default=None),
        'cas': fields.IntegerField(nullable=True, default=None),
        'project': fields.ObjectField('Project', nullable=True, default=None),
    }

    db_model = models.ProjectQuotas
    db_repo = repos.get_project_quotas_repository()
    synthetic_fields = ['project']

    def _validate_fields(self, change_fields):
        msg = u._("Must supply non-None {0} argument for ProjectQuotas entry.")

        if change_fields.get('project_id') is None:
            raise exception.MissingArgumentError(msg.format("project_id"))

    def _get_db_entity(self, parsed_project_quotas=None):
        return self.db_model(parsed_project_quotas=parsed_project_quotas,
                             check_exc=False)

    def create(self, session=None, parsed_project_quotas=None):
        change_fields = self._get_changed_persistent_fields()
        self._validate_fields(change_fields)
        db_entity = self._get_db_entity(
            parsed_project_quotas=parsed_project_quotas)
        db_entity.update(change_fields)
        db_entity = self.db_repo.create_from(db_entity, session=session)
        self._from_db_object(db_entity)

    @classmethod
    def get_by_create_date(cls,
                           offset_arg=None,
                           limit_arg=None,
                           suppress_exception=False,
                           session=None):
        entities_db, offset, limit, total = \
            cls.db_repo.get_by_create_date(offset_arg, limit_arg,
                                           suppress_exception, session)
        entities = [
            cls()._from_db_object(entity_db) for entity_db in entities_db
        ]
        return entities, offset, limit, total

    @classmethod
    def create_or_update_by_project_id(cls,
                                       project_id,
                                       parsed_project_quotas,
                                       session=None):
        cls.db_repo.create_or_update_by_project_id(project_id,
                                                   parsed_project_quotas,
                                                   session)

    @classmethod
    def get_by_external_project_id(cls,
                                   external_project_id,
                                   suppress_exception=False,
                                   session=None):
        entity_db = cls.db_repo. \
            get_by_external_project_id(external_project_id,
                                       suppress_exception, session)
        return cls()._from_db_object(entity_db)

    @classmethod
    def delete_by_external_project_id(cls,
                                      external_project_id,
                                      suppress_exception=False,
                                      session=None):
        cls.db_repo.delete_by_external_project_id(external_project_id,
                                                  suppress_exception, session)
Ejemplo n.º 5
0
 def __init__(self):
     self.repo = repo.get_project_quotas_repository()