# Guide for Cytomine developers
In this section, you will learn how to develop Cytomine components to extend the Cytomine platform or develop new features.
If you don't know Cytomine yet, follow the Get Started page in the user guide to have a tour and discover the main concept of Cytomine.
As the Cytomine project is composed of multiple services with different programming language, it is possible to contribute to one or another service according to your skills.
The main components of the Cytomine project are
- The Core (opens new window) component. It contains the programming logic, the object representation, their dependencies and the access permissions. Core is also the component connected to the databases. It is developed in Grails (opens new window).
- The IMS (opens new window) (Image Management Server) component. Connected to the storage disk, the uploads are made on IMS and it will convert, if necessary, and deploy the uploaded images. It will also return the tiles displayed in the viewer when you browse an image with its dependencies (For example see IIP Image Server (opens new window)). It is developed in Grails.
- The Cytomine-Web-UI (opens new window) component is our supported front-end. It is a Web User Interface developed in VueJS. It is every graphic component that you can see into your Cytomine browser navigation.
The main componant are on the following architecture graph :