Cooperator framework

19/06/2006 - 18:25 por Daniel A. Calvin | Informe spam
Amigos, les cuento que hace unos meses empezamos a trabajar con un grupo de
amigos en un proyecto para crear un framework que saque provecho de las
ventajas de .Net 2.0
La idea original fue de Eugenio Serrano y me invito a trabajar junto a el y
otros amigos.
El proyecto es un framewok de desarrollo, seguramente estarán pensando: otro
más :-)
Nos decidimos a hacer este nuevo con la idea principal de que sea bien facil
de usar y de acercar los objetos a mas gente de una forma facil.

Hemos trabajado con mucha energía estos últimos meses y hemos logrado armar
algo muy interesante según nuestra opinion.

Los objetivos que nos planteamos fueron:

- 100% Orientado a objetos
- Aplanar la curva de aprendizaje y facilitar el camino de quienes aún están
condicionados por el modelo relacional.
- No usar datasets
- No usamos reflection.
- Modelo totalmente tipado, esto significa que las clases de persistencia y
recuperacion de objetos devuelven un tipo especifico y no un tipo object.
- Debido a la potencia de VS2005 se pueden bindear estos objetos a los
controles sin escribir una linea de codigo, y aporvechar las venjas de
edicion de VS2005
- No depende de la estructura relacional, soporta cualquier tipo de
estructura de base de datos.
- No hay que modificar la Primary Key o crear un campo unique en las tablas.
- Usa stored procedures.
- Soporta concurrencia
- Las condiciones de busqueda se expresan mediante objetos específicos
tipados y extendibles por el programador que terminan ejecutando un Stored
Procedure en forma transparente.
- En la capa de negocio todo se expresa en términos del dominio, incluido
los filtros y busquedas.
- Genera código en base a scripts escritos en el lenguaje que prefiera el
programador. Por defecto estan en c#, pero puedo escribir un script en c#,
para generar código SQL, o puedo escribir un script en vb.net para generar
código c#.
- Hay un modelo propuesto de las clases que se generaran que se basa en el
modelo de datos, pero el programador, antes de generar las clases edita
dicho modelo en una herramienta muy facil de usar y define como sera el
modelo que desea crear.
- Si las opciones de modelado que provee la herramienta no alcanzan, el
programador puede editar los templates y generar su propio modelo.
- La herramienta de generacion, genera 2 archivos por cada clase usando
clases parciales pensado para que el programador solo modifique una de las
2.
Si mas tarde se agrega un nuevo campo a una tabla, se puede volver a generar
el otro archivo de manera de no "pisar" cualquier codigo que el programador
ya haya escrito en esa clase.
- Soporta transacciones desconectadas.
- Licencia tipo open source, aún no hemos optado por cual, pero será de
código abierto.

Todo esto lo logramos de forma poco invasiva, implementando interfaces y
valiendonos de las nuevas características del net framework 2.0, sobre todo
Generics y clases parciales.

El framework será publicado en un término no mayor a 60 días.

Nos gustaría mucho contar con algún retorno por parte de la comunidad,
principalmente que cosas les molesta de otras herraminetas de este tipo,
incluso que les gustaría tener y aún no han encontrado en otros frameworks.

Desde ya muchas gracias

Daniel Calvin

Preguntas similare

Leer las respuestas

#31 Daniel A. Calvin
20/06/2006 - 20:37 | Informe spam
Hola

Las entiadades en Cooperator solo conocen sus propiedades y metodos, proias
del negocio, nada adicional.

En Cooperator esto no existe:
Mostrar la cita
La información de mapeo solo la conocen clases especialixadas, los mappers y
no trabajamos con atributos.

La entidades tienen solo aquello que le defines y algunas pocas cosas
adicionales, muy pocas, que no hemos podido ocultar.

Gracias


Daniel A. Calvin
MCP


"Vyacheslav Popov" escribió:

Mostrar la cita
#32 Daniel A. Calvin
20/06/2006 - 20:49 | Informe spam
Hola carolina

Tiene ventajas reales ese esquema ?

La ventaja es que el codigo es muy claro, que tus objetos son los objetos
del dominio el problema y puedes identificarlos facilmente mientras miras o
escribes el codigo.

Todo tiene identidad.

Tal vez si me cuentas que tipo arquitectura o modelo utilizas te pueda decir
que ventajas o desvenatjas tiene esto en tu esquema.

Gracias



Daniel A. Calvin
MCP


"Carolina Alvarez" escribió:

Mostrar la cita
#33 Daniel A. Calvin
20/06/2006 - 20:53 | Informe spam
Vyacheslav Popov

Seguro que con reflection puedes ahorrate muchas lineas de código.

Pero como esas lineas de código las escribe Cooperator no nos preocupa.

Todo eso que mencionas Cooperator lo necesita, pero no lo escribe el
programador, lo escribe el solito.
Ese fue el enfoque que pretendimos darle, fue nuestro objetivo.
Puede no gustarte por supuesto.

Pero la realidad es que escribis muy poco, todo ese código pesado lo escribe
cooperator y tu ni te enteras. Solo invocas el mapper correspondiente.

Por ejemplo:

dim objClientes as ClientesList = ClientesMapper.GetList(new
ClienteFinder.TraerPorLocalidad( localidad))

( Si trabajaramos por reflection esta linea de codigo no sería tan clara
para quien no conoce la aplicación )

Saludos
Daniel A. Calvin
MCP


"Vyacheslav Popov" escribió:

Mostrar la cita
#34 Daniel A. Calvin
20/06/2006 - 21:00 | Informe spam
Hola Alfredo

Mostrar la cita
No se trata de ventajas, se tarta de acceso, si estoy en un entorno remoto,
no puedo acceder a lso metodos CRUD del motor de base de datos.

Por otra parte tampoco me interesa llevar la logica de persistencia al
cliente.
Toda la capa de negocio resuelve las colaboraciones, algunas clases que
componen la capa de negocio tienen contacto con la capa de datos.

El Cliente, ya sea viá capa de transporte, no en esta verison d cooperator,
o en forma directa, solo conoce la capa de negocios, el modelo de domio o los
procesos y entidades si lo prefieres.

Mostrar la cita
Aqui vamos a tener algún problema.

Gracias

Daniel A. Calvin
MCP


"Alfredo Novoa" escribió:

Mostrar la cita
#35 Daniel A. Calvin
20/06/2006 - 21:06 | Informe spam
Hola Vyacheslav Popov

Trato de responder todas las peguntas.
En un momento crei que tenías algún interes en que te cuente sobre la
iniciativa, ya no se que pretendes.

Que tengas un buen día.

Daniel A. Calvin
MCP


"Vyacheslav Popov" escribió:

Mostrar la cita
Ads by Google
Search Busqueda sugerida