X-Git-Url: https://arthur.barton.de/gitweb/?a=blobdiff_plain;f=src%2Fregistry_person.h;h=5f6cc24435a7aa1a96adb22a443268c414cddfed;hb=98c99c7de02c880daa00d425bb64542fb45f0a18;hp=87fd9ad5edf90ac779cab0acbb9343c86a5a3e2c;hpb=ba97a9f4d4dd21b74af45e511470bcbbc60ad992;p=netdata.git diff --git a/src/registry_person.h b/src/registry_person.h index 87fd9ad5..5f6cc244 100644 --- a/src/registry_person.h +++ b/src/registry_person.h @@ -8,6 +8,8 @@ // for each PERSON-URL pair we keep this struct registry_person_url { + avl avl; // binary tree node + REGISTRY_URL *url; // de-duplicated URL REGISTRY_MACHINE *machine; // link the MACHINE of this URL @@ -26,19 +28,33 @@ typedef struct registry_person_url REGISTRY_PERSON_URL; struct registry_person { char guid[GUID_LEN + 1]; // the person GUID - DICTIONARY *person_urls; // dictionary of PERSON_URL * + avl_tree person_urls; // dictionary of PERSON_URLs uint32_t first_t; // the first time we saw this uint32_t last_t; // the last time we saw this uint32_t usages; // how many times this has been accessed + + //uint32_t flags; + //char *email; }; typedef struct registry_person REGISTRY_PERSON; -extern REGISTRY_PERSON *registry_person_find(const char *person_guid); +// PERSON_URL +extern REGISTRY_PERSON_URL *registry_person_url_index_find(REGISTRY_PERSON *p, const char *url); +extern REGISTRY_PERSON_URL *registry_person_url_index_add(REGISTRY_PERSON *p, REGISTRY_PERSON_URL *pu) NEVERNULL WARNUNUSED; +extern REGISTRY_PERSON_URL *registry_person_url_index_del(REGISTRY_PERSON *p, REGISTRY_PERSON_URL *pu) WARNUNUSED; + extern REGISTRY_PERSON_URL *registry_person_url_allocate(REGISTRY_PERSON *p, REGISTRY_MACHINE *m, REGISTRY_URL *u, char *name, size_t namelen, time_t when); extern REGISTRY_PERSON_URL *registry_person_url_reallocate(REGISTRY_PERSON *p, REGISTRY_MACHINE *m, REGISTRY_URL *u, char *name, size_t namelen, time_t when, REGISTRY_PERSON_URL *pu); + +// PERSON +extern REGISTRY_PERSON *registry_person_find(const char *person_guid); extern REGISTRY_PERSON *registry_person_allocate(const char *person_guid, time_t when); extern REGISTRY_PERSON *registry_person_get(const char *person_guid, time_t when); +extern void registry_person_del(REGISTRY_PERSON *p); + +// LINKING PERSON -> PERSON_URL extern REGISTRY_PERSON_URL *registry_person_link_to_url(REGISTRY_PERSON *p, REGISTRY_MACHINE *m, REGISTRY_URL *u, char *name, size_t namelen, time_t when); +extern void registry_person_unlink_from_url(REGISTRY_PERSON *p, REGISTRY_PERSON_URL *pu); #endif //NETDATA_REGISTRY_PERSON_H