def put_proyecto(self, id_proyecto, nombre_proyecto, idusuario, descripcion, asmSelect0, tipos_fases,**kw): nom_proyecto=Variables.get_valor_by_nombre("nombre_proyecto_actual") nom_fase=Variables.get_valor_by_nombre("nombre_fase_actual") if id_proyecto is not None: id_proyecto=int(id_proyecto) if idusuario is not None: idusuario=int(idusuario) nombres=Proyecto.get_nombres() proyecto = DBSession.query(Proyecto).get(id_proyecto) if not isinstance(nombres, list): nombres = [nombres] nombres.remove(proyecto.nombre_proyecto) if nombre_proyecto not in nombres: miembro=Equipo_Desarrollo.get_miembro_by_usuario_by_proyecto( proyecto.idusuario,proyecto.id_proyecto) id_miembro=miembro.id_equipo Equipo_Desarrollo.borrar_by_id(id_miembro) DBSession.flush() fases=Fase.get_fase_by_proyecto(proyecto.id_proyecto) for fase in fases: Fase.borrar_by_id(fase.id_fase) DBSession.flush() if not isinstance(tipos_fases, list): tipos_fases = [tipos_fases] tipos_fases = [DBSession.query(Tipo_Fase).get(tipo_fase) for tipo_fase in tipos_fases] cant=1 for tipo_fase in tipos_fases: fase = Fase (nombre_fase=tipo_fase.nombre_tipo_fase, id_tipo_fase=tipo_fase.id_tipo_fase, estado ="Nuevo", proyecto=proyecto.id_proyecto,orden=cant, linea_base="Abierta", descripcion=tipo_fase.descripcion) DBSession.add(fase) DBSession.flush() cant+=1 proyecto.idusuario = idusuario proyecto.nombre_proyecto=nombre_proyecto proyecto.descripcion = descripcion proyecto.tipos_fases = tipos_fases proyecto.estado="Desactivado" DBSession.flush() fases = Fase.get_fase_by_proyecto(Proyecto.get_ultimo_id()) nom="Lider Proyecto" mirol=Rol.get_rol_by_nombre(nom) equipo = Equipo_Desarrollo(proyecto=Proyecto.get_ultimo_id(), idusuario=idusuario, idrol=mirol.idrol,fases=fases) DBSession.add(equipo) DBSession.flush() fases = Fase.get_fase_by_proyecto(proyecto.id_proyecto) flash("Proyecto Modificado!") return dict(pagina="/fase/listar_fase", fases=fases, nom_proyecto=nom_proyecto,nom_fase=nom_fase) else: flash("nombre proyecto repetido!") redirect('/proyecto/editar_proyecto?id_proyecto=%d' % id_proyecto)
def post_proyecto(self, nombre_proyecto, idusuario, tipos_fases, asmSelect0, descripcion,start=0,end=5,indice=None,texto=""): nom_proyecto=Variables.get_valor_by_nombre("nombre_proyecto_actual") nom_fase=Variables.get_valor_by_nombre("nombre_fase_actual") nombres=Proyecto.get_nombres() if not isinstance(nombres, list): nombres = [nombres] if nombre_proyecto not in nombres: if idusuario is not None: idusuario = int(idusuario) if tipos_fases is not None: if not isinstance(tipos_fases, list): tipos_fases = [tipos_fases] tipos_fases = [DBSession.query(Tipo_Fase).get(tipo_fase) for tipo_fase in tipos_fases] proyecto = Proyecto (nombre_proyecto=nombre_proyecto, idusuario=idusuario, descripcion=descripcion, tipos_fases=tipos_fases, estado ="Desactivado") DBSession.add(proyecto) DBSession.flush() proy=int(Proyecto.get_ultimo_id()) cant=1 lista=[] for tipo_fase in tipos_fases: fase = Fase (nombre_fase=tipo_fase.nombre_tipo_fase, id_tipo_fase=tipo_fase.id_tipo_fase, estado ="Nuevo",proyecto=proy, orden=cant,linea_base="Abierta", descripcion=tipo_fase.descripcion) DBSession.add(fase) DBSession.flush() lista.append(fase) cant+=1 nom="Lider Proyecto" mirol=Rol.get_rol_by_nombre(nom) fases2=Fase.get_fase_by_proyecto(proy) equipo = Equipo_Desarrollo(proyecto=Proyecto.get_ultimo_id(), idusuario=idusuario, idrol=mirol.idrol,fases=fases2) DBSession.add(equipo) DBSession.flush() fases,len_fases = Fase.get_fase_by_proyecto_por_pagina(proy,start,end) ############ paginado = 5 if start <> 0: end=int(start.split('=')[1]) #obtiene el fin de pagina start=int(start.split('&')[0]) #obtiene el inicio de pagina #print start,end total = len(Fase.get_fase_by_proyecto(proy)) pagina_actual = ((start % end) / paginado) + 1 if ((start % end) % paginado) <> 0: pagina_actual = pagina_actual + 1 #roles = Fase.get_fase_by_proyecto_por_pagina(proy,start,end) ########### param="/fase/fase" flash("Proyecto Agregado!") return dict(pagina="../fase/fase", fases=fases, nom_proyecto=nom_proyecto,nom_fase=nom_fase, inicio=start,fin=end,paginado=paginado, pagina_actual=pagina_actual,total=total, param=param) else: nom_proyecto=Variables.get_valor_by_nombre("nombre_proyecto_actual") nom_fase=Variables.get_valor_by_nombre("nombre_fase_actual") usuarios = Usuario.get_usuarios() tipos_fases = Tipo_Fase.get_tipo_fases() flash("Nombre del Proyecto ya existe!") redirect('../proyecto/agregar_proyecto')