Tony Mack [Fri, 5 Jan 2007 16:16:16 +0000 (16:16 +0000)]
 
- initial checkin of new API implementation
Tony Mack [Fri, 5 Jan 2007 16:12:12 +0000 (16:12 +0000)]
 
- checkin of previous plc sendmail.py
Tony Mack [Fri, 5 Jan 2007 16:09:09 +0000 (16:09 +0000)]
 
- added sendmail object ('mailer') as a member of PLCAPI class
Tony Mack [Fri, 5 Jan 2007 16:00:09 +0000 (16:00 +0000)]
 
- dont return 'password', 'verification_key' or 'verification_expires' fields
Tony Mack [Fri, 5 Jan 2007 15:56:16 +0000 (15:56 +0000)]
 
- added 'verification_key', 'verification_expires' to Person.fields
Tony Mack [Fri, 5 Jan 2007 15:54:39 +0000 (15:54 +0000)]
 
*** empty log message ***
Mark Huang [Thu, 4 Jan 2007 16:05:35 +0000 (16:05 +0000)]
 
throw an error if methods.py fails
Mark Huang [Thu, 4 Jan 2007 16:01:28 +0000 (16:01 +0000)]
 
minimal hacks so that the PHP bindings can be built under FC2
Tony Mack [Wed, 20 Dec 2006 14:11:52 +0000 (14:11 +0000)]
 
- added 'message' instance variable (high level description of this event)
Tony Mack [Wed, 20 Dec 2006 14:08:40 +0000 (14:08 +0000)]
 
- Log event['message']
Tony Mack [Wed, 20 Dec 2006 14:07:22 +0000 (14:07 +0000)]
 
- added 'message' as an event field
Tony Mack [Wed, 20 Dec 2006 14:06:40 +0000 (14:06 +0000)]
 
- added 'message' column to events table
Mark Huang [Mon, 18 Dec 2006 17:55:58 +0000 (17:55 +0000)]
 
disable pycurl build for fc2 (not supported anyway)
Mark Huang [Fri, 15 Dec 2006 19:47:33 +0000 (19:47 +0000)]
 
regenerate
Mark Huang [Fri, 15 Dec 2006 19:46:19 +0000 (19:46 +0000)]
 
- lowercase subdirs
Mark Huang [Fri, 15 Dec 2006 19:45:49 +0000 (19:45 +0000)]
 
move docclean into clean
Mark Huang [Fri, 15 Dec 2006 19:43:37 +0000 (19:43 +0000)]
 
- be a little more verbose in the returns doc
- use peer.connect()
Mark Huang [Fri, 15 Dec 2006 19:42:27 +0000 (19:42 +0000)]
 
- add peer to roles
- fix returns
Mark Huang [Fri, 15 Dec 2006 19:42:09 +0000 (19:42 +0000)]
 
- add peer to roles
- fix accepts
- be a little more verbose in the returns doc
Mark Huang [Fri, 15 Dec 2006 19:41:12 +0000 (19:41 +0000)]
 
- add DeletePeer method
Mark Huang [Fri, 15 Dec 2006 19:41:02 +0000 (19:41 +0000)]
 
- add UpdatePeer method
Mark Huang [Fri, 15 Dec 2006 19:40:45 +0000 (19:40 +0000)]
 
- style nits, fix docs
Mark Huang [Fri, 15 Dec 2006 19:39:55 +0000 (19:39 +0000)]
 
- add peer_keys, peer_slice_attribute_types, and peer_slice_attributes
- use urlparse to validate peer URL scheme
- delete all peer entities when deleting peer
Mark Huang [Fri, 15 Dec 2006 19:39:04 +0000 (19:39 +0000)]
 
- add peer_keys, peer_slice_attribute_types, and peer_slice_attributes
Mark Huang [Fri, 15 Dec 2006 18:40:21 +0000 (18:40 +0000)]
 
- no need to pass auth struct, Peer now signs calls automatically
Mark Huang [Fri, 15 Dec 2006 18:39:51 +0000 (18:39 +0000)]
 
- make Peer a wrapper around xmlrpclib.ServerProxy, that also magically
  signs each call and checks the SSL certificate
Mark Huang [Fri, 15 Dec 2006 18:36:16 +0000 (18:36 +0000)]
 
- use PyCurlTransport and add --cacert to optionally check certificates
  if going over XML-RPC
Mark Huang [Fri, 15 Dec 2006 18:35:38 +0000 (18:35 +0000)]
 
- add GPGAuth signature authentication, primarily for peers
- require AuthMethod for consistency in SessionAuth
Mark Huang [Fri, 15 Dec 2006 18:34:46 +0000 (18:34 +0000)]
 
- peers: replace persons authentication with GPG/SSL authentication
Mark Huang [Fri, 15 Dec 2006 18:21:57 +0000 (18:21 +0000)]
 
Python "binding" for GPG. I'll write GPGME bindings eventually. The
intent is to use GPG to sign method calls, as a way of identifying
and authenticating peers. Calls should still go over an encrypted
transport such as HTTPS, with certificate checking.
Mark Huang [Fri, 15 Dec 2006 18:21:39 +0000 (18:21 +0000)]
 
Replacement for xmlrpclib.SafeTransport, which does not validate
SSL certificates. Requires PyCurl.
Mark Huang [Fri, 15 Dec 2006 16:20:20 +0000 (16:20 +0000)]
 
- must build modules before subdirs
Mark Huang [Fri, 15 Dec 2006 16:19:49 +0000 (16:19 +0000)]
 
- build psycopg2, pycurl generically
- build subdirs after metafiles
Mark Huang [Fri, 15 Dec 2006 16:18:06 +0000 (16:18 +0000)]
 
This commit was generated by cvs2svn to compensate for changes in r600,
which included commits to RCS files with non-trunk default branches.
Mark Huang [Wed, 13 Dec 2006 22:29:28 +0000 (22:29 +0000)]
 
- fix bugs
Thierry Parmentelat [Tue, 12 Dec 2006 13:02:51 +0000 (13:02 +0000)]
 
Provides test results references for
- run-m : start from 2 empty dbs, performs all tests, in mini mode
          (1 instance of each object)
- run-en : the dbs are suposed to have been populated by running -p -n
           that is with normal size, like a handful of each object
- run-eb : idem in big mode, a few hundreds of each type -
           like the public PL
- run-eh : idem in huge mode, a few thousands of each type -
1st mode is rather complete and convenient, just wipe off both dbs,
  everything is done remotely from the test node
other modes are more tedious to run,
  I usually run the populate phase locally, save the db dumps, and reinstall later on
  otherwise it's not workable
  they provide good indications of performance for
  (*) RefreshPeer from scratch
  (*) RefreshPeer in usual mode (no change done)
  (*) GetSlivers()
a rough indication in huge mode:
each plc gets populated with
1000 sites, 2000 persons, 3000 nodes & 2000 slices
1 keys/person, 3 nodes/slice & 3 persons/slice
- 1st refresh peer
   all : 407 s
   xmit:  25 s
   proc: 383 s
- 2nd refresh peer
   all :  42 s
   xmit:  25 s
   proc:  17 s
note that updating slice attributes is still not optimized wrt sync operations,
reasonably processing time could be improved to less than 10s.
- GetSlivers ()
   536 s just for getting the result from the peer, no processing
Thierry Parmentelat [Tue, 12 Dec 2006 10:59:01 +0000 (10:59 +0000)]
 
(*) Peer has new fields person_ids and site_ids
    also the former person_id field gets renamed as auth_person_id
(*) new method GetPeerName to access remote plc's name as configured in PLC_NAME
(*) System slices are cached - assuming PLC_SLICE_PREFIX are different, this is no problem
    so GetSlivers filters out remote system slices
(*) RefreshPeer returns *remote* peer name as 'peername'
    formerly 'plcname' returned *local* plc name
(*) Caching mechanism now should be operational in 3+ peers federations,
       that is to say GetPeerData returns only local and caller's objects, not third-peer's
       this requires various plc names to be correctly up to date
(*) RefreshPeer attempts to ensure this is true after a few hiccups,
       this might get improved once we have peer authentication
(*) various docs updated
Thierry Parmentelat [Mon, 11 Dec 2006 13:02:41 +0000 (13:02 +0000)]
 
removes requirement that /etc/planetlab/plc_config should exist, for use on non-myplc boxes
Thierry Parmentelat [Mon, 11 Dec 2006 11:56:37 +0000 (11:56 +0000)]
 
oops - usage was broken, still referred to global
Thierry Parmentelat [Thu, 7 Dec 2006 09:13:55 +0000 (09:13 +0000)]
 
prevents side-effect on foreign objects when appropriate
Thierry Parmentelat [Tue, 5 Dec 2006 16:45:33 +0000 (16:45 +0000)]
 
various changes in the test suite
Thierry Parmentelat [Tue, 5 Dec 2006 16:45:03 +0000 (16:45 +0000)]
 
Cache:
(*) sync only when needed - drastic improvements on peering refresh
    when up2date
(*) reverted Tony's change in Cache
(*) returns a lot of timing info in the 'timers' key
Other classes:
(*) removes refreshing of timestamps - were read-only and broke sync optim.
Thierry Parmentelat [Tue, 5 Dec 2006 16:25:26 +0000 (16:25 +0000)]
 
same function but in a class
backward-compatible
and also provides the ability to create several instances
  for testing federation scripts
Mark Huang [Mon, 4 Dec 2006 19:10:47 +0000 (19:10 +0000)]
 
- Fix casting of unicode strings in arrays
From federico on psycopg mailing list:
Il giorno mar, 28/11/2006 alle 15.33 -0500, Mark Huang ha scritto:
>> I've noticed that Unicode strings in PostgreSQL arrays are not cast to
>> Python unicode objects:
You need to register UNICODEARRAY just as you registered UNICODE but,
ouch!, it is not exported! I'll make it exported in next release, right
now you can use one of the internals:
psycopg2.extensions.register_type(psycopg2._psycopg.UNICODEARRAY)
Mark Huang [Mon, 4 Dec 2006 15:41:43 +0000 (15:41 +0000)]
 
- spacing nits
- fix wildcard check
Thierry Parmentelat [Mon, 4 Dec 2006 15:25:17 +0000 (15:25 +0000)]
 
before we switch to using new Shell.py
Tony Mack [Fri, 1 Dec 2006 16:37:15 +0000 (16:37 +0000)]
 
- modified insert_new_item to support multiple value insert in single sql statement
Thierry Parmentelat [Fri, 1 Dec 2006 14:52:10 +0000 (14:52 +0000)]
 
oops-need to revert last move
Thierry Parmentelat [Fri, 1 Dec 2006 14:32:39 +0000 (14:32 +0000)]
 
cosmetic
Thierry Parmentelat [Fri, 1 Dec 2006 13:16:54 +0000 (13:16 +0000)]
 
returns ellapsed time
Thierry Parmentelat [Fri, 1 Dec 2006 08:22:59 +0000 (08:22 +0000)]
 
defines persons_per_slice to avoid quadratic complexity - can run with DB dumps
Tony Mack [Thu, 30 Nov 2006 22:13:56 +0000 (22:13 +0000)]
 
- populate sites.max_slices correctly
Thierry Parmentelat [Thu, 30 Nov 2006 10:55:32 +0000 (10:55 +0000)]
 
foreign_xrefs should be a list and not a dict anymore
Thierry Parmentelat [Thu, 30 Nov 2006 10:53:01 +0000 (10:53 +0000)]
 
GetPeerData returns separate items for local and peer data
Thierry Parmentelat [Thu, 30 Nov 2006 10:23:25 +0000 (10:23 +0000)]
 
new naming scheme for outputs and reference outputs
Thierry Parmentelat [Thu, 30 Nov 2006 10:14:06 +0000 (10:14 +0000)]
 
new limit on nodes_per_slice to avoid quadratic total time on big tests
Thierry Parmentelat [Thu, 30 Nov 2006 10:12:01 +0000 (10:12 +0000)]
 
(*) implements validate_ methods for all timestamp objects
(*) now allows multiple sync() calls on the same object by
    reverting human-readable form to unix timestamp if needed
(*) removes extra reload formerly needed in Cache
Tony Mack [Wed, 29 Nov 2006 22:14:32 +0000 (22:14 +0000)]
 
- order queried events by event_id
Tony Mack [Wed, 29 Nov 2006 19:46:58 +0000 (19:46 +0000)]
 
- added support for wildcards in dictionary filters
Mark Huang [Wed, 29 Nov 2006 19:43:17 +0000 (19:43 +0000)]
 
- only add optional arguments if specified
Tony Mack [Wed, 29 Nov 2006 19:05:37 +0000 (19:05 +0000)]
 
- log affected object_ids
Tony Mack [Wed, 29 Nov 2006 18:30:10 +0000 (18:30 +0000)]
 
- - removed anything having to do with event_type/event_object
Tony Mack [Wed, 29 Nov 2006 17:57:27 +0000 (17:57 +0000)]
 
- removed anything having to with event_type/event_object
Mark Huang [Wed, 29 Nov 2006 03:44:36 +0000 (03:44 +0000)]
 
- fix probable checkin of debug code
Tony Mack [Tue, 28 Nov 2006 22:02:33 +0000 (22:02 +0000)]
 
- added logging vars
Tony Mack [Tue, 28 Nov 2006 22:00:14 +0000 (22:00 +0000)]
 
- insert Sliver into object_types table
Tony Mack [Tue, 28 Nov 2006 21:48:08 +0000 (21:48 +0000)]
 
- insert peers to object_types table
Mark Huang [Tue, 28 Nov 2006 21:34:48 +0000 (21:34 +0000)]
 
- fix check for foreign node
- fix case when multiple slice attributes of the same type have been set
  (e.g. proper_op)
Thierry Parmentelat [Tue, 28 Nov 2006 16:23:56 +0000 (16:23 +0000)]
 
creates a fixed number of keys, huge test would issue 200x200 keys through xmlrpc otherwise
Thierry Parmentelat [Tue, 28 Nov 2006 16:23:45 +0000 (16:23 +0000)]
 
updated with dump
Thierry Parmentelat [Tue, 28 Nov 2006 14:55:00 +0000 (14:55 +0000)]
 
(*) direct cross refs redefined as NOT NULL in the database
    (e.g. Node:site_id, Person:site_id, Slice:creator_person_id)
    NOTE. I screwed up, this was already in former commit of planetlab4.sql,
(*) cross-ref mechanism reviewed
    could not handle several xrefs with the same type in the same table
(*) undid ad-hoc trick for selecting local/foreign nodes (was named scope)
    had no added-value and was only used in TestPeers anyway
Thierry Parmentelat [Tue, 28 Nov 2006 10:25:03 +0000 (10:25 +0000)]
 
adopted as reference
Tony Mack [Tue, 28 Nov 2006 01:02:15 +0000 (01:02 +0000)]
 
- fixed how node['slice_ids'] are filterd
Tony Mack [Mon, 27 Nov 2006 18:33:13 +0000 (18:33 +0000)]
 
- use all_slice_ids when checking slice_ids in node['slice_ids']
Thierry Parmentelat [Mon, 27 Nov 2006 16:43:32 +0000 (16:43 +0000)]
 
(*) full support for database caching, including SliceAttributes
(*) looks OK but further tests are required
(*) system slices to be checked with latest implementation from Mark
    (I haven't got anything realting to pl_conf and such in GetSlivers
     since Mark made that change)
(*) TestPeers to dump both status verbatim
Tony Mack [Mon, 27 Nov 2006 16:09:56 +0000 (16:09 +0000)]
 
- remove invalid (i.e. expired) slice_ids from from node['slice_ids']
Thierry Parmentelat [Mon, 27 Nov 2006 12:28:08 +0000 (12:28 +0000)]
 
ooops
Thierry Parmentelat [Mon, 27 Nov 2006 12:18:13 +0000 (12:18 +0000)]
 
(*) slice atttribute types get cached
(*) TestPeers to create custom slice attribute types and slice attributes
(*) new method GetPeerData to allow RefreshPeer to perform
    a single xmlrpc request (overall improvement : x 3 on small deployments)
(*) Cache created with a peer_id rather than with a peer,
    so as to remove a useless dependency (arg check done by RefreshPeer)
(*) caching slice attributes will require another method,
    equality cannot be based on a single column as for other types
    of cached data; ongoing
Thierry Parmentelat [Mon, 27 Nov 2006 12:13:16 +0000 (12:13 +0000)]
 
removes time-dependent data before diffing out and ref
Thierry Parmentelat [Mon, 27 Nov 2006 08:23:48 +0000 (08:23 +0000)]
 
more precise timing
Thierry Parmentelat [Sat, 25 Nov 2006 09:41:14 +0000 (09:41 +0000)]
 
more detailed info passed when raising an exception
Thierry Parmentelat [Sat, 25 Nov 2006 09:38:34 +0000 (09:38 +0000)]
 
cleanup
Thierry Parmentelat [Sat, 25 Nov 2006 09:35:36 +0000 (09:35 +0000)]
 
caching sites, connected to persons, and nodes
Cache had a bug in handling simple (belongs_to-like) xrefs (e.g. site_id in persons)
Thierry Parmentelat [Sat, 25 Nov 2006 09:33:53 +0000 (09:33 +0000)]
 
new targets
Thierry Parmentelat [Sat, 25 Nov 2006 09:33:25 +0000 (09:33 +0000)]
 
more consistent slice-naming scheme
Thierry Parmentelat [Fri, 24 Nov 2006 20:18:40 +0000 (20:18 +0000)]
 
new ref output for TestPeers.py
Thierry Parmentelat [Fri, 24 Nov 2006 20:17:49 +0000 (20:17 +0000)]
 
create multiple sites, attached to persons and slices
Thierry Parmentelat [Fri, 24 Nov 2006 14:25:25 +0000 (14:25 +0000)]
 
persons get connected to slices. GetSlivers reports the right keys
the test framework provides timing information for evaluating performance
also the number of xmlrpc requests is kept to 4, for keys, persons, nodes and slices
Thierry Parmentelat [Fri, 24 Nov 2006 12:06:00 +0000 (12:06 +0000)]
 
Persons gets cached and connected to Keys (not tested until GetSlivers yet)
reference output of TestPeers under cvs
yet todo:
check GetSlivers
Optimize the set of calls each peer sends other peers, the current
scheme tends to be slow because of too many small requests being issued
consider writing a dedicated Method at some point
Thierry Parmentelat [Fri, 24 Nov 2006 11:57:15 +0000 (11:57 +0000)]
 
frun to run fast (1x1x1x1) test
Thierry Parmentelat [Thu, 23 Nov 2006 19:43:34 +0000 (19:43 +0000)]
 
add system slices on local hosts only -
though I'm not sure I understand what sense it makes for a plc
to answer GetSlivers for a non-local node
Thierry Parmentelat [Thu, 23 Nov 2006 19:36:07 +0000 (19:36 +0000)]
 
testing keys
Thierry Parmentelat [Thu, 23 Nov 2006 19:35:38 +0000 (19:35 +0000)]
 
cached Keys
the class_id field in cached classes is deprecated, it was redundant with primary_key,
Thierry Parmentelat [Thu, 23 Nov 2006 15:25:16 +0000 (15:25 +0000)]
 
accessories objects (transcoder and xreftable) instantiated once per xref_class
Thierry Parmentelat [Thu, 23 Nov 2006 11:55:24 +0000 (11:55 +0000)]
 
this version uses the first release of Cache.py
Thierry Parmentelat [Thu, 23 Nov 2006 11:51:13 +0000 (11:51 +0000)]
 
Generic cache management algorithm
(*) Transcoder class implements translation between alien ids (ids referring to another peer's DB) into the local DB
(*) XrefTable class implements DB access to bilateral n-to-n relationsships like slice_node
(*) Cache basically gets object lists from the peer, and calls update_table sequentially
A lot of stuff was removed from Peer and RefreshPeer, as well as Slices and was rewritten here
The classes subject to this now need to define extra attributes:
(*) class_id : e.g. 'node_id'
(*) class_key : e.g. 'hostname'
(*) foreign_fields : the list of stuff we copy verbatim from foreign objects
(*) foreign_xrefs : specify what cross-references should be solved and how, see Slices for an example
yet to do:
(*) improve intermediate objects allocation (transcoders and xreftables are created on the fly)
(*) use for importing keys, persons and slice attributes.
Thierry Parmentelat [Thu, 23 Nov 2006 11:37:40 +0000 (11:37 +0000)]
 
miscell
Tony Mack [Wed, 22 Nov 2006 19:51:01 +0000 (19:51 +0000)]
 
- fix print statements
Tony Mack [Tue, 21 Nov 2006 20:07:06 +0000 (20:07 +0000)]
 
- comments
Tony Mack [Tue, 21 Nov 2006 20:01:25 +0000 (20:01 +0000)]
 
- fix db archive