source: main/eko-disco-specs/trunk/data.rst @ 10748

Last change on this file since 10748 was 10747, checked in by Henrik Bettermann, 11 years ago

The system admin is not necessarily a portal user even though system admins can always access the portal through the zope.manager account.

File size: 10.4 KB
Line 
1
2.. |n0| replace:: n\ :sub:`0`
3.. |m0| replace:: m\ :sub:`0`
4
5.. _label-data-entities:
6
7Data Entities
8=============
9
10These are the data entities the new system is supposed to model. Each
11of these entities should be addable, editable, and removable as
12covered in more detail in :ref:`label-use-cases`.
13
14For each entity we give a short description to tell what it means,
15what its purpose is and in what regards (and how) it should be handled
16by the system. Again the more detailed actions on these entities
17provided by the system are described in the :ref:`label-use-cases`
18section.
19
20The data entities are sorted alphabetically, not by importance or
21similar. Used description terms should link to other respective
22entities/terms where possible.
23
24Each data entitiy description provides a list of use cases and other
25data entities connected. Connections to other data entities contain a
26relationship telling how many instances of the described entity are
27connected to how many instances of the related entity.
28
29The following relation types may occur (in both directions):
30
31  - 1:1 (one on one)
32  - n:1 (many on one)
33  - n:m (many on many)
34  - p:1 (many or none on one)
35  - p:q (many or none on many or none)
36  - p:n (many or none on many)
37  - b:1 (one or none on one)
38
39with
40
41  - n, m element of {1, 2, ...},
42  - p, q element of {0, 1, 2, ...}
43  - b element of {0, 1}
44
45Examples:
46
471:p service-contract relation means that each service
48offered can result in various contracts, but each contract is
49only based on one service.
50
51p:q user-userrole relation means that each user can have no role or
52several roles and each role can be assigned to no user or several users.
53
54Relations can always be read in two directions.
55
56.. _label-contact-address:
57
58Contact Address
59---------------
60
61A postal address.
62
63Connected to: :ref:`label-contact-data` (p:1)
64
65Used in the following use cases:
66
67
68.. _label-contact-data:
69
70Contact Data
71------------
72
73The data neccessary to contact some :ref:`label-customer`, staff
74person or similar entity. Contact data might contain several
75addresses, phone numbers, emails, etc.
76
77Connected to: :ref:`label-customer` (1:1),
78:ref:`label-contact-address` (1:p), :ref:`label-contact-email`
79(1:n), :ref:`label-contact-phone` (1:p)
80
81Used in the following use cases:
82
83
84.. _label-contact-email:
85
86Contact Email
87-------------
88
89An email address with optional additional clear name. For email
90addresses we store some timestamp that indicates when the respective
91email address was last checked successfully (thus marking it a 'valid'
92one). No timestamp means, the email address has never been checked.
93
94Connected to: :ref:`label-contact-data` (n:1),
95:ref:`label-timestamp` (1:q)
96
97Used in the following use cases:
98
99
100.. _label-contact-phone:
101
102Contact Phone
103-------------
104
105Mobile phone number which is capable of receiving sms text messages.
106
107Connected to: :ref:`label-contact-data` (p:1)
108
109Used in the following use cases:
110
111
112.. _label-contract:
113
114Contract
115--------
116
117A contract is created whenever a :ref:`label-customer` orders some
118:ref:`label-service` from the system. It is always connected to a
119:ref:`label-customer` and a :ref:`label-service` .
120
121A contract is not necessarily written on paper and signed by
122people. Instead it is an abstraction used inside the system.
123
124It is always created from a :ref:`label-service`, which tells about
125the basic data, with additional parameters set that depend on the type
126of :ref:`label-service` ordered.
127
128Contracts can trigger :ref:`label-transaction`\ s. For instance if some
129:ref:`label-customer` orders a service. When the service charges
130become due, a respective :ref:`label-transaction` is triggered.
131
132Contracts can have multiple :ref:`label-contract-addon`\ s.
133
134Connected to: :ref:`label-service` (p:1), :ref:`label-customer` (p:1),
135:ref:`label-contract-addon` (1:p), :ref:`label-transaction` (1:p),
136:ref:`label-meter` (1:b)
137
138Used in the following use cases:
139
140
141.. _label-contract-addon:
142
143Contract Addon
144--------------
145
146Kind of 'sub contract' that always belongs to some already existing
147:ref:`label-contract` but comes with an own set of
148parameters. Contract addons are created by :ref:`label-contract`\ s.
149
150Connected to: :ref:`label-contract` (p:1),
151:ref:`label-service` (p:1), :ref:`label-customer` (p:1),
152:ref:`label-transaction` (1:p)
153
154
155.. _label-customer:
156
157Customer
158--------
159
160Beneficiary of :ref:`label-contract`\ s.
161
162Customers are added to the system by initial import (migration phase),
163being created by staff or can self-register themselves to the system.
164
165Customers have to provide :ref:`label-contact-data` and get
166:ref:`label-login-credentials` to login to the system.
167
168Once logged in, customers get a 'My Eko-Disco' page where they can
169
170- see their current orders
171
172- watch their consumption
173
174- order more services
175
176- handle contractual problems
177
178- get help if problems arise
179
180- retrieve bills
181
182- change their passwords
183
184Customers can order :ref:`label-service`\ s and pay these (kinds of
185payment depend on the type of service/good ordered and the available
186payment methods).
187
188Customers and their data can be managed by customers themselves (for
189instance when postal addresses change), and by staff members.
190
191Connected to: :ref:`label-contract` (1:p),
192:ref:`label-contact-data` (1:1), :ref:`label-login-credentials` (1:1),
193:ref:`label-user` (b:1)
194
195
196.. _label-location:
197
198Location
199--------
200
201A real-world location. Used for instance for meters to store
202information about their place. The location of a meter does not necessarily
203correspond with one of the :ref:`label-contact-address`\ es.
204Locations can either be less formal, for instance describing a location
205in words, or very precise by using GPS data.
206
207Connected to: :ref:`label-meter` (1:p)
208
209
210.. _label-login-credentials:
211
212Login Credentials
213-----------------
214
215A set of username/password assigned to system users. Passwords are
216stored inside the system using strong cryptographic hash functions.
217
218Passwords can be reset on request.
219
220Connected to: :ref:`label-customer` (1:1)
221
222
223.. _label-meter:
224
225Meter
226-----
227
228A meter measures power consumption. It has a place where it is
229installed and might be connected to one or several contracts. For a
230given time a meter can be connected to one or zero contracts.
231
232Each meter has to provide a :ref:`label-location` that tells, where it
233is installed.
234
235Meters also contain a history of meter values
236(:ref:`label-meter-value`), which is basically a list of meter values
237at a given time.
238
239Connected to: :ref:`label-contract` (b:1),
240:ref:`label-meter-value` (1:n), :ref:`label-location` (p:1)
241
242
243.. _label-meter-value:
244
245Meter Value
246-----------
247
248The value of a :ref:`label-meter` at a certain point in time
249(providing a :ref:`label-timestamp`) authorized by some
250:ref:`label-user` or device.
251
252It serves mainly for computing power consumption of
253:ref:`label-customer`\ s.
254
255When a new meter value is added to the system (the respective
256:ref:`label-meter` is 'updated'), the system also registers how the
257the new value was entered, i.e. by whom and when.
258
259The system will be prepared to collect meter values in two ways:
260
261a) (push-method): by being fed with respective data by authorized
262   users (staff members)
263
264b) (pull-method): by polling dedicated hardware that provides the
265   neccessary interface (automatic remote-reading).
266
267The second choice requires appropriate hardware to be in place, which
268in detail is not part of this specs. The system will, however, be
269prepared to collect meter data from external devices.
270
271Connected to: :ref:`label-meter` (n:1), :ref:`label-timestamp` (1:1),
272:ref:`label-user` (p:1)
273
274
275.. _label-officer:
276
277Officer
278-------
279
280Officers are staff members with certain permissions to manage portal data.
281
282Actors are called :ref:`Manager <label-manager>` if they are officers with with local managing permission.
283
284Connected to: :ref:`label-login-credentials` (1:1),
285:ref:`label-user` (b:1),
286:ref:`label-user-role` (1:p)
287
288
289
290.. _label-report:
291
292Report
293------
294
295Administrative report or list to give overviews over current state of
296business. Includes lists of customers sorted by various categories
297(type of contract, amount of fees paid, etc.), lists of services
298sorted by various categories, etc.
299
300Reports are generated as PDF documents and are available for download
301by authorized :ref:`label-user`\ s.
302
303Connected to: (almost everything else)
304
305
306.. _label-service:
307
308Service
309-------
310
311The system will provide different services to
312:ref:`label-customer`\ s. These can have arbitrary forms, including
313one-time services (like installation of meters) and open-ended
314long-time services (like delivering power based on contract). Services
315are managable by staff like goods offered in a shop.
316
317Services define the conditions under which they can be ordered by
318:ref:`label-customer`\ s, including prices, runtimes, etc.
319
320Services also serve as factories for :ref:`label-contract`\ s.
321
322Connected to: :ref:`label-contract` (1:p)
323
324Used in the following use cases:
325
326
327.. _label-timestamp:
328
329Timestamp
330---------
331
332A timestamp can be a calendar date or a calendar date plus some day
333time.
334
335The system will internally use UTC-based timestamps only to minimize
336ambiguities. In menus, frontends, etc. timestamps are displayed in
337local Lagos time.
338
339Connected to: :ref:`label-meter-value` (1:1),
340:ref:`label-contact-email` (p:1)
341
342
343.. _label-transaction:
344
345Transaction
346-----------
347
348A transaction is some business-relevant action taken. A transaction
349means basically, that something happened, that leads to increased or
350decreased customer accounts. Normally this is something like a
351payment, some service order or similar.
352
353Transactions do always belong to one certain customer account. They
354also contain some amount of money which is thereby transfered to or
355from a customer's account. They also always reference a service which
356is consumed, purchased, or (pre-)paid by the respective customer.
357
358Connected to: :ref:`label-customer` (p:1), :ref:`label-service`
359(p:1), :ref:`label-contract` (p:1)
360
361Used in the following use cases:
362
363
364.. _label-user:
365
366User
367----
368
369A system user.
370
371Users can have :ref:`label-user-role`\ s managed by the
372system. Real-world staff members and customers are different to the
373system as they will have different roles. Also anonymous users are
374accepted by the system to provide marketing pages, service offers,
375etc.
376
377Each user has one set of :ref:`label-login-credentials` to authenticate
378against the system.
379
380Users can be blocked or removed from the system.
381
382Connected to: :ref:`label-login-credentials` (1:1),
383:ref:`label-customer` (1:b),
384:ref:`label-user-role` (p:q)
385
386
387.. _label-user-role:
388
389User Role
390---------
391
392A set of permissions assigned to a group of :ref:`label-user`\ s.
393
394Connected to: :ref:`label-user` (p:q)
395
Note: See TracBrowser for help on using the repository browser.