forked from grnet/synnefo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Changelog
895 lines (671 loc) · 31.8 KB
/
Changelog
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
.. _Changelog:
Unified Changelog file for Synnefo versions >= 0.13
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Since v0.13 most of the Synnefo components have been merged into a single
repository and have aligned versions.
v0.15next
=========
Released: UNRELEASED
Synnefo-wide
------------
* Replace accumulative projects with pool projects:
* Projects are now viewed as a source of finite resources. A member can
reserve a part of these resources up to a specified limit.
* Base quota are now offered through a special purpose user-specific base
project, identified with the same UUID as the user.
* Each actual resource (Cyclades VM, network, floating IP and Pithos
container) is now also associated with a project besides the owner.
* In resource creation, project defaults to the user-specific base
project, if not specified otherwise. It is also possible to change the
project assignment of an existing resource.
* All existing resources have been assigned to the respective
user-specific base projects.
* Logging mechanism for Synnefo management commands
* Log all stdout and stderr output of every invocation of snf-manage,
on unique filenames under a given directory.
* Add a new setting in the snf-common package, namely 'LOG_DIR', which
specifies the directory to be used by Synnefo components to write
their log files.
Astakos
-------
* Decouple projects from applications:
* Support project creation (by the system) and modification (by a
privileged user) without the need to submit/approve an application.
* View applications as modifications. When a project is uninitialized
(e.g. an application for a new project is pending), no further
modification is allowed.
* Applications are removed from the API. A project's last application is
only accessible as part of the project details.
* Decouple project state from application state; they can be combined by
an API client, if needed.
* Changes concerning quota and pool projects:
* A project must provide limits for all registered resources. On project
activation, resources missing are automatically completed using a
skeleton.
* Field `uplimit' of registed resources is exposed as `base_default' and
provide the skeleton for user-specific base projects. A new field
`project_default' is introduce to act as a skeleton for conventional
projects.
* The quotaholder now also records project quota besides user quota. The
two types of holders are distinguished with a prefix: `user:' and
`project:'.
* The quota API is extended to make project quota available.
* Removed setting `ASTAKOS_PROJECTS_VISIBLE'; we now always display
projects in Astakos menu.
* Projects can be set `private', making it accessible only to its owner and
members.
=======
.. _Changelog-0.15:
v0.15
=====
Released: Mon Mar 10 14:01:32 EET 2014
Synnefo-wide
------------
* Integrate Pithos tests in continuous integration.
* Change astakosclient to accept AUTH_URL instead of BASE_URL
ASTAKOS_BASE_URL settings has been removed from Pithos and Cyclades
and has been replaced with ASTAKOS_AUTH_URL. Both Pithos and Cyclades
proxy the Astakos services under ASTAKOS_PROXY_PREFIX path.
ASTAKOS_PROXY_PREFIX by default has a value of '_astakos'.
More specifically, Astakos' identity service is proxied under
'_astakos/identity', Astakos' account service is under '_astakos/account'
and Astakos' ui service is under '_astakos/ui'.
* Add 'mail_admins' handler to 'django.request' logger in order to send email
notifications to users listed in 'ADMINS' setting about unhandled exceptions
in the code.
* Extend astakosclient to request and validate OAuth 2.0 access tokens
* Change response status code from 400 (Bad Request) to 405 (Not allowed
method) in case of an unexpected request method.
Astakos
-------
* Changes in project schema:
* A Project entry is created when submitting an application for a new
project, rather than on approval. Its state is dependent on the state
of its `reference' application (current definition). Lock Project rather
than Chain (the latter is semantically obsolete).
* Project states "Active - Pending" and "Suspended - Pending" have been
removed. In management command `project-list', the existence of a pending
modification is indicated by a non-blank `Pending AppID'.
* Improve recording of project, application, and membership actions.
* Implement API calls for projects.
* Store the base URL of a component. Deployer should provide it when adding
a new component. Service endpoints originating from a component are
expected to match its base URL; otherwise, a warning is issued.
Re-registration with `snf-component-register' affects both the base and
the ui URL.
* Changes in resource and quota handling:
* New resources are registered with unlimited default base quota,
represented by 2**63-1.
* Each newly accepted user copies the default value for all resources
as their own base quota. A base quota is considered 'custom' if its
value differs from the default.
* Changing resource's default quota affects the base quota *only* of
future users.
* Resource definition got flags 'api_visible' and 'ui_visible',
replacing flag 'allow_in_projects'. They control whether a user can
access these resources. The system internally always accounts for
all resources, and a user can get off quota even for a resource that
is not visible.
* Remove API call GET /account/v1.0/authenticate in favor of
POST /identity/v2.0/tokens.
* Export basic statistics about Astakos service at the '/admin/stats/detail' API
endpoint. Access to this endpoint is only allowed to users that belong to
the Astakos groups that are defined in the
'ASTAKOS_ADMIN_STATS_PERMITTED_GROUPS' setting. Statistics are also available
through the 'snf-manage stats-astakos' management command.
* Implement OAuth 2.0 Authorization Code Grant
Add API calls for authorization code and access token generation
* Add API call for validating OAuth 2.0 access tokens
* **Shibboleth module** Extract unique identifier from the
``REMOTE_USER`` header.
* Automatically fill third-party signup form fields when available by the
the third-party provider.
* Management commands:
* Introduced new commands:
* component-show
* quota-list (replacing quota, supports various filters)
* quota-verify (replacing quota)
* oauth2-client-add (register OAuth 2.0 client)
* oauth2-client-list (list registered oauth 2.0 clients)
* oauth2-client-remove (remove OAuth 2.0 client)
* Changed commands:
* component-add got options --base-url and --ui-url
* resource-modify --limit became --default-quota
* user-modify can operate on multiple users with --all and --exclude
* user-modify --set-base-quota became --base-quota
* Removed commands:
* quota
* resource-import (subsumed by service-import)
* resource-export-astakos (subsumed by service-export-astakos)
* Fix request authorization code failures due to Unicode issue:
https://code.grnet.gr/issues/4971
* Omit validation issues for non-required metadata values received from the
third-party authentication provider.
Cyclades
--------
* Major changes to Cyclades networks:
* Implement 'cyclades_network' service, containing the /networks, /ports,
/subnets and /floatingips API endpoints under '/network/v2.0'. The old
/networks API of 'cyclades_compute' (under /compute/v2.0) is
removed.
* Implement `snf-manage subnet-{create, list, modify, inspect}' management
commands for handling of subnets.
* Implement `snf-manage port-{create, list, remove, inspect}' management
commands for handling of ports.
* Add two new settings, 'CYCLADES_FORCED_SERVER_NETWORKS' and
'CYCLADES_DEFAULT_SERVER_NETWORKS' to control the networks that newly
created servers will be connected.
* Implement Floating IP addresses, which are IPv4 addresses that can be
dynamically added and removed to a running server.
* Add new 'cyclades.floating_ip' resource.
* Implement 'snf-manage floating-ip-{create,list,remove,attach,detach}'
management commands to handle floating IPs.
* Add 'floating_ip_pool' attribute to networks to mark networks that can
be used as floating IP pools.
* Implement 'resize' server action.
* Implement the 'resize' server action, to change the flavor of a server.
Only 'cpu' and 'memory' resizing is supported.
* Compute quotas for CPU and memory of running VMs.
* Change 'cyclades.cpu' and 'cyclades.ram' resources to represent the CPU
and RAM for running VMs. Total CPU and RAM usage is represented by new
'cyclades.total_cpu' and 'cyclades.total_ram' resources.
* Refer to Ganeti NICs by their name instead of their index.
* Make cyclades give a unique name to each Ganeti NIC. NICs are refered by
their unique name and not by their index inside the VM that are connected
to.
* Support firewall profile for all NICs of an instance. Change firewall
settings to be filled with the unique name of the NIC. The affected settings
are the GANETI_FIREWALL_{ENABLED, DISABLED, PROTECTED}_TAG settings.
* Add accounting for public IP addresses that is accessible via `snf-manage
ip-list` management command and via the helpdesk app.
* Implement IPv6 only networks.
* Extend servers info API response with 'SNF:fqdn' attribute, and introduce
CYCLADES_SERVERS_FQDN to set the template for servers FDQN. Remove
'UI_VM_HOSTNAME_FORMAT' setting.
* Extend servers info API response with 'SNF:port_forwarding' attribute,
describing port forwarding rules (DNAT) that are applied to vms. The
description of such rules is done via the new CYCLADES_PORT_FORWARDING
setting.
* Speed up server reconciliation, by performing parallel reconciliation for
each backend.
* Change --dhcp option of network management commands from a flag to a boolean
value, e.g. --dhcp=True
* Remove 'ARCHIPELAGO_BACKENDS' setting used to distinguish between backends
that hosted only archipelago backends. Instead allocation is based on which
disk-templates are enabled in each backend.
* Implement 'snf-manage server-remove' management command.
* Move reconciliation of IP pools from 'reconcile-networks' to
'reconcile-pools'. The IP pool reconciliation does not reconcile the IP
pools with Ganeti. Instead it checks if the pool is consistent with the
IPs that are used by instances.
* Do not automatically release externally reserved IPs if they are released
from a Ganeti backend. Management of externally reserved IPs must be
performed from Cyclades with 'network-modify' command.
* Export basic statistics about Cyclades Service at the '/admin/stats/detail'
API endpoint. Access to this endpoint is only allowed to users that belong
to the Astakos groups that are defined in the 'ADMIN_STATS_PERMITTED_GROUPS'
setting. Statistics are also available through the 'snf-manage stats-cyclades'
management command.
* Support enforcing quota through command 'enforce-resources-cyclades'.
* Remove command 'resource-export-cyclades' subsumed by
'service-export-cyclades'.
* Obsolete PUBLIC_USE_POOL setting, since Cyclades manages IP pool for all
type of networks.
* Encrypt / decrypt the instance id / hostname in the stats URL in
snf-cyclades-app and snf-stats-app, using the 'CYCLADES_STATS_SECRET_KEY'
and 'STATS_SECRET_KEY' respectively.
* Add support for snf-vncauthproxy-1.5 and the setting
'CYCLADES_VNCAUTHPROXY_OPTS', which configures the extra options / arguments
needed by the newer version of snf-vncauthproxy. Support for older versions
of snf-vncauthproxy has been dropped. See also the upgrade notes for Synnefo
and snf-vncauthproxy-1.5.
* Remove 'DEFAULT_ROUTING_TABLE' setting. If a link for an IP_LESS_ROUTED
network is not specified, the link will be uniquely named
'snf-link-$network_id'.
* Extend flavors with 'allow_create' attribute. Flavors that have this
attribute unset cannot be used by users to create new servers.
* Store each image property(metadata) as a separate Pithos metadata and check
that the size of each property is valid.
* Fix a few occurrences of HTTP 500 errors being triggered due to insufficient
validation of incoming requests in the Network API
* Speed up some API calls by fixing the relevant DB queries
Cyclades UI
-----------
- Retrieve all networks information from the introduced cyclades network
service.
- New IPs pane from which user can manage floating IPs.
- Redesign public keys overlay as an additional pane view.
- Split networking configuration into an additional step in machine create
wizard.
- Display forced networks and choices of the available floating IPs which will
be assigned to the created machine.
- Support for machine resize action. Explicit handling when machine is started
by displaying an utility shutdown button within the resize overlay.
- Machine IPs toggling subview in icon/single views.
- Replace IPv4/IPv6 with machine's FQDN in icon/single view. When no FQDN can
be resolved display a message. Message can be configured using the introduced
``UI_NO_FQDN_MESSAGE``. Setting ``UI_VM_HOSTNAME_FORMAT`` has been removed
and no longer used.
- Respect ``SNF:task_state`` machine attribute in order to improve machine
status display.
- Append software version as a url parameter in HTML static files in order
to force browser cache invalidation between versions.
- Configurable Google fonts base url. Fonts base url can be changed usint the
``SYNNEFO_FONTS_BASE_URL`` setting.
- Regression fix: Display reboot required notification on machine firewall
parameters.
- Handling of ``GANETI_USE_HOTPLUG`` setting. Do not allow live network actions
when setting is set to ``False``.
- Double escaping fix in machine create wizard images list and machine details
subview.
- Fix image ordering in machine create wizard.
- New setting ``UI_SSH_SUPPORT_OSFAMILY_EXCLUDE_LIST``. A list of image OS
families for which ui will disable ssh key injection in machine wizard.
- Setting ``UI_SUPPORT_SSH_OS_LIST`` removed and no longer used.
- Group public networks by name if setting ``UI_GROUP_PUBLIC_NETWORKS`` is set
to True.
- Setting ``UI_GROUPED_PUBLIC_NETWORK_NAME`` has been deprecated and no longer
used.
- Fix UI to filter available flavors in VM wizard
Cyclades Userdata
-----------------
- Maximum allowed length of ssh key content. Configurable from the
``USERDATA_SSH_KEY_MAX_CONTENT_SIZE`` setting.
Pithos
------
* Rewrite tests.
* Performance optimizations in object listing.
* Introduce backend method decorator for handling transaction management if no
transaction is initiated from the frontend.
* Fix Internal Server Errors https://code.grnet.gr/issues/4501 &
https://code.grnet.gr/issues/4502.
* Fix REQUEST ENTITY TOO LARGE request failure during move operations
https://code.grnet.gr/issues/4154.
* Fix FORBIDDEN request failure while listing implicitly shared objects
https://code.grnet.gr/issues/4131.
* Fix issue with the computed size of an updated object.
* Reply with the Merkle hash in the ETag header if MD5 is deactivated.
* Reply with FORBIDDEN (403) to public listing requests performed by non path
owners.
* Change response status to NOT FOUND (404) while trying to delete an
already deleted object.
* Change SQLAlchemy version to 0.7
* Change view authorization
The pithos views do not use the cookie information for user authentication.
They request (from Astakos) and use a short-term access token for a
specific resource.
* Remove PITHOS_ASTAKOS_COOKIE_NAME setting, since it is no longer useful
* Add PITHOS_OAUTH2_CLIENT_CREDENTIALS setting to authenticate the views with
astakos during the resource access token generation procedure
* Add PITHOS_UNSAFE_DOMAIN setting to restrict file serving endpoints to a
specific host
* Added new 'file-show' management command
* Remove command 'resource-export-pithos' subsumed by 'service-export-pithos'.
* Extend API to optionally enforce a specific content disposition type
in view and public requests: https://code.grnet.gr/issues/5019
* Fix bulk operation (delete/copy/move) failures in overpopulated
containers/folders: https://code.grnet.gr/issues/5119
* Fix performance issue due to missing index
* Fix backend open hashfile bug:
https://code.grnet.gr/issues/5011
* Fix GET request for public path with If-None-Match
https://code.grnet.gr/issues/5168
.. _Changelog-0.14.10:
v0.14.10
=======
Released: Tue Nov 26 11:03:37 EET 2013
Cyclades
-------
* This is the first release to support Ganeti 2.8. Support for older versions
of Ganeti is dropped.
* Use Ganeti opportunistic locking to achive parallelized instance creations
in the same backend. Add setting 'GANETI_USE_OPPORTUNISTIC_LOCKING' to
enable the use of this feature.
* Fix warning message while getting object permissions to appear only when
path is None and the object has permissions
* Add name to newly created NICs and the corresponding firewall tags.
.. _Changelog-0.14.9:
v0.14.9
=======
Released: Mon Nov 11 12:13:31 EET 2013
* Astakos: Fix minor problems with logging in the Astakos module, which could
lead to unexpected exceptions
.. _Changelog-0.14.8:
v0.14.8
=======
Released: Fri Nov 8 17:25:08 EET 2013
Synnefo-wide
------------
* This is the first release to support Debian Wheezy along with Squeeze. You
can mix and match nodes freely.
* Update Django dependency to Django>=1.2,<1.5. Django 1.4.5 is available for
Squeeze through squeeze-backports.
* Since this version, Synnefo ships an example Gunicorn configuration file
that is automatically installed at ``/etc/gunicorn.d/synnefo.example``.
Cyclades
--------
* On VM creation, pass the hashmap of the image (pithosmap://) instead of the
image URL (pithos://). Access to the Pithos DB by Ganeti nodes is no longer
required.
* Workaround race between server creation and server deletion. This will be
fixed properly by updating Ganeti to support the 'depends' attribute for
OP_INSTANCE_REMOVE.
Astakos
-------
* For Shibboleth logins, store all attributes along with the user in the DB.
.. _Changelog-0.14.7:
v0.14.7
=======
Released: Wed Sep 18 17:50:12 EEST 2013
Cyclades
--------
* Fix bug in helpdesk view
.. _Changelog-0.14.6:
v0.14.6
=======
Released: Wed Sep 18 16:18:58 EEST 2013
Pithos
------
* Substitute the PITHOS_BACKEND_QUOTA setting with two
distinct settings: PITHOS_BACKEND_ACCOUNT_QUOTA &
PITHOS_BACKEND_CONTAINER_QUOTA
* Set PITHOS_BACKEND_CONTAINER_QUOTA default value to 0 (unlimited)
* Fix bug that resulted in DB deadlocks.
Cyclades
--------
* Fix bug in snf-dispatcher that resulted in servers to be deleted from the
DB even if the corresponding Ganeti job failed.
Branding
--------
* Add new BRANDING_FOOTER_EXTRA_MESSAGE setting.
.. _Changelog-0.14.5:
v0.14.5
=======
Released: Wed Aug 7 11:19:49 EEST 2013
Pithos
------
* Fix security issue with handling Pithos versions.
.. _Changelog-0.14.4:
v0.14.4
=======
Released: Mon Jul 29 12:24:22 EEST 2013
Pithos
------
* Fix bug in reconcile resources management command.
.. _Changelog-0.14.3:
v0.14.3
=======
Released: Thu Jul 25 12:22:47 EEST 2013
Synnefo-wide
------------
* Use the SYNNEFO_TRACE environmental variable to control whether the greenlet
tracing code will get loaded or not.
* Split the HIDDEN_COOKIES setting in HIDDEN_HEADERS and HIDDEN_COOKIES, and
add the MAIL_MAX_LEN setting, to limit the mail size for unhandled
exceptions.
.. _Changelog-0.14.2:
Released: Fri Jul 12 13:13:32 EEST 2013
v0.14.2
=======
Cyclades
--------
* Add new setting PITHOS_BACKEND_POOL_SIZE, which configures the size
of the pool of Pithos backends that are used by plankton.
Pithos
------
* Refactor metadata schema (table attributes) in Pithos DB to speedup current
objects by domain attribute. This is used by Plankton for listing VM images.
.. _Changelog-0.14:
v0.14
=====
Released: Tue Jun 25 14:01:19 EEST 2013
Synnefo-wide
------------
* Create 'snf_django' Python package to hold common code for all Synnefo
components.
* Create a JSON-exportable definition document for each Synnefo Components
(Astakos, Cyclades, Pithos, etc.) that consolidates APIs (services),
resources, and other standardized properties (e.g. default URL prefixes).
* Standardize URLs for Synnefo Components, impose structure and naming
conventions to related settings. Make each component deployable under
a user-configurable <COMPONENT>_BASE_URL. Each API (compute, image, etc.)
is deployable under a developer-configurable prefix beneath BASE_URL.
* Deprecate CLOUDBAR_ACTIVE_SERVICE setting from all apps.
* Common synnefo 404/500 templates (located in snf-webproject)
Astakos
-------
* Redesign of the accounting system (quotaholder) and integration into
Astakos.
* Simplified the quotaholder model; removed tables Entity and Policy; now
table Holding contains limit and usage for every holding.
* Extended table Holding, so that we can keep track of quota for every
valid combination of holder (e.g. user), resource, and source (e.g. the
default system or some specific project).
* Refactored code for issuing and resolving commissions for robustness;
added a 'force' option to bypass the upper limit check when issuing a
commission.
* Simplified syncing to the quotaholder; removed fields from models
Project and ProjectMembership, previously needed for syncing; removed
state PROJECT_DEACTIVATED from ProjectMembership.
* Removed settings ASTAKOS_QUOTAHOLDER_URL, ASTAKOS_QUOTAHOLDER_TOKEN,
and ASTAKOS_QUOTAHOLDER_POOLSIZE.
* API-related changes:
* Implemented API calls for quota, resources, and commissions.
* Moved all API calls under '/account/v1.0'.
* Implemented the keystone API call POST /tokens under '/identity/v2.0'.
* Service and resource specification and handling:
* Specified a format for defining services along with the API endpoints
and the resources they expose. Migrated internal resource name by
prefixing it with service name (e.g. 'vm' becomes 'cyclades.vm');
renamed registered service 'pithos+' to 'pithos'.
* Specified a procedure to register a Synnefo component, its services and
their resources in astakos and set the resources' default base quota
limit. Removed resource definitions from settings.
* Moved service and resource presentation data out of the respective db
models into a separate file of UI constants.
* Converted the limit on pending applications from a setting to a quotable
resource. Converted the related user setting to a user-specific base quota
limit. Deprecated model UserSetting; removed setting
ASTAKOS_PENDING_APPLICATION_LIMIT.
* Changes in locking strategy:
* Lock only project's chain for all project operations; lock user before
syncing to quotaholder.
* When locking multiple rows (e.g. users or holdings) include an ORDER BY
clause in the query to impose ordering on locking.
* Changes in views:
* Replaced custom transaction context with a simple decorator for managing
transactions and a context 'ExceptionHandler', which logs and suppresses
exceptions
* Added fine grain user auth provider's policies.
* Administrator can override default auth provider policies to a specific
user or group of users.
* Optionally a user can be assigned to a list of groups, based on the
authentication method he choosed to signup.
* Removed explicit handling of SMTP errors on each email delivery. Exceptions
are now propagated to base django exception handler.
* Email used in html/email tempaltes which prompt user to contact for service
support prompts is now defined in ``CONTACT_EMAIL`` setting introduced in
snf-common settings.
* Improvements in user activation flow
* User moderation now takes place after the user has verified his email
address.
* User model enriched with additional user state fields
* Split activation email from moderation process. Administrator is required
to moderate user explicitly using the `user-modify --accept` or
`user-modify --reject` commands.
* Improved logging throught out user activation procedures.
* Remove deprecated AstakosUser model fields: `provider`,
`third_party_identifier`
* Allow override of authentication provider messages using the following
format in setting names: ``ASTAKOS_<PROVIDER_MODULE>_<MSGID>_MSG``
* Cloudbar automatically tries to identify the active service based on window
location.
* Removing authentication provider view is now CSRF protected.
* New `API access` view, containing useful information to users on how to
access available Synnefo services API's.
* Remove of ASTAKOS_*_EMAIL_SUBJECT settings. All email subjects are now
defined in astakos.im.messages module. Overriding default values can be
achieved using custom gettext files or using astakos messages settings::
#change of greeting email subject
ASTAKOS_GREETING_EMAIL_SUBJECT_MESSAGE = 'Welcome to my cloud'
* Remove ``ASTAKOS_ACTIVATION_REDIRECT_URL`` and ``ASTAKOS_LOGIN_SUCCESS_URL``
from astakos .conf file. Settings are dynamically computed based on
``ASTAKOS_BASE_URL``.
* Management commands:
* Introduced new commands:
* authpolicy-{add, list, remove, set, show}
* group-{add, list}
* component-{add, list, modify, remove}
* reconcile-resources-astakos
* resource-{export-astakos, import, modify}
* service-{export-astakos, import, show}
* Renamed commands:
* astakos-quota to quota
* user-update to user-modify
* full-cleanup to cleanup-full
* Removed commands:
* astakos-init
* invitation-{details, list}
* project-sync
* resource-{add, remove}
* service-{add, remove, token-renew, update}
* user-invite
* user-set-initial-quota (integrated its functionality in user-modify and quota)
* Added quota and project-related information in user-show command; added
membership information in project-show.
Cyclades
--------
* Make 'type' attribute required for network create API request.
* Networks not created to all Ganeti backends upon creation, they are instead
created to a backend only when a VM connects to the network.
* Add 'CYCLADES_ASTAKOSCLIENT_POOLSIZE' setting which tunes the size of the
http connection pool to astakos.
* Remove 'CYCLADES_USER_CATALOG_URL' and 'CYCLADES_USER_FEEDBACK_URL' settings
* Remove CYCLADES_USE_QUOTAHOLDER, CYCLADES_QUOTAHOLDER_TOKEN,
CYCLADES_QUOTAHOLDER_URL, CYCLADES_QUOTAHOLDER_POOLSIZE settings
* Rename 'cyclades-usage-verify' management command to
'reconcile-resources-cyclades'. Also, remove 'cyclades-usage-reset' command,
which is equivalent to 'reconcile-resources-cyclades --fix'.
* Rename 'cyclades-reconcile-commissions' management command to
'reconcile-commissions-cyclades'.
* Remove obsolete 'MAX_VMS_PER_USER', 'MAX_NETWORKS_PER_USER',
"VMS_USER_QUOTA" and "NETWORKS_USER_QUOTA" settings, since their usage
is covered by Quotaholder.
* Remove obsolete setting 'API_ROOT_URL', since it is being covered by
the use of CYCLADES_BASE_URL* Remove obsolete setting 'API_ROOT_URL', since
it is being covered by 'CYCLADES_BASE_URL'.
* Remove obsolete settings GANETI_DISK_TEMPLATES and
DEFAULT_GANETI_DISK_TEMPLATE
Cyclades helpdesk
-----------------
* Additional start/stop vm action
* Display extend backend info in vm's view
* Fixed IP lookup
Pithos
------
* Remove PITHOS_AUTHENTICATION_USERS setting, which was used to override
astakos users.
* Remove 'PITHOS_USER_CATALOG_URL', 'PITHOS_USER_FEEDBACK_URL' and
'PITHOS_USER_LOGIN_URL' settings.
* Remove PITHOS_USE_QUOTAHOLDER, PITHOS_QUOTAHOLDER_URL,
PITHOS_QUOTAHOLDER_TOKEN and PITHOS_ASTAKOSCLIENT_POOLSIZE
* Enforce container-level atomicity in (most) Pithos API calls.
Tools
-----
.. _Changelog-0.13:
v0.13
=====
Released: Wed Apr 10 18:52:50 EEST 2013
In v0.13 the code was very heavily refactored for increased uniformity since
most of the Synnefo components have been merged into a single repository. Thus,
**just for this version** we will not document a complete Changelog (features,
fixes, improvements, issues, setting changes), but rather just copy from the
`NEWS` file with minor additions wherever needed.
Synnefo-wide
------------
* Support for pooling throughout Synnefo
* Pooled Django DB connections, Pithos backend connections, HTTP
connections using single `objpool` package
* Improved management commands
* Unified codebase for output of tables in JSON, CSV
* Bring most of Synnefo code inside a single, unified repository
* support automatic Python and Debian package builds for individual commits
* with automatic version generation
* Overhauling of Synnefo settings: renames and refactoring, for increased
uniformity (in progress)
* Deployment: Standardize on gunicorn, with gevent-based workers
and use of Green threads throughout Synnefo
* Documentation: New scale-out guide, with distinct node roles,
for mass Synnefo deployments
Astakos
-------
* Support multiple authentication methods
* Classic (username/password), Shibboleth, LDAP/Active Directory,
Google, Twitter, LinkedIn
* Users can enable/disable auth methods, and switch between them
* Introduce a UUID as a global identifier for users, throughout Synnefo
* The UUID remains constant as the user enables/disables login methods
* Allow users to modify their email address freely
* Per-user, per-resource accounting mechanism (quotaholder)
* Full quota support, with per-user, per-resource quotas, based on quotaholder
* Projects: Users can create and join Projects
* Projects grant extra resources to their members
* UI Enhancements for quotas and projects
* distinct Usage tab, showing usage of individual resources
* Project management UI
* New Overview page
* refactored/improved /login endpoint used by desktop/mobile clients.
* endpoint url is now exposed by `weblogin` service
* clients should use unauthenticated identity/tokens api to resolve the
endpoint url
* view only allows redirects to `pithos://` scheme urls
* removed uuid from redirect parameters. Client should use authenticated
request to identity/tokens to retrieve user uuid.
Cyclades
--------
* Commission resources on quotaholder/Astakos
* Support mass creation of flavors
* Support for the ExtStorage disk template in Ganeti
* Query and report quotas in the UI
* Pass VM configuration parameters over a VM-side API (`vmapi`)
* Do not pass sensitive data as Ganeti OS parameters
* Keep sensitive data in memory caches (memcached) and
never allow them to hit the disk
* Display additional backend information in helpdesk machines list
* Allow helpdesk users to search for an account using a known machine id
* Helpdesk actions are now logged using the synnefo's common login
infrastructure
UI
^^
* Removed feedback endpoint. Feedback requests delegate to astakos feedback
service. ``FEEDBACK_CONTACTS``, ``FEEDBACK_EMAIL_FROM`` settings removed,
and no longer used.
* ``UI_LOGIN_URL``, ``UI_GLANCE_URL``, ``COMPUTE_URL`` settings no longer
required to be set and are dynamically computed based on ``ASTAKOS_BASE_URL``
and ``CYCLADES_BASE_URL`` settings.
* File group is no longer included in ssh keys personality metadata sent in
create vm calls.
Pithos
------
* Support storage of blocks on a RADOS backend, for Archipelago
* new settings:
PITHOS_RADOS_STORAGE, PITHOS_RADOS_POOL_BLOCKS, PITHOS_RADOS_POOL_MAPS
* X-Object-Public now contains full url (domain + proper component prefix +
file path)
* Rewritten support for public URLs, with admin-selectable length
* new settings:
PITHOS_PUBLIC_URL_SECURITY, PITHOS_PUBLIC_URL_ALPHABET
* Enable pithos backend to use external quotaholder component
* new settings:
PITHOS_USE_QUOTAHOLDER, PITHOS_QUOTAHOLDER_URL, PITHOS_QUOTAHOLDER_TOKEN,
PITHOS_QUOTAHOLDER_POOLSIZE
* Moderated version debiting mechanism
* new setting:
PITHOS_BACKEND_FREE_VERSIONING
* Proxy Astakos user-visible services
* new settings:
PITHOS_PROXY_USER_SERVICES, PITHOS_USER_CATALOG_URL,
PITHOS_USER_FEEDBACK_URL, PITHOS_USER_LOGIN_URL
Tools
-----
* Extend snf-burnin to include testing of Pithos functionality