Folksonomy Engine/Functional use cases and specifications

From Open Food Facts wiki

Note: to see the prototype of each functional use case, you need to install Folksonomy Engine client script.

Open Food Facts' apps and API share some common basic meta-features:

  • Links create value: every property or value or another thing that make sense should be linked to its documentation and groups it belong to.
  • All lists should be:
    • shown as table: sortable by each column; filterable; with added statistics such as number of occurrences, percentage, etc.
    • downloadable: CSV and XLSX
    • queried with a REST API
  • All product's attributes (property/value pairs) should be queried with a REST API.
  • KISS and wiki principles:
    • Straight to the point.
    • Everything can be modified (properties, values). Modified property/value pairs are not deleted, but archived and versioned.
    • Lowering the barrier: anyone should be able to do things easily.
    • Accept as many usages as we can: fields are not constrained and anyone should enter anything as a new property or a new value. Organisation will come later.
  • If possible, main lists of products should be proposed as facets, with the possibility to be mixed with other Open Food Facts facets [create a non-blocking issue]

1. The user asks the list of properties/values pairs for a given product.

  • The user selects a product (link, search result, etc.).
  • The system shows the product, with the list of property/value pairs.

Rationale: this is the main usage of Folksonomy Engine. It allows to know that a product has some particular properties which are not in the traditional Open Food Facts data model.

Questions:

  • should this use case allow to download all the property/value pairs at one time: the ones from the traditional data model, and the ones from Folksonomy Engine ?

Prototype (beta): https://world.openfoodfacts.org/product/9310036071174/paul-s-caramel-custard

2. The user enters a new property/value pair for a given product.

  • The user selects a product (link, search result, etc.).
  • The system shows the product, with a form to enter a new property/value.
  • Eventually, the user search for an existing property corresponding to his need (see dedicated use case 6).
  • The user enters the property (see dedicated functional use case 2.1).
  • The user enters the value (see dedicated functional use case 2.2).
  • The user asks the system to save the property/value pair.
  • The system checks for user authentication [this part is not detailed].
  • The system saves the property/value pair, with some metadata: the date and time of modification, the version, the username, and optionally a comment.
  • The system archives the old property/value pair and its metadata, if any.

Rationale: to discover new properties, they have to be entered by people. Open Food Facts is a project opened to any kind of editors.

Prototype (beta): https://world.openfoodfacts.org/product/9310036071174/paul-s-caramel-custard

3. The user asks for the whole list of properties.

  • The user asks for the whole list of properties: links located:
    • somewhere near the list of properties/values pairs for a given product
    • anywhere else
  • The system shows the list of all the properties with, for each property, the number of products and the number of different values.
    • It should be a list for the given context: the list corresponding to the products present in the current context, eg. Open Products Facts (create specific non-blocking issue).

Rationale: the list of all properties allows:

  • To explore the different properties and their usages.
  • To forecast the evolution of properties and their usages.
  • To observe which are the most used and the properties which are not really used.

Prototype (beta): https://world.openfoodfacts.org/keys

4. The user asks for the whole list of products with a particular property.

  • The user asks for the whole list of products with a particular property (link from the list of properties, link from a product's page using this property).
  • The system returns:
    • The list of all products using this property; for each product: the product's barcode, optionally the product name, the product's photo, the last modification date, the editor of the property, the value.
    • The link to the property's ation.

Rationale: the list of products with a particular property allows:

  • To explore all the product with a particular property.
  • To forecast the evolution of products with a particular property.
  • To observe which are the most used and the properties which are not really used.

Prototype (beta): https://world.openfoodfacts.org/key/packaging:has_character

5. The user asks for the whole list of products with a particular property/value pair.

  • The user asks for the whole list of products with a particular property/pair (link from a product's page using this property/value pair).
  • The system returns:
    • The list of all products using this property; for each product: the product's barcode, optionally the product name, the product's photo, the last modification date, the editor of the property.
    • The link to the property's ation.

Rationale: this use case allows hundreds of new usages; eg. listing all the products that have been recalled last month; all products that are blue; etc.

Prototype (beta): https://world.openfoodfacts.org/key/packaging:has_character/value/yes

6. The user searches for an existing property corresponding to his need.

  • The user asks the system for a keyword related to his need.
  • The system list all the pages of the documentation related to this keyword; this can be:
    • pages related to properties' documentation
    • pages related to a group of properties: categories, etc.

Rationale: the suggestions made by the system in the use case 2.1, based on the property name, is not sufficient to find the relevant properties; eg. thehas_character property is namely dealing with cartoon characters: searching for cartoon won't help to find this property. Folksonomy Engine needs efficient tools to allow users reuse existing properties and not always reinvent the wheel.

2.1. The user enters a property for a given product.

  • The user starts typing the name of a property.
  • The system suggests back all properties containing these letters (beginning at the second letter).
  • The user selects a property or continues to type.
  • If the property is a new one, the system informs the user about social aspects of property creation: documentation, values, reuse, etc. It encourages the user to write the documentation of the new property, providing him the automatic link to the documentation.
  • Eventually the user documents the property (see 2.3).
  • Back to use case 2.

2.2 The user enters the value.

  • If possible, the system suggests some values based on the current values already given for the property.
  • The user starts typing the content of the value.
  • The system suggests back all current values related to this property and containing these letters (beginning at the second letter).
  • The user selects a value or continues to type.
  • Back to use case 2.

2.3 The user documents the property

[TODO]

  • The system shows the dedicated documentation page for the given property.
  • The user can specify:
    • usages
    • values
    • See also
    • the category
    • [to be completed]

Questions

  • For transparency reasons (and maybe for other reasons):
    • Should we provide a use case to let the user see the history of property/value pairs for each product? Version 2?
    • Should we provide a use case to let the users see the history of all property/value pairs for all product (something like the "recent changes" in Mediawiki/Wikipedia)? Version 2?
  • Should we immediately provide use cases related to private property/value pairs for V1?
    • Eg. my_morning_diet=yes;
    • Should these use cases take care of stocks issues?
    • Could public properties be used privately?
      • CONs: one can build a big private database with Open Food Facts resources.
    • Could private properties be used publically?
    • If private properties can only be used privately, should we clearly separate them from the private ones:
      • Show another section in the product page?
      • Name them to ensure they are private; eg. private:my_prefered_product=yes
    • Should private properties be documented as well as public properties?
    • Should some properties be necessarily private? Eg. our_prefered_product=yes
    • Should the property suggestion take care of private properties?
    • Should we adopt some limits to private usage? (to take care of common resources)
      • How would it look like? Max number of property/value pairs?
  • Should we take care of stock issues for V1?
    • Eg. I have three items of this product, one ending 2021-10-10, and two ending 2021-10-31.
  • When a new property is created, we need to inform user about social aspects of property creation: documentation, values, reuse, etc.
  • Synonyms of a property.?