Statistics
| Branch: | Tag: | Revision:

root / Changelog @ d2db2d69

History | View | Annotate | Download (28.7 kB)

1
.. _Changelog:
2

    
3
Unified Changelog file for Synnefo versions >= 0.13
4
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
5

    
6
Since v0.13 most of the Synnefo components have been merged into a single
7
repository and have aligned versions.
8

    
9
v0.15rc5
10
========
11

    
12
Released: UNRELEASED
13

    
14
Astakos
15
-------
16

    
17
* Fix request authorisation code failures due to Unicode issue:
18
  https://code.grnet.gr/issues/4971
19

    
20
Pithos
21
------
22

    
23
* Extend API to optionally enforce a specific content disposition type
24
  in view and public requests: https://code.grnet.gr/issues/5019
25

    
26
* Fix bulk operation (delete/copy/move) failures in overpopulated
27
  containers/folders: https://code.grnet.gr/issues/5119
28

    
29
* Fix performance issue due to missing index
30

    
31
.. _Changelog-0.15rc4:
32

    
33
v0.15rc4
34
========
35

    
36
Released: Wed Jan 15 10:56:10 EET 2014
37

    
38
Synnefo-wide
39
------------
40

    
41
* Integrate Pithos tests in continuous integration.
42

    
43
* Change astakosclient to accept AUTH_URL instead of BASE_URL
44
  ASTAKOS_BASE_URL settings has been removed from Pithos and Cyclades
45
  and has been replaced with ASTAKOS_AUTH_URL. Both Pithos and Cyclades
46
  proxy the Astakos services under ASTAKOS_PROXY_PREFIX path.
47
  ASTAKOS_PROXY_PREFIX by default has a value of '_astakos'.
48
  More specifically, Astakos' identity service is proxied under
49
  '_astakos/identity', Astakos' account service is under '_astakos/account'
50
  and Astakos' ui service is under '_astakos/ui'.
51

    
52
* Add 'mail_admins' handler to 'django.request' logger in order to send email
53
  notifactions to users listed in 'ADMINS' setting about unhandled exceptions
54
  in the code.
55

    
56
* Extend astakosclient to request and validate OAuth 2.0 access tokens
57

    
58
* Change response status code from 400 (Bad Request) to 405 (Not allowed
59
  method) in case of an unexpected request method.
60

    
61
Astakos
62
-------
63

    
64
* Changes in project schema:
65

    
66
  * A Project entry is created when submitting an application for a new
67
    project, rather than on approval. Its state is dependent on the state
68
    of its `reference' application (current definition). Lock Project rather
69
    than Chain (the latter is semantically obsolete).
70

    
71
  * Project states "Active - Pending" and "Suspended - Pending" have been
72
    removed. In management command `project-list', the existence of a pending
73
    modification is indicated by a non-blank `Pending AppID'.
74

    
75
  * Improve recording of project, application, and membership actions.
76

    
77
* Implement API calls for projects.
78

    
79
* Store the base URL of a component. Deployer should provide it when adding
80
  a new component. Service endpoints originating from a component are
81
  expected to match its base URL; otherwise, a warning is issued.
82
  Re-registration with `snf-component-register' affects both the base and
83
  the ui URL.
84

    
85
* Changes in resource and quota handling:
86

    
87
  * New resources are registered with unlimited default base quota,
88
    represented by 2**63-1.
89
  * Each newly accepted user copies the default value for all resources
90
    as their own base quota. A base quota is considered 'custom' if its
91
    value differs from the default.
92
  * Changing resource's default quota affects the base quota *only* of
93
    future users.
94
  * Resource definition got flags 'api_visible' and 'ui_visible',
95
    replacing flag 'allow_in_projects'. They control whether a user can
96
    access these resources. The system internally always accounts for
97
    all resources, and a user can get off quota even for a resource that
98
    is not visible.
99

    
100
* Remove API call GET /account/v1.0/authenticate in favor of
101
  POST /identity/v2.0/tokens.
102

    
103
* Export basic statistics about Astakos service from '/admin/stats/detail' API
104
  endpoint. Access to this endpoint is only allowed to users that belong to
105
  the Astakos groups that are defined in the
106
  'ASTAKOS_ADMIN_STATS_PERMITTED_GROUPS' setting. Statistics are also availble
107
  from 'snf-manage stats-astakos' management command.
108

    
109
* Implement OAuth 2.0 Authorization Code Grant
110
  Add API calls for authorization code and access token generation
111

    
112
* Add API call for validating OAuth 2.0 access tokens
113

    
114
* **Shibboleth module** Extract unique identifier from the
115
  ``REMOTE_USER`` header.
116

    
117
* Automatically fill third party signup form fields when available by the
118
  the third party provider.
119

    
120
* Omit validation issues for non-required metadata values received from the 
121
  third party authentication provider.
122

    
123
* Management commands:
124

    
125
  * Introduced new commands:
126
	* component-show
127
	* quota-list (replacing quota, supports various filters)
128
	* quota-verify (replacing quota)
129
	* oauth2-client-add (register OAuth 2.0 client)
130
	* oauth2-client-list (list registered oauth 2.0 clients)
131
	* oauth2-client-remove (remove OAuth 2.0 client)
132
  * Changed commands:
133
	* component-add got options --base-url and --ui-url
134
	* resource-modify --limit became --default-quota
135
	* user-modify can operate on multiple users with --all and --exclude
136
	* user-modify --set-base-quota became --base-quota
137
  * Removed commands:
138
	* quota
139
	* resource-import (subsumed by service-import)
140
	* resource-export-astakos (subsumed by service-export-astakos)
141

    
142
Cyclades
143
--------
144

    
145
* Major changes to Cyclades networks:
146

    
147
  * Implement 'cyclades_network' service, containing the /networks, /ports,
148
    /subnets and /floatingips API endpoints under '/network/v2.0'. The old
149
    /networks API of 'cyclades_compute' (under /compute/v2.0) is
150
    removed.
151
  * Implement `snf-manage subnet-{create, list, modify, inspect}' management
152
    commands for handling of subnets.
153
  * Implement `snf-manage port-{create, list, remove, inspect}' management
154
    commands for handling of ports.
155
  * Add two new settings, 'CYCLADES_FORCED_SERVER_NETWORKS' and
156
    'CYCLADES_DEFAULT_SERVER_NETWORKS' to control the networks that newly
157
    created servers will be connected.
158

    
159
* Implement Floating IP addresses, which are IPv4 addresses that can be
160
  dynamically added and removed to a running server.
161

    
162
  * Add new 'cyclades.floating_ip' resource.
163
  * Implement 'snf-manage floating-ip-{create,list,remove,attach,detach}'
164
    management commands to handle floating IPs.
165
  * Add 'floating_ip_pool' attribute to networks to mark networks that can
166
    be used as floating IP pools.
167

    
168
* Implement 'resize' server action.
169

    
170
  * Implement the 'resize' server action, to change the flavor of a server.
171
    Only 'cpu' and 'memory' resizing is supported.
172

    
173
* Compute quotas for CPU and memory of running vms.
174

    
175
  * Change 'cyclades.cpu' and 'cyclades.ram' resources to represent the CPU
176
    and RAM for running VMs. Total CPU and RAM usage is represented by new
177
    'cyclades.total_cpu' and 'cyclades.total_ram' resources.
178

    
179
* Refer to Ganeti NICs by their name instead of their index.
180

    
181
  * Make cyclades give a unique name to each Ganeti NIC. NICs are refered by
182
    their unique name and not by their index inside the VM that are connected
183
    to.
184

    
185
* Support firewall profile for all NICs of an instance. Change firewall
186
  settings to be filled with the unique name of the NIC. The affected settings
187
  are the GANETI_FIREWALL_{ENABLED, DISABLED, PROTECTED}_TAG settings.
188
* Add accounting for public IP addresses that is accessible via `snf-manage
189
  ip-list` management command and via the helpdesk app.
190
* Implement IPv6 only networks.
191
* Extend servers info API response with 'SNF:fqdn' attribute, and introduce
192
  CYCLADES_SERVERS_FQDN to set the template for servers FDQN. Remove
193
  'UI_VM_HOSTNAME_FORMAT' setting.
194
* Extend servers info API response with 'SNF:port_forwarding' attribute,
195
  describing port fowarding rules (DNAT) that are applied to vms. The
196
  description of such rules is done via the new CYCLADES_PORT_FORWARDING
197
  setting.
198
* Speed up server reconciliation, by performing parallel reconciliation for
199
  each backend.
200
* Change --dhcp option of network management commands from a flag to a boolean
201
  value, e.g. --dhcp=True
202
* Remove 'ARCHIPELAGO_BACKENDS' setting used to distinquish between backends
203
  that hosted only archipelago backends. Instead allocation is based on which
204
  disk-templates are enabled in each backend.
205
* Implement 'snf-manage server-remove' management command.
206
* Move reconciliation of IP pools from 'reconcile-networks' to
207
  'reconcile-pools'. The IP pool reconciliation does not reconcile the IP
208
  pools with Ganeti. Instead it checks if the pool is consistent with the
209
  IPs that are used by instances.
210
* Do not automatically release externally reserved IPs if they are released
211
  from a Ganeti backend. Management of externally reserved IPs must be
212
  performed from Cyclades with 'network-modify' command.
213
* Export basic statistics about Cyclades Service from '/admin/stats/detail'
214
  API endpoint. Access to this endpoint is only allowed to users that belong
215
  to the Astakos groups that are defined in the 'ADMIN_STATS_PERMITTED_GROUPS'
216
  setting.  Statistics are also availble from 'snf-manage stats-cyclades'
217
  management command.
218
* Support enforcing quota through command 'enforce-resources-cyclades'.
219
* Remove command 'resource-export-cyclades' subsumed by
220
  'service-export-cyclades'.
221
* Obsolete PUBLIC_USE_POOL setting, since Cyclades manages IP pool for all
222
  type of networks.
223
* Encrypt / decrypt the instance id / hostname in the  stats URL in
224
  snf-cyclades-app and snf-stats-app, using the 'CYCLADES_STATS_SECRET_KEY'
225
  and 'STATS_SECRET_KEY' respectively.
226
* Add support for snf-vncauthproxy-1.5 and the setting
227
  'CYCLADES_VNCAUTHPROXY_OPTS', which configures the extra options / arguments
228
  needed by the newer version of snf-vncauthproxy. Support for older versions
229
  of snf-vncauthproxy has been dropped. See also the upgrade notes for Synnefo
230
  and snf-vncauthproxy-1.5.
231
* Remove 'DEFAULT_ROUTING_TABLE' setting. If a link for an IP_LESS_ROUTED
232
  network is not specified, the link will be uniquely named
233
  'snf-link-$network_id'.
234
* Extend flavors with 'allow_create' attribute. Flavors that have this
235
  attribute unset cannot be used by users to create new servers.
236

    
237

    
238
Cyclades UI
239
-----------
240

    
241
- Retrieve all networks information from the introduced cyclades network
242
  service.
243
- New IPs pane from which user can manage floating IPs.
244
- Redesign public keys overlay as an additional pane view.
245
- Split networking configuration into an additional step in machine create
246
  wizard.
247
- Display forced networks and choices of the available floating IPs which will
248
  be assigned to the created machine.
249
- Support for machine resize action. Explicit handling when machine is started
250
  by displaying an utility shutdown button within the resize overlay.
251
- Machine IPs toggling subview in icon/single views.
252
- Replace IPv4/IPv6 with machine's FQDN in icon/single view. When no FQDN can
253
  be resolved display a message. Message can be configured using the introduced
254
  ``UI_NO_FQDN_MESSAGE``. Setting ``UI_VM_HOSTNAME_FORMAT`` has been removed
255
  and no longer used.
256
- Respect ``SNF:task_state`` machine attribute in order to improve machine
257
  status display.
258
- Append software version as a url parameter in HTML static files in order
259
  to force browser cache invalidation between versions.
260
- Configurable Google fonts base url. Fonts base url can be changed usint the
261
  ``SYNNEFO_FONTS_BASE_URL`` setting.
262
- Regression fix: Display reboot required notification on machine firewall
263
  parameters.
264
- Handling of ``GANETI_USE_HOTPLUG`` setting. Do not allow live network actions
265
  when setting is set to ``False``.
266
- Double escaping fix in machine create wizard images list and machine details
267
  subview.
268
- Fix image ordering in machine create wizard.
269
- New setting ``UI_SSH_SUPPORT_OSFAMILY_EXCLUDE_LIST``. A list of image OS
270
  families for which ui will disable ssh key injection in machine wizard.
271
- Setting ``UI_SUPPORT_SSH_OS_LIST`` removed and no longer used.
272
- Group public networks by name if setting ``UI_GROUP_PUBLIC_NETWORKS`` is set 
273
  to True.
274
- Setting ``UI_GROUPED_PUBLIC_NETWORK_NAME`` has been deprecated and no longer 
275
  used.
276

    
277

    
278
Cyclades Userdata
279
-----------------
280

    
281
- Maximum allowed length of ssh key content. Configurable from the 
282
  ``USERDATA_SSH_KEY_MAX_CONTENT_SIZE`` setting.
283

    
284

    
285
Pithos
286
------
287

    
288
* Rewrite tests.
289
* Performance optimizations in object listing.
290
* Introduce backend method decorator for handling transaction management if no
291
  transaction is initiated from the frontend.
292
* Fix Internal Server Errors https://code.grnet.gr/issues/4501 &
293
  https://code.grnet.gr/issues/4502.
294
* Fix REQUEST ENTITY TOO LARGE request failure during move operations
295
  https://code.grnet.gr/issues/4154.
296
* Fix FORBIDDEN request failure while listing implicitly shared objects
297
  https://code.grnet.gr/issues/4131.
298
* Fix issue with the computed size of an updated object.
299
* Reply with the Merkle hash in the ETag header if MD5 is deactivated.
300
* Reply with FORBIDDEN (403) to public listing requests performed by non path
301
  owners.
302
* Change response status to NOT FOUND (404) while trying to delete an
303
  already deleted object.
304
* Change SQLAlchemy version to 0.7
305
* Change view authorization
306
  The pithos views do not use the cookie information for user authentication.
307
  They request (from Astakos) and use a short-term access token for a
308
  specific resource.
309
* Remove PITHOS_ASTAKOS_COOKIE_NAME setting, since it is no longer useful
310
* Add PITHOS_OAUTH2_CLIENT_CREDENTIALS setting to authenticate the views with
311
  astakos during the resource access token generation procedure
312
* Add PITHOS_UNSAFE_DOMAIN setting to restrict file serving endpoints to a
313
  specific host
314
* Added new 'file-show' management command
315
* Remove command 'resource-export-pithos' subsumed by 'service-export-pithos'.
316

    
317
.. _Changelog-0.14.10:
318

    
319
v0.14.10
320
=======
321

    
322
Released: Tue Nov 26 11:03:37 EET 2013
323

    
324
Cyclades
325
-------
326

    
327
* This is the first release to support Ganeti 2.8. Support for older versions
328
  of Ganeti is dropped.
329
* Use Ganeti opportunistic locking to achive parallelized instance creations
330
  in the same backend. Add setting 'GANETI_USE_OPPORTUNISTIC_LOCKING' to
331
  enable the use of this feature.
332
* Fix warning message while getting object permissions to appear only when
333
  path is None and the object has permissions
334
* Add name to newly created NICs and the corresponding firewall tags.
335

    
336
.. _Changelog-0.14.9:
337

    
338
v0.14.9
339
=======
340

    
341
Released: Mon Nov 11 12:13:31 EET 2013
342

    
343
* Astakos: Fix minor problems with logging in the Astakos module, which could
344
  lead to unexpected exceptions
345

    
346
.. _Changelog-0.14.8:
347

    
348
v0.14.8
349
=======
350

    
351
Released: Fri Nov  8 17:25:08 EET 2013
352

    
353
Synnefo-wide
354
------------
355

    
356
* This is the first release to support Debian Wheezy along with Squeeze. You
357
  can mix and match nodes freely.
358
* Update Django dependency to Django>=1.2,<1.5. Django 1.4.5 is available for
359
  Squeeze through squeeze-backports.
360
* Since this version, Synnefo ships an example Gunicorn configuration file
361
  that is automatically installed at ``/etc/gunicorn.d/synnefo.example``.
362

    
363
Cyclades
364
--------
365

    
366
* On VM creation, pass the hashmap of the image (pithosmap://) instead of the
367
  image URL (pithos://). Access to the Pithos DB by Ganeti nodes is no longer
368
  required.
369
* Workaround race between server creation and server deletion. This will be
370
  fixed properly by updating Ganeti to support the 'depends' attribute for
371
  OP_INSTANCE_REMOVE.
372

    
373
Astakos
374
-------
375

    
376
* For Shibboleth logins, store all attributes along with the user in the DB.
377

    
378
.. _Changelog-0.14.7:
379

    
380
v0.14.7
381
=======
382

    
383
Released: Wed Sep 18 17:50:12 EEST 2013
384

    
385
Cyclades
386
--------
387

    
388
* Fix bug in helpdesk view
389

    
390
.. _Changelog-0.14.6:
391

    
392
v0.14.6
393
=======
394

    
395
Released: Wed Sep 18 16:18:58 EEST 2013
396

    
397
Pithos
398
------
399

    
400
* Substitute the PITHOS_BACKEND_QUOTA setting with two
401
  distinct settings: PITHOS_BACKEND_ACCOUNT_QUOTA &
402
  PITHOS_BACKEND_CONTAINER_QUOTA
403
* Set PITHOS_BACKEND_CONTAINER_QUOTA default value to 0 (unlimited)
404
* Fix bug that resulted in DB deadlocks.
405

    
406
Cyclades
407
--------
408

    
409
* Fix bug in snf-dispatcher that resulted in servers to be deleted from the
410
  DB even if the corresponding Ganeti job failed.
411

    
412
Branding
413
--------
414

    
415
* Add new BRANDING_FOOTER_EXTRA_MESSAGE setting.
416

    
417

    
418
.. _Changelog-0.14.5:
419

    
420
v0.14.5
421
=======
422

    
423
Released: Wed Aug  7 11:19:49 EEST 2013
424

    
425
Pithos
426
------
427

    
428
* Fix security issue with handling Pithos versions.
429

    
430

    
431
.. _Changelog-0.14.4:
432

    
433
v0.14.4
434
=======
435

    
436
Released: Mon Jul 29 12:24:22 EEST 2013
437

    
438
Pithos
439
------
440

    
441
* Fix bug in reconcile resources management command.
442

    
443

    
444
.. _Changelog-0.14.3:
445

    
446
v0.14.3
447
=======
448

    
449
Released: Thu Jul 25 12:22:47 EEST 2013
450

    
451
Synnefo-wide
452
------------
453

    
454
* Use the SYNNEFO_TRACE environmental variable to control whether the greenlet
455
  tracing code will get loaded or not.
456
* Split the HIDDEN_COOKIES setting in HIDDEN_HEADERS and HIDDEN_COOKIES, and
457
  add the MAIL_MAX_LEN setting, to limit the mail size for unhandled
458
  exceptions.
459

    
460

    
461
.. _Changelog-0.14.2:
462

    
463
Released: Fri Jul 12 13:13:32 EEST 2013
464

    
465
v0.14.2
466
=======
467

    
468
Cyclades
469
--------
470

    
471
* Add new setting PITHOS_BACKEND_POOL_SIZE, which configures the size
472
  of the pool of Pithos backends that are used by plankton.
473

    
474
Pithos
475
------
476

    
477
* Refactor metadata schema (table attributes) in Pithos DB to speedup current
478
objects by domain attribute. This is used by Plankton for listing VM images.
479

    
480

    
481
.. _Changelog-0.14:
482

    
483
v0.14
484
=====
485

    
486
Released: Tue Jun 25 14:01:19 EEST 2013
487

    
488
Synnefo-wide
489
------------
490

    
491
* Create 'snf_django' Python package to hold common code for all Synnefo
492
  components.
493

    
494
* Create a JSON-exportable definition document for each Synnefo Components
495
  (Astakos, Cyclades, Pithos, etc.) that consolidates APIs (services),
496
  resources, and other standardized properties (e.g. default URL prefixes).
497

    
498
* Standardize URLs for Synnefo Components, impose structure and naming
499
  conventions to related settings. Make each component deployable under
500
  a user-configurable <COMPONENT>_BASE_URL. Each API (compute, image, etc.)
501
  is deployable under a developer-configurable prefix beneath BASE_URL.
502

    
503
* Deprecate CLOUDBAR_ACTIVE_SERVICE setting from all apps.
504

    
505
* Common synnefo 404/500 templates (located in snf-webproject)
506

    
507
Astakos
508
-------
509

    
510
* Redesign of the accounting system (quotaholder) and integration into
511
  Astakos.
512

    
513
  * Simplified the quotaholder model; removed tables Entity and Policy; now
514
    table Holding contains limit and usage for every holding.
515
  * Extended table Holding, so that we can keep track of quota for every
516
    valid combination of holder (e.g. user), resource, and source (e.g. the
517
    default system or some specific project).
518
  * Refactored code for issuing and resolving commissions for robustness;
519
    added a 'force' option to bypass the upper limit check when issuing a
520
    commission.
521
  * Simplified syncing to the quotaholder; removed fields from models
522
    Project and ProjectMembership, previously needed for syncing; removed
523
    state PROJECT_DEACTIVATED from ProjectMembership.
524
  * Removed settings ASTAKOS_QUOTAHOLDER_URL, ASTAKOS_QUOTAHOLDER_TOKEN,
525
    and ASTAKOS_QUOTAHOLDER_POOLSIZE.
526

    
527
* API-related changes:
528

    
529
  * Implemented API calls for quota, resources, and commissions.
530
  * Moved all API calls under '/account/v1.0'.
531
  * Implemented the keystone API call POST /tokens under '/identity/v2.0'.
532

    
533
* Service and resource specification and handling:
534

    
535
  * Specified a format for defining services along with the API endpoints
536
    and the resources they expose. Migrated internal resource name by
537
    prefixing it with service name (e.g. 'vm' becomes 'cyclades.vm');
538
    renamed registered service 'pithos+' to 'pithos'.
539
  * Specified a procedure to register a Synnefo component, its services and
540
    their resources in astakos and set the resources' default base quota
541
    limit. Removed resource definitions from settings.
542
  * Moved service and resource presentation data out of the respective db
543
    models into a separate file of UI constants.
544

    
545
* Converted the limit on pending applications from a setting to a quotable
546
  resource. Converted the related user setting to a user-specific base quota
547
  limit. Deprecated model UserSetting; removed setting
548
  ASTAKOS_PENDING_APPLICATION_LIMIT.
549

    
550
* Changes in locking strategy:
551

    
552
  * Lock only project's chain for all project operations; lock user before
553
    syncing to quotaholder.
554
  * When locking multiple rows (e.g. users or holdings) include an ORDER BY
555
    clause in the query to impose ordering on locking.
556

    
557
* Changes in views:
558

    
559
  * Replaced custom transaction context with a simple decorator for managing
560
    transactions and a context 'ExceptionHandler', which logs and suppresses
561
    exceptions
562

    
563
* Added fine grain user auth provider's policies.
564

    
565
  * Administrator can override default auth provider policies to a specific
566
    user or group of users.
567
  * Optionally a user can be assigned to a list of groups, based on the
568
    authentication method he choosed to signup.
569

    
570
* Removed explicit handling of SMTP errors on each email delivery. Exceptions
571
  are now propagated to base django exception handler.
572

    
573
* Email used in html/email tempaltes which prompt user to contact for service
574
  support prompts is now defined in ``CONTACT_EMAIL`` setting introduced in
575
  snf-common settings.
576

    
577
* Improvements in user activation flow
578

    
579
  * User moderation now takes place after the user has verified his email
580
    address.
581
  * User model enriched with additional user state fields
582
  * Split activation email from moderation process. Administrator is required
583
    to moderate user explicitly using the `user-modify --accept` or
584
    `user-modify --reject` commands.
585
  * Improved logging throught out user activation procedures.
586

    
587
* Remove deprecated AstakosUser model fields: `provider`,
588
  `third_party_identifier`
589

    
590
* Allow override of authentication provider messages using the following
591
  format in setting names: ``ASTAKOS_<PROVIDER_MODULE>_<MSGID>_MSG``
592

    
593
* Cloudbar automatically tries to identify the active service based on window
594
  location.
595

    
596
* Removing authentication provider view is now CSRF protected.
597

    
598
* New `API access` view, containing useful information to users on how to
599
  access available Synnefo services API's.
600

    
601
* Remove of ASTAKOS_*_EMAIL_SUBJECT settings. All email subjects are now
602
  defined in astakos.im.messages module. Overriding default values can be
603
  achieved using custom gettext files or using astakos messages settings::
604

    
605
	#change of greeting email subject
606
  	ASTAKOS_GREETING_EMAIL_SUBJECT_MESSAGE = 'Welcome to my cloud'
607

    
608
* Remove ``ASTAKOS_ACTIVATION_REDIRECT_URL`` and ``ASTAKOS_LOGIN_SUCCESS_URL``
609
  from astakos .conf file. Settings are dynamically computed based on
610
  ``ASTAKOS_BASE_URL``.
611

    
612
* Management commands:
613

    
614
  * Introduced new commands:
615
     * authpolicy-{add, list, remove, set, show}
616
     * group-{add, list}
617
     * component-{add, list, modify, remove}
618
     * reconcile-resources-astakos
619
     * resource-{export-astakos, import, modify}
620
     * service-{export-astakos, import, show}
621
  * Renamed commands:
622
     * astakos-quota to quota
623
     * user-update to user-modify
624
     * full-cleanup to cleanup-full
625
  * Removed commands:
626
     * astakos-init
627
     * invitation-{details, list}
628
     * project-sync
629
     * resource-{add, remove}
630
     * service-{add, remove, token-renew, update}
631
     * user-invite
632
     * user-set-initial-quota (integrated its functionality in user-modify and quota)
633
  * Added quota and project-related information in user-show command; added
634
    membership information in project-show.
635

    
636
Cyclades
637
--------
638

    
639
* Make 'type' attribute required for network create API request.
640
* Networks not created to all Ganeti backends upon creation, they are instead
641
  created to a backend only when a VM connects to the network.
642
* Add 'CYCLADES_ASTAKOSCLIENT_POOLSIZE' setting which tunes the size of the
643
  http connection pool to astakos.
644
* Remove 'CYCLADES_USER_CATALOG_URL' and 'CYCLADES_USER_FEEDBACK_URL' settings
645
* Remove CYCLADES_USE_QUOTAHOLDER, CYCLADES_QUOTAHOLDER_TOKEN,
646
  CYCLADES_QUOTAHOLDER_URL, CYCLADES_QUOTAHOLDER_POOLSIZE settings
647
* Rename 'cyclades-usage-verify' management command to
648
  'reconcile-resources-cyclades'. Also, remove 'cyclades-usage-reset' command,
649
  which is equivalent to 'reconcile-resources-cyclades --fix'.
650
* Rename 'cyclades-reconcile-commissions' management command to
651
  'reconcile-commissions-cyclades'.
652
* Remove obsolete 'MAX_VMS_PER_USER', 'MAX_NETWORKS_PER_USER',
653
  "VMS_USER_QUOTA" and "NETWORKS_USER_QUOTA" settings, since their usage
654
  is covered by Quotaholder.
655
* Remove obsolete setting 'API_ROOT_URL', since it is being covered by
656
  the use of CYCLADES_BASE_URL* Remove obsolete setting 'API_ROOT_URL', since
657
  it is being covered by 'CYCLADES_BASE_URL'.
658
* Remove obsolete settings GANETI_DISK_TEMPLATES and
659
  DEFAULT_GANETI_DISK_TEMPLATE
660

    
661
Cyclades helpdesk
662
-----------------
663

    
664
* Additional start/stop vm action
665
* Display extend backend info in vm's view
666
* Fixed IP lookup
667

    
668
Pithos
669
------
670

    
671
* Remove PITHOS_AUTHENTICATION_USERS setting, which was used to override
672
  astakos users.
673
* Remove 'PITHOS_USER_CATALOG_URL', 'PITHOS_USER_FEEDBACK_URL' and
674
  'PITHOS_USER_LOGIN_URL' settings.
675
* Remove PITHOS_USE_QUOTAHOLDER, PITHOS_QUOTAHOLDER_URL,
676
  PITHOS_QUOTAHOLDER_TOKEN and PITHOS_ASTAKOSCLIENT_POOLSIZE
677

    
678
* Enforce container-level atomicity in (most) Pithos API calls.
679

    
680

    
681
Tools
682
-----
683

    
684

    
685
.. _Changelog-0.13:
686

    
687
v0.13
688
=====
689

    
690
Released: Wed Apr 10 18:52:50 EEST 2013
691

    
692
In v0.13 the code was very heavily refactored for increased uniformity since
693
most of the Synnefo components have been merged into a single repository. Thus,
694
**just for this version** we will not document a complete Changelog (features,
695
fixes, improvements, issues, setting changes), but rather just copy from the
696
`NEWS` file with minor additions wherever needed.
697

    
698
Synnefo-wide
699
------------
700

    
701
* Support for pooling throughout Synnefo
702

    
703
  * Pooled Django DB connections, Pithos backend connections, HTTP
704
    connections using single `objpool` package
705

    
706
* Improved management commands
707

    
708
  * Unified codebase for output of tables in JSON, CSV
709

    
710
* Bring most of Synnefo code inside a single, unified repository
711

    
712
  * support automatic Python and Debian package builds for individual commits
713
  * with automatic version generation
714

    
715
* Overhauling of Synnefo settings: renames and refactoring, for increased
716
  uniformity (in progress)
717
* Deployment: Standardize on gunicorn, with gevent-based workers
718
  and use of Green threads throughout Synnefo
719
* Documentation: New scale-out guide, with distinct node roles,
720
  for mass Synnefo deployments
721

    
722
Astakos
723
-------
724

    
725
* Support multiple authentication methods
726

    
727
  * Classic (username/password), Shibboleth, LDAP/Active Directory,
728
    Google, Twitter, LinkedIn
729
  * Users can enable/disable auth methods, and switch between them
730

    
731
* Introduce a UUID as a global identifier for users, throughout Synnefo
732

    
733
  * The UUID remains constant as the user enables/disables login methods
734

    
735
* Allow users to modify their email address freely
736
* Per-user, per-resource accounting mechanism (quotaholder)
737
* Full quota support, with per-user, per-resource quotas, based on quotaholder
738
* Projects: Users can create and join Projects
739

    
740
  * Projects grant extra resources to their members
741

    
742
* UI Enhancements for quotas and projects
743

    
744
  * distinct Usage tab, showing usage of individual resources
745
  * Project management UI
746
  * New Overview page
747

    
748
* refactored/improved /login endpoint used by desktop/mobile clients.
749
  * endpoint url is now exposed by `weblogin` service
750
  * clients should use unauthenticated identity/tokens api to resolve the
751
    endpoint url
752
  * view only allows redirects to `pithos://` scheme urls
753
  * removed uuid from redirect parameters. Client should use authenticated
754
    request to identity/tokens to retrieve user uuid.
755

    
756

    
757
Cyclades
758
--------
759

    
760
* Commission resources on quotaholder/Astakos
761
* Support mass creation of flavors
762
* Support for the ExtStorage disk template in Ganeti
763
* Query and report quotas in the UI
764
* Pass VM configuration parameters over a VM-side API (`vmapi`)
765

    
766
  * Do not pass sensitive data as Ganeti OS parameters
767
  * Keep sensitive data in memory caches (memcached) and
768
    never allow them to hit the disk
769

    
770
* Display additional backend information in helpdesk machines list
771
* Allow helpdesk users to search for an account using a known machine id
772
* Helpdesk actions are now logged using the synnefo's common login
773
  infrastructure
774

    
775
UI
776
^^
777
* Removed feedback endpoint. Feedback requests delegate to astakos feedback
778
  service. ``FEEDBACK_CONTACTS``, ``FEEDBACK_EMAIL_FROM`` settings removed,
779
  and no longer used.
780
* ``UI_LOGIN_URL``, ``UI_GLANCE_URL``, ``COMPUTE_URL`` settings no longer
781
  required to be set and are dynamically computed based on ``ASTAKOS_BASE_URL``
782
  and ``CYCLADES_BASE_URL`` settings.
783
* File group is no longer included in ssh keys personality metadata sent in
784
  create vm calls.
785

    
786

    
787
Pithos
788
------
789

    
790
* Support storage of blocks on a RADOS backend, for Archipelago
791

    
792
  * new settings:
793
    PITHOS_RADOS_STORAGE, PITHOS_RADOS_POOL_BLOCKS, PITHOS_RADOS_POOL_MAPS
794

    
795
* X-Object-Public now contains full url (domain + proper component prefix +
796
  file path)
797

    
798
* Rewritten support for public URLs, with admin-selectable length
799

    
800
  * new settings:
801
    PITHOS_PUBLIC_URL_SECURITY, PITHOS_PUBLIC_URL_ALPHABET
802

    
803
* Enable pithos backend to use external quotaholder component
804

    
805
  * new settings:
806
    PITHOS_USE_QUOTAHOLDER, PITHOS_QUOTAHOLDER_URL, PITHOS_QUOTAHOLDER_TOKEN,
807
    PITHOS_QUOTAHOLDER_POOLSIZE
808

    
809
* Moderated version debiting mechanism
810

    
811
  * new setting:
812
    PITHOS_BACKEND_FREE_VERSIONING
813

    
814
* Proxy Astakos user-visible services
815

    
816
  * new settings:
817
    PITHOS_PROXY_USER_SERVICES, PITHOS_USER_CATALOG_URL,
818
    PITHOS_USER_FEEDBACK_URL, PITHOS_USER_LOGIN_URL
819

    
820
Tools
821
-----
822

    
823
* Extend snf-burnin to include testing of Pithos functionality