X-Git-Url: http://www.project-moonshot.org/gitweb/?p=trust_router.git;a=blobdiff_plain;f=include%2Ftr_idp.h;h=68d669eb0a2860740a89a478275d1cfc6188153c;hp=25d281d2e2a3bfcdb0b7f139f9e5eba72de81747;hb=dd90d231263fc3dde5f538a5a83d88dd701ed178;hpb=7a7f4079644a03d967616134db12b271390b75f7 diff --git a/include/tr_idp.h b/include/tr_idp.h index 25d281d..68d669e 100644 --- a/include/tr_idp.h +++ b/include/tr_idp.h @@ -35,7 +35,10 @@ #ifndef TR_IDP_H #define TR_IDP_H -#include +#include +#include + +#include #include typedef struct tr_aaa_server { @@ -43,6 +46,18 @@ typedef struct tr_aaa_server { TR_NAME *hostname; } TR_AAA_SERVER; +typedef struct tr_aaa_server_iter { + TR_AAA_SERVER *this; +} TR_AAA_SERVER_ITER; + +/* may also want to use in tr_rp.h */ +typedef enum tr_realm_origin { + TR_REALM_LOCAL=0, /* realm we were configured to contact */ + TR_REALM_REMOTE_INCOMPLETE, /* realm we were configured to know about, without contact info yet */ + TR_REALM_REMOTE, /* realm we were configured to know about, with discovered contact info */ + TR_REALM_DISCOVERED /* realm we learned about from a peer */ +} TR_REALM_ORIGIN; + typedef struct tr_idp_realm { struct tr_idp_realm *next; struct tr_idp_realm *comm_next; /* for linked list in comm config */ @@ -50,8 +65,42 @@ typedef struct tr_idp_realm { int shared_config; TR_AAA_SERVER *aaa_servers; TR_APC *apcs; + TR_REALM_ORIGIN origin; /* how did we learn about this realm? */ + unsigned int refcount; /* how many TR_COMM_MEMBs refer to this realm */ } TR_IDP_REALM; -TR_AAA_SERVER *tr_idp_aaa_server_lookup(TR_IDP_REALM *idp_realms, TR_NAME *idp_realm_name, TR_NAME *comm); +TR_IDP_REALM *tr_idp_realm_new(TALLOC_CTX *mem_ctx); +void tr_idp_realm_free(TR_IDP_REALM *idp); +TR_NAME *tr_idp_realm_get_id(TR_IDP_REALM *idp); +TR_NAME *tr_idp_realm_dup_id(TR_IDP_REALM *idp); +void tr_idp_realm_set_id(TR_IDP_REALM *idp, TR_NAME *id); +void tr_idp_realm_set_apcs(TR_IDP_REALM *idp, TR_APC *apc); +TR_APC *tr_idp_realm_get_apcs(TR_IDP_REALM *idp); +TR_IDP_REALM *tr_idp_realm_lookup(TR_IDP_REALM *idp_realms, TR_NAME *idp_name); +TR_IDP_REALM *tr_idp_realm_add_func(TR_IDP_REALM *head, TR_IDP_REALM *new); +#define tr_idp_realm_add(head,new) ((head)=tr_idp_realm_add_func((head),(new))) +TR_IDP_REALM *tr_idp_realm_remove_func(TR_IDP_REALM *head, TR_IDP_REALM *remove); +#define tr_idp_realm_remove(head,remove) ((head)=tr_idp_realm_remove_func((head),(remove))) +TR_IDP_REALM *tr_idp_realm_sweep_func(TR_IDP_REALM *head); +#define tr_idp_realm_sweep(head) ((head)=tr_idp_realm_sweep_func((head))) +int tr_idp_realm_aaa_server_count(TR_IDP_REALM *idp); +int tr_idp_realm_apc_count(TR_IDP_REALM *idp); +void tr_idp_realm_incref(TR_IDP_REALM *realm); +void tr_idp_realm_decref(TR_IDP_REALM *realm); + +TR_AAA_SERVER *tr_aaa_server_new(TALLOC_CTX *mem_ctx, TR_NAME *hostname); +void tr_aaa_server_free(TR_AAA_SERVER *aaa); + +TR_AAA_SERVER_ITER *tr_aaa_server_iter_new(TALLOC_CTX *mem_ctx); +void tr_aaa_server_iter_free(TR_AAA_SERVER_ITER *iter); +TR_AAA_SERVER *tr_aaa_server_iter_first(TR_AAA_SERVER_ITER *iter, TR_AAA_SERVER *aaa); +TR_AAA_SERVER *tr_aaa_server_iter_next(TR_AAA_SERVER_ITER *iter); + +TR_AAA_SERVER *tr_idp_aaa_server_lookup(TR_IDP_REALM *idp_realms, TR_NAME *idp_realm_name, TR_NAME *comm, int *shared_out); TR_AAA_SERVER *tr_default_server_lookup(TR_AAA_SERVER *default_servers, TR_NAME *comm); + +/* tr_idp_encoders.c */ +char *tr_idp_realm_to_str(TALLOC_CTX *mem_ctx, TR_IDP_REALM *idp); +json_t *tr_idp_realms_to_json(TR_IDP_REALM *idp); + #endif