def crearProyecto(self, **kw): proyecto = Proyecto() proyecto.nombre = kw['nombre'] proyecto.estado = 'definicion' proyecto.fecha = kw['fecha'] DBSession.add(proyecto) proyecto = DBSession.query(Proyecto).filter_by(nombre=kw['nombre']).one() # Se crean los permisos de consulta, edición y eliminación del proyecto permiso_consultar = Permission() permiso_consultar.permission_name='ConsultarProyecto' + str(proyecto.codproyecto) DBSession.add(permiso_consultar) permiso_editar = Permission() permiso_editar.permission_name='EditarProyecto' + str(proyecto.codproyecto) DBSession.add(permiso_editar) permiso_eliminar = Permission() permiso_eliminar.permission_name='EliminarProyecto' + str(proyecto.codproyecto) DBSession.add(permiso_eliminar) permiso_definir_fases = Permission() permiso_definir_fases.permission_name='DefinirFases' + str(proyecto.codproyecto) DBSession.add(permiso_definir_fases) #Agregar los permisos de consulta, edicion y eliminacion al rol por defecto del usuario creador de proyecto identity = request.environ['repoze.who.identity'] usuario_creador_de_proyecto = identity['user'] rol = DBSession.query(Group).filter_by(group_name='RolPorDefecto' + str(usuario_creador_de_proyecto.user_id)).one() rol.permissions.append(permiso_consultar) rol.permissions.append(permiso_editar) rol.permissions.append(permiso_eliminar) rol.permissions.append(permiso_definir_fases) flash("El proyecto fue creado con exito") redirect("ListarProyectos")
def setup(self): try: new_attrs = {} new_attrs.update(self.attrs) new_attrs.update(self.do_get_dependencies()) self.obj = self.klass(**new_attrs) DBSession.add(self.obj) DBSession.flush() return self.obj except: DBSession.rollback() raise
def setUp(self): """Prepare model test fixture.""" try: new_attrs = {} new_attrs.update(self.attrs) new_attrs.update(self.do_get_dependencies()) self.obj = self.klass(**new_attrs) DBSession.add(self.obj) DBSession.flush() return self.obj except: DBSession.rollback() raise
def crearFase(self, proy_id, **kw): fase = Fase() fase.nombre = kw['nombre'] fase.descripcion = kw['descripcion'] fase.estado = "definicion" import datetime fase.fecha = datetime.date.today() proyecto = DBSession.query(Proyecto).filter_by(codproyecto=proy_id).one() fase.proyecto = proyecto proyecto.fases.append(fase) #fase.codproyecto=int(proy_id) DBSession.add(fase) self.CrearTipoItemBasico(proy_id, fase) flash("La fase fue creada con exito") redirect("/DefinirFases/"+proy_id)
def crearUsuario(self, **kw): usuario = User() usuario.user_name = kw['nombre'] usuario.user_fullname = kw[u'apellido'] usuario.password = kw[u'contrasena'] usuario.user_telefono = kw[u'telefono'] usuario.user_direccion = kw[u'direccion'] usuario.email_address = kw[u'email'] DBSession.add(usuario) #Agregar los roles roles = kw[u'rol'] for rol_id in roles: rol = DBSession.query(Group).filter_by(group_id=rol_id).one() rol.users.append(usuario) #Crear el rol por defecto para este usuario rol_por_defecto = Group() rol_por_defecto.group_name = 'RolPorDefecto' + str(usuario.user_id) DBSession.add(rol_por_defecto) rol_por_defecto.users.append(usuario) #Asociar el rol por defecto con el usuario # Se crean los permisos de consulta, edicion y eliminacion de este usuario permiso_consultar = Permission() permiso_consultar.permission_name='ConsultarUsuario' + str(usuario.user_id) DBSession.add(permiso_consultar) permiso_editar = Permission() permiso_editar.permission_name='EditarUsuario' + str(usuario.user_id) DBSession.add(permiso_editar) permiso_eliminar = Permission() permiso_eliminar.permission_name='EliminarUsuario' + str(usuario.user_id) DBSession.add(permiso_eliminar) #Asociar el rol por defecto con el usuario #rol_por_defecto.users.append(usuario) #rol_por_defecto.permissions.append() #Agregar los permisos de consulta, edicion y eliminacion al rol por defecto del usuario creador de usuario identity = request.environ['repoze.who.identity'] usuario_creador_de_usuario = identity['user'] rol = DBSession.query(Group).filter_by(group_name='RolPorDefecto' + str(usuario_creador_de_usuario.user_id)).one() rol.permissions.append(permiso_consultar) rol.permissions.append(permiso_editar) rol.permissions.append(permiso_eliminar) #Asignarle al usuario recien creado el permiso de consulta de sus datos rol_por_defecto.permissions.append(permiso_consultar) flash("El usuario fue creado satisfactoriamente") redirect("NuevoUsuario")
def crearItem(self, proyecto_id, fase_id, tipoitem_id, **kw): #print tipoitem_id item = Item() item.nombre=kw['nombre'] item.complejidad=kw['complejidad'] item.prioridad=kw['prioridad'] item.version=1 item.estado='desarrollo' import datetime item.fecha=datetime.date.today() tipoitem = DBSession.query(Tipoitem).filter_by(codtipoitem=tipoitem_id).one() item.tipoitem = tipoitem fase = DBSession.query(Fase).filter_by(codfase=fase_id).one() #print fase #print item.fase item.fase = fase #print tipoitem DBSession.add(item) fase.items.append(item) tipoitem.items.append(item) redirect("/IngresarFase/"+proyecto_id+"/"+fase_id)
def editarItem(self, proyecto_id, fase_id, item_id, **kw): item = DBSession.query(Item).filter_by(coditem=item_id).one() item.nombre=kw['nombre'] item.complejidad=kw['complejidad'] item.prioridad=kw['prioridad'] item.version=1 item.estado='definicion' import datetime item.fecha=datetime.date.today() DBSession.flush() ##Crear las relaciones if 'items_izq' in kw: items_izq = kw['items_izq'] if not isinstance(items_izq, list): items_izq = [items_izq] else: items_izq=list() if 'items_der' in kw: items_der = kw['items_der'] if not isinstance(items_der, list): items_der = [items_der] else: items_der=list() for item in items_izq: relacion = Relacion() relacion.coditeminicio= int(item) relacion.coditemfin=item_id relacion.tipo='antecesor-sucesor' DBSession.add(relacion) for item in items_der: relacion = Relacion() relacion.coditeminicio= item_id relacion.coditemfin=int(item) relacion.tipo='antecesor-sucesor' DBSession.add(relacion) redirect("/IngresarFase/"+proyecto_id+"/"+fase_id)
def crearRol(self, **kw): rol = Group() rol.group_name = kw['nombre'] rol.group_description = kw['descripcion'] DBSession.add(rol) #Agregar los permisos permisos = kw[u'permiso'] for permiso_id in permisos: permiso = DBSession.query(Permission).filter_by(permission_id=permiso_id).one() permiso.groups.append(rol) # Se crean los permisos de consulta, edicion y eliminacion de este rol rol = DBSession.query(Group).filter_by(group_name=kw['nombre']).one() permiso_consultar = Permission() permiso_consultar.permission_name='ConsultarRol' + str(rol.group_id) DBSession.add(permiso_consultar) permiso_editar = Permission() permiso_editar.permission_name='EditarRol' + str(rol.group_id) DBSession.add(permiso_editar) permiso_eliminar = Permission() permiso_eliminar.permission_name='EliminarRol' + str(rol.group_id) DBSession.add(permiso_eliminar) #grupo = DBSession.query(Group).filter_by(group_id='2').one() #permiso_editar.groups.append(grupo) #permiso_eliminar.groups.append(grupo) #Agregar los permisos de consulta, edicion y eliminacion al rol por defecto del usuario creador del rol identity = request.environ['repoze.who.identity'] usuario_creador_de_usuario = identity['user'] rol = DBSession.query(Group).filter_by(group_name='RolPorDefecto' + str(usuario_creador_de_usuario.user_id)).one() rol.permissions.append(permiso_consultar) rol.permissions.append(permiso_editar) rol.permissions.append(permiso_eliminar) flash("El rol fue creado con exito") redirect("ListarRoles")