source: examples/python_tests/basic_id/id.py @ 09496b3

mei_rt2mei_rt2_fix_1
Last change on this file since 09496b3 was 09496b3, checked in by Mei <mei@…>, 12 years ago

1) add ID api that takes abac_chunk_t*

  • Property mode set to 100755
File size: 2.8 KB
RevLine 
[5110d42]1#!/usr/bin/env python
2
3"""
4  to test with python
5
6cmd1:env keystore=`pwd` ./id.py
7cmd2:env ABAC_CN=1 keystore=`pwd` ./id.py
8
9"""
10
11import os
12import ABAC
13
14ctxt = ABAC.Context()
15
16print "ABAC version %s" % ctxt.version()
17
[f824a9e]18# Keystore is the directory containing the principal credentials.
19# Load existing principals and/or policy credentials
20if (os.environ.has_key("keystore")) :
21    keystore=os.environ["keystore"]
22    ctxt.load_directory(keystore)
23else:
24    print("keystore is not set...")
25    exit(1) 
[5110d42]26
27out = ctxt.context_principals()
28print "...initial principal set..."
29for x in out[1]:
30    print "%s " % x.string()
31print "\n" 
32
[09496b3]33## case 1
[f824a9e]34## creating and writing out using libabac ID
[5110d42]35id=ABAC.ID("Mary", 0)
[5d06689]36print "adding -> %s(good)" % id.id_name()
[5730a10]37id.id_write_cert("Mary_ID.pem")
[5d06689]38id.id_write_privkey("Mary_private.pem")
[f824a9e]39## load principal with id/key file pair
40## note, with this, we do not have handle on the keyid
41## to Mary but it will be in the db
[5d06689]42ctxt.load_id_files("Mary_ID.pem","Mary_private.pem")
[5110d42]43
[09496b3]44## case 2
[f824a9e]45## creating principal using ID
[5110d42]46nid=ABAC.ID("Jack", 0)
[5d06689]47print "adding -> %s(good)" % nid.id_name()
[f824a9e]48## load principal directly with the ID, no external
49## credential files were created
[5110d42]50ctxt.load_id(nid)
51
[09496b3]52## case 3
[f824a9e]53## creating principal using ID
[5110d42]54id=ABAC.ID("Mark", 0)
[5d06689]55print "adding -> %s(good)" % id.id_name()
[f824a9e]56## write cert and key content to a combo file. One is appended
57## after another
[5d06689]58id.id_write_privkey("Mark_IDKEY.pem")
59id.id_write_cert("Mark_IDKEY.pem")
[f824a9e]60## load principal in with the combo file with the tandem format
[5110d42]61ctxt.load_id_file("Mark_IDKEY.pem")
62
[09496b3]63## case 4
[f824a9e]64## creating principal using ID
[5110d42]65id=ABAC.ID("John", 0)
[5d06689]66print "adding -> %s(good,invisible)" % id.id_name()
67id.id_write_privkey("John_other.pem")
68id.id_write_cert("John_other.pem")
[f824a9e]69## load id without the key file
[d9c3886]70ctxt.load_id_file("John_other.pem")
[5110d42]71
[09496b3]72## case 5
[f824a9e]73## creating principal using ID
[5110d42]74id=ABAC.ID("Lori", 0)
[5d06689]75print "adding -> %s(good,nokey)" % id.id_name()
[f824a9e]76## write just cert into the combo file
[5d06689]77id.id_write_cert("Lori_IDKEY.pem")
[f824a9e]78##load principal from a combo file that only contains cert part
[5110d42]79ctxt.load_id_file("Lori_IDKEY.pem")
80
[09496b3]81## case 6
[f824a9e]82## creating principal using ID
[5110d42]83id=ABAC.ID("Tom", 0)
[5d06689]84print "adding -> %s(bad,nocert)" % id.id_name()
[f824a9e]85## write just key into the combo file
[5d06689]86id.id_write_privkey("Tom_IDKEY.pem")
[f824a9e]87## load principal from combo file that only contains key part
[5110d42]88ctxt.load_id_file("Tom_IDKEY.pem")
89
[09496b3]90## case 7
91## creating ID using chunk
92id=ABAC.ID("Tim", 0)
93chunk=id.id_cert_chunk_ptr() 
94nid=ABAC.ID(chunk)
95## load principal from new id file
96ctxt.load_id(nid)
97
98## case 8
[f824a9e]99## failure case, loading a non-existing combo file
[5110d42]100print "adding -> Casper(bad,unknown file)"
101ctxt.load_id_file("Casper_IDKEY.pem")
102
[09496b3]103
[5110d42]104print "...final principal set..."
105out = ctxt.context_principals()
106for x in out[1]:
107    print "%s " % x.string()
108print "\n"
109
[5d06689]110ctxt.dump_yap_db()
Note: See TracBrowser for help on using the repository browser.