X-Git-Url: http://www.project-moonshot.org/gitweb/?p=trust_router.git;a=blobdiff_plain;f=include%2Ftr_idp.h;h=68d669eb0a2860740a89a478275d1cfc6188153c;hp=aa407b86cd34a81b3c46733b1a0e5cd47e2c4c3b;hb=dd90d231263fc3dde5f538a5a83d88dd701ed178;hpb=b2d7ec671b225873b6e689cdb426132d90557585 diff --git a/include/tr_idp.h b/include/tr_idp.h index aa407b8..68d669e 100644 --- a/include/tr_idp.h +++ b/include/tr_idp.h @@ -38,7 +38,7 @@ #include #include -#include +#include #include typedef struct tr_aaa_server { @@ -46,6 +46,10 @@ 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 */ @@ -75,14 +79,28 @@ 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))) -char *tr_idp_realm_to_str(TALLOC_CTX *mem_ctx, TR_IDP_REALM *idp); +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 *tr_idp_aaa_server_lookup(TR_IDP_REALM *idp_realms, TR_NAME *idp_realm_name, TR_NAME *comm); +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