# HG changeset patch # User Nicolas Chauvat # Date 1229972070 -3600 # Node ID 0575e7973c5ed22de674b4e9aee238f6b6a8dd0e # Parent 843e0b1bf9916908d65b6bcb4cd563d03e17ad2e [doc] trying to improve the tutorial diff -r 843e0b1bf991 -r 0575e7973c5e doc/book/en/A020-tutorial.en.txt --- a/doc/book/en/A020-tutorial.en.txt Mon Dec 22 19:10:38 2008 +0100 +++ b/doc/book/en/A020-tutorial.en.txt Mon Dec 22 19:54:30 2008 +0100 @@ -5,18 +5,20 @@ Quick overview of `CubicWeb` ============================ -`CubicWeb` allows us to develop web applications instances based on -one or more `cubes`. +`CubicWeb` is a semantic web application framework that favors reuse and +object-oriented design. + +A `cube` is a component that includes a model defining the data types and a set of +views to display the data. -What we call a `cube` is a model defining the data types and views. -A `cube` is a reusable component grouped with others cubes in the file -system. +An application is a `cube`, but usually an application is built by assembling +a few smaller cubes. -An `instance` refers to a specific installation of one or more `cubes` - where are grouped configuration files of the final web application. +An `instance` is a specific installation of an application and includes +configuration files. -In this document, we will show you how to create a `cube` and how to use it -in an `instance` for your web application. +This tutorial will show how to create a `cube` and how to use it as an +application to run an `instance`. .. include:: A02a-create-cube.en.txt .. include:: A02b-components.en.txt diff -r 843e0b1bf991 -r 0575e7973c5e doc/book/en/A02a-create-cube.en.txt --- a/doc/book/en/A02a-create-cube.en.txt Mon Dec 22 19:10:38 2008 +0100 +++ b/doc/book/en/A02a-create-cube.en.txt Mon Dec 22 19:54:30 2008 +0100 @@ -3,19 +3,19 @@ Create your cube ---------------- -After you installed your `CubicWeb` development environment, you can start -to build your first cube: :: +Once your `CubicWeb` development environment is set up, you can create a new +cube:: cubicweb-ctl newcube blog -This will create in ``/path/to/forest/cubes`` a directory containing: :: +This will create in ``/path/to/forest/cubes`` a directory named ``blog`` containing:: blog/ | |-- data/ | |-- cubes.blog.css | |-- cubes.blog.js - | |-- external_resources + | `-- external_resources | |-- debian/ | |-- changelog @@ -23,13 +23,13 @@ | |-- control | |-- copyright | |-- cubicweb-blog.prerm - | |-- rules + | `-- rules | |-- entities.py | |-- i18n/ | |-- en.po - | |-- fr.po + | `-- fr.po | |-- __init__.py | @@ -37,7 +37,7 @@ | |-- migration/ | |-- postcreate.py - | |-- precreate.py + | `-- precreate.py | |-- __pkginfo__.py | @@ -51,30 +51,27 @@ | |-- test/ | |-- data/ - | |-- bootstrap_cubes + | | `-- bootstrap_cubes | |-- pytestconf.py | |-- realdb_test_blog.py - | |-- test_blog.py + | `-- test_blog.py | - |-- views.py - -Any changes applied to your data model should be done in this -directory. + `-- views.py .. _DefineDataModel: -Define your data schema ------------------------ +Define your data model +---------------------- -The data model or schema is hte core of your `CubicWeb` application. -This is where is defined the type of content you application will handle. +The data model or schema is the core of your `CubicWeb` application. +It defines the type of content your application will handle. -The data model is defined in the file ``schema.py`` of your cube -``blog`` such as follows. +The data model of your cube ``blog`` is defined in the file ``schema.py``: :: from cubicweb.schema import format_constraint + class Blog(EntityType): title = String(maxsize=50, required=True) description = String() @@ -107,7 +104,7 @@ Create your instance -------------------- -:: +To use this cube as an application and create a new instance named ``blogdemo``, do:: cubicweb-ctl create blog blogdemo @@ -116,48 +113,46 @@ which will contain all the configuration files required to start you web application. -The instance ``blogdemo`` is based on the cube ``blog``. - - -Welcome in your web application +Welcome to your web application ------------------------------- -Run your application with the following command: :: +Start your application in debug mode with the following command: :: cubicweb-ctl start -D blogdemo -You can now access to your web application to create blogs and post messages -by visitin the URL http://localhost:8080/. -A login form will first be prompted. By default, the application will not allow -anonymous user to get in the application. You should then use the admin -account you created at the time you initialized the database with -``cubicweb-ctl create``. +You can now access your web application to create blogs and post messages +by visiting the URL http://localhost:8080/. + +A login form will appear. By default, the application will not allow anonymous +users to enter the application. To login, you need then use the admin account +you created at the time you initialized the database with ``cubicweb-ctl +create``. .. image:: images/login-form.png Once authenticated, you can start playing with your application -and create entities. Bravo! +and create entities. .. image:: images/blog-demo-first-page.png -Please notice that so far, `CubicWeb` franework managed all aspects of -the web application based in the schema provided at first. +Please notice that so far, the `CubicWeb` franework managed all aspects of +the web application based on the schema provided at first. -Create entities ---------------- +Add entities +------------ -We will now create a couple of entities in our web application. +We will now add entities in our web application. -Create a Blog -~~~~~~~~~~~~~ +Add a Blog +~~~~~~~~~~ -Let us create a few of these entities. Click on the `[+]` at the right -of the link Blog. Call this new Blog ``Tech-blog`` and type in -``everything about technology`` as the description, then validate the -form by clicking on ``Validate``. +Let us create a few of these entities. Click on the `[+]` at the left of the +link Blog on the home page. Call this new Blog ``Tech-blog`` and type in +``everything about technology`` as the description, then validate the form by +clicking on ``Validate``. .. image:: images/cbw-create-blog.en.png :alt: from to create blog @@ -182,10 +177,10 @@ .. image:: images/cbw-list-two-blog.en.png :alt: displaying a list of two blogs -Create a BlogEntry -~~~~~~~~~~~~~~~~~~ +Add a BlogEntry +~~~~~~~~~~~~~~~ -Get back to the home page and click on [+] at the right of the link +Get back to the home page and click on [+] at the left of the link BlogEntry. Call this new entry ``Hello World`` and type in some text before clicking on ``Validate``. You added a new blog entry without saying to what blog it belongs. There is a box on the left entitled @@ -240,7 +235,7 @@ A view is applied on a `result set` which contains a set of entities we are trying to display. `CubicWeb` uses a selector -mecanism which computes a score used to identify which view +mechanism which computes a score used to identify which view is the best to apply for the `result set` we are trying to display. The standard library of selectors is in ``cubicweb.common.selector`` and a library of methods used to diff -r 843e0b1bf991 -r 0575e7973c5e doc/book/en/A02b-components.en.txt --- a/doc/book/en/A02b-components.en.txt Mon Dec 22 19:10:38 2008 +0100 +++ b/doc/book/en/A02b-components.en.txt Mon Dec 22 19:54:30 2008 +0100 @@ -5,24 +5,24 @@ Cubes ----- -What is a cube -~~~~~~~~~~~~~~ +What is a cube ? +~~~~~~~~~~~~~~~~ A cube is a model grouping one or more entity types and/or views associated in order to provide a specific feature or even a complete application using others cubes. + You can decide to write your own set of cubes if you wish to re-use the -entity types you develop. By default, LAX comes with its owns set of cubes -that you can start using right away. +entity types you develop. Lots of cubes are available from the `CubicWeb +Forge`_ under a free software license. +.. _`CubicWeb Forge`: http://www.cubicweb.org/project/ Standard library ~~~~~~~~~~~~~~~~ -A library of standard cubes is part of the `LAX` release (look at -``lax/skel/ginco-apps``). Cubes provide entities and views. With -``lax-0.4``, you should get a set of application entities and system -entities you can re-use. +A library of standard cubes is part of the `CubicWeb` release (look at the +output of ``cubicweb-ctl list``). Cubes provide entities and views. The available application entities are: @@ -36,7 +36,6 @@ * classtags: Tag (to tag anything) - * file: File (to allow users to upload and store binary or text files) * link: Link (to collect links to web resources) @@ -56,7 +55,6 @@ * comment: Comment (to attach comment threads to entities) - Adding comments to BlogDemo ~~~~~~~~~~~~~~~~~~~~~~~~~~~~