18 #define VARIANT_NATIVE 1
28 unsigned int count = 0;
42 for (; gIter != NULL; gIter = gIter->next) {
77 if (is_multiply_active(rsc)) {
90 while (g_hash_table_iter_next(&gIter, NULL, (
void **)&local_node)) {
109 for (; gIter != NULL; gIter = gIter->next) {
118 crm_debug(
"%s is active on multiple nodes including %s: %s",
126 if (rsc->
parent != NULL) {
137 for (GList *child = rsc->
children; child != NULL; child = child->next) {
146 native_variant_data_t *native_data = NULL;
152 native_data = calloc(1,
sizeof(native_variant_data_t));
171 recursive_clear_unique(parent);
172 recursive_clear_unique(rsc);
177 pe_err(
"Resource %s is of type %s and therefore "
178 "cannot be used as a promotable clone resource",
221 const char *rid =
ID(rsc->
xml);
230 }
else if (!strcmp(
id, rsc->
id)) {
240 match = pe_base_name_eq(rsc,
id);
243 if (match && on_node) {
244 bool match_node = rsc_is_on_node(rsc, on_node,
flags);
246 if (match_node == FALSE) {
270 char *value_copy = NULL;
271 const char *value = NULL;
272 GHashTable *hash = NULL;
273 GHashTable *local_hash = NULL;
276 CRM_CHECK(name != NULL && strlen(name) != 0,
return NULL);
280 if (create || g_hash_table_size(rsc->
parameters) == 0) {
287 local_hash = crm_str_table_new();
296 value = g_hash_table_lookup(hash, name);
299 value = g_hash_table_lookup(rsc->
meta, name);
303 value_copy = strdup(value);
305 if (local_hash != NULL) {
306 g_hash_table_destroy(local_hash);
316 for (; gIter != NULL; gIter = gIter->next) {
333 struct print_data_s {
339 native_print_attr(gpointer key, gpointer value, gpointer user_data)
341 long options = ((
struct print_data_s *)user_data)->options;
342 void *print_data = ((
struct print_data_s *)user_data)->print_data;
344 status_print(
"Option: %s = %s\n", (
char *)key, (
char *)value);
350 const char *pending_state = NULL;
353 pending_state =
"Starting";
356 pending_state =
"Stopping";
359 pending_state =
"Migrating";
363 pending_state =
"Migrating";
366 pending_state =
"Promoting";
369 pending_state =
"Demoting";
372 return pending_state;
378 const char *pending_task = NULL;
381 pending_task =
"Monitoring";
411 native_displayable_state(
resource_t *rsc,
long options)
413 const char *rsc_state = NULL;
416 rsc_state = native_pending_state(rsc);
418 if (rsc_state == NULL) {
419 rsc_state =
role2text(native_displayable_role(rsc));
425 native_print_xml(
resource_t * rsc,
const char *pre_text,
long options,
void *print_data)
429 const char *rsc_state = native_displayable_state(rsc, options);
430 const char *target_role = NULL;
456 const char *pending_task = native_pending_task(rsc);
479 for (; gIter != NULL; gIter = gIter->next) {
482 status_print(
"%s <node name=\"%s\" id=\"%s\" cached=\"%s\"/>\n", pre_text,
495 static inline const char *
504 const char *desc = NULL;
507 const char *target_role = NULL;
508 enum rsc_role_e role = native_displayable_role(rsc);
512 char buffer[LINE_MAX];
513 char flagBuffer[LINE_MAX];
521 crm_trace(
"skipping print of internal resource %s", rsc->id);
532 native_print_xml(rsc, pre_text, options, print_data);
547 }
else if (rsc->variant ==
pe_native && (rsc->running_on == NULL)) {
550 }
else if (g_list_length(rsc->running_on) > 1) {
562 offset += snprintf(buffer + offset, LINE_MAX - offset,
"%s", pre_text);
564 offset += snprintf(buffer + offset, LINE_MAX - offset,
"%s", name);
565 offset += snprintf(buffer + offset, LINE_MAX - offset,
"\t(%s",
class);
568 offset += snprintf(buffer + offset, LINE_MAX - offset,
"::%s", prov);
570 offset += snprintf(buffer + offset, LINE_MAX - offset,
":%s):\t", kind);
572 offset += snprintf(buffer + offset, LINE_MAX - offset,
" ORPHANED ");
575 offset += snprintf(buffer + offset, LINE_MAX - offset,
"FAILED %s",
role2text(role));
577 offset += snprintf(buffer + offset, LINE_MAX - offset,
"FAILED");
579 const char *rsc_state = native_displayable_state(rsc, options);
581 offset += snprintf(buffer + offset, LINE_MAX - offset,
"%s", rsc_state);
585 offset += snprintf(buffer + offset, LINE_MAX - offset,
" %s", node->
details->
uname);
588 flagOffset += snprintf(flagBuffer + flagOffset, LINE_MAX - flagOffset,
589 "%sUNCLEAN", comma_if(flagOffset));
594 const char *pending_task = native_pending_task(rsc);
597 flagOffset += snprintf(flagBuffer + flagOffset, LINE_MAX - flagOffset,
598 "%s%s", comma_if(flagOffset), pending_task);
609 flagOffset += snprintf(flagBuffer + flagOffset, LINE_MAX - flagOffset,
610 "%sdisabled", comma_if(flagOffset));
611 rsc->cluster->disabled_resources++;
615 flagOffset += snprintf(flagBuffer + flagOffset, LINE_MAX - flagOffset,
616 "%starget-role:%s", comma_if(flagOffset), target_role);
617 rsc->cluster->disabled_resources++;
622 flagOffset += snprintf(flagBuffer + flagOffset, LINE_MAX - flagOffset,
623 "%sblocked", comma_if(flagOffset));
624 rsc->cluster->blocked_resources++;
627 flagOffset += snprintf(flagBuffer + flagOffset, LINE_MAX - flagOffset,
628 "%sunmanaged", comma_if(flagOffset));
632 flagOffset += snprintf(flagBuffer + flagOffset, LINE_MAX - flagOffset,
633 "%sfailure ignored", comma_if(flagOffset));
642 status_print(
"%s (%s)%s%s", buffer, flagBuffer, desc?
" ":
"", desc?desc:
"");
644 status_print(
"%s%s%s", buffer, desc?
" ":
"", desc?desc:
"");
663 }
else if (g_list_length(rsc->running_on) > 1) {
674 for (; gIter != NULL; gIter = gIter->next) {
715 struct print_data_s pdata;
717 pdata.options = options;
718 pdata.print_data = print_data;
719 g_hash_table_foreach(rsc->parameters, native_print_attr, &pdata);
726 status_print(
"%s\t(%s%svariant=%s, priority=%f)", pre_text,
729 crm_element_name(rsc->xml), (
double)rsc->priority);
731 g_hash_table_iter_init(&iter, rsc->allowed_nodes);
732 while (g_hash_table_iter_next(&iter, NULL, (
void **)&n)) {
733 status_print(
"%s\t * %s %d", pre_text, n->details->uname, n->weight);
742 g_hash_table_iter_init(&iter, rsc->allowed_nodes);
743 while (g_hash_table_iter_next(&iter, NULL, (
void **)&n)) {
756 native_print_xml(rsc, pre_text, options, print_data);
760 node = pe__current_node(rsc);
773 pe_rsc_trace(rsc,
"Freeing resource action list (not the data)");
808 for (; gIter != NULL; gIter = gIter->next) {
814 }
else if (current) {
828 if (result && (result->next == NULL)) {
835 for (; gIter != NULL; gIter = gIter->next) {
839 *list = g_list_append(*list, node);
849 get_rscs_brief(
GListPtr rsc_list, GHashTable * rsc_table, GHashTable * active_table)
853 for (; gIter != NULL; gIter = gIter->next) {
860 char buffer[LINE_MAX];
862 int *rsc_counter = NULL;
863 int *active_counter = NULL;
869 offset += snprintf(buffer + offset, LINE_MAX - offset,
"%s",
class);
872 offset += snprintf(buffer + offset, LINE_MAX - offset,
"::%s", prov);
874 offset += snprintf(buffer + offset, LINE_MAX - offset,
":%s", kind);
878 rsc_counter = g_hash_table_lookup(rsc_table, buffer);
879 if (rsc_counter == NULL) {
880 rsc_counter = calloc(1,
sizeof(
int));
882 g_hash_table_insert(rsc_table, strdup(buffer), rsc_counter);
890 for (; gIter2 != NULL; gIter2 = gIter2->next) {
892 GHashTable *node_table = NULL;
898 node_table = g_hash_table_lookup(active_table, node->
details->
uname);
899 if (node_table == NULL) {
900 node_table = crm_str_table_new();
901 g_hash_table_insert(active_table, strdup(node->
details->
uname), node_table);
904 active_counter = g_hash_table_lookup(node_table, buffer);
905 if (active_counter == NULL) {
906 active_counter = calloc(1,
sizeof(
int));
908 g_hash_table_insert(node_table, strdup(buffer), active_counter);
917 destroy_node_table(gpointer
data)
919 GHashTable *node_table =
data;
922 g_hash_table_destroy(node_table);
928 void *print_data, gboolean print_all)
930 GHashTable *rsc_table = crm_str_table_new();
931 GHashTable *active_table = g_hash_table_new_full(
crm_str_hash, g_str_equal,
932 free, destroy_node_table);
933 GHashTableIter hash_iter;
935 int *rsc_counter = NULL;
937 get_rscs_brief(rsc_list, rsc_table, active_table);
939 g_hash_table_iter_init(&hash_iter, rsc_table);
940 while (g_hash_table_iter_next(&hash_iter, (gpointer *)&
type, (gpointer *)&rsc_counter)) {
941 GHashTableIter hash_iter2;
942 char *node_name = NULL;
943 GHashTable *node_table = NULL;
944 int active_counter_all = 0;
946 g_hash_table_iter_init(&hash_iter2, active_table);
947 while (g_hash_table_iter_next(&hash_iter2, (gpointer *)&node_name, (gpointer *)&node_table)) {
948 int *active_counter = g_hash_table_lookup(node_table,
type);
950 if (active_counter == NULL || *active_counter == 0) {
954 active_counter_all += *active_counter;
966 status_print(
"%s%d/%d\t(%s):\tActive %s\n", pre_text ? pre_text :
"",
967 active_counter ? *active_counter : 0,
968 rsc_counter ? *rsc_counter : 0,
type,
969 active_counter && (*active_counter > 0) && node_name ? node_name :
"");
971 status_print(
"%s%d\t(%s):\tActive %s\n", pre_text ? pre_text :
"",
972 active_counter ? *active_counter : 0,
type,
973 active_counter && (*active_counter > 0) && node_name ? node_name :
"");
981 if (print_all && active_counter_all == 0) {
986 status_print(
"%s%d/%d\t(%s):\tActive\n", pre_text ? pre_text :
"",
988 rsc_counter ? *rsc_counter : 0,
type);
997 g_hash_table_destroy(rsc_table);
1001 g_hash_table_destroy(active_table);
1002 active_table = NULL;