Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

zowelog zss format handler #160

Closed
wants to merge 7 commits into from

Conversation

sakeerthy
Copy link
Contributor

@sakeerthy sakeerthy commented Feb 27, 2020

Dependent on zowe/zowe-common-c#126

Do not merge this until zowe common c is approved/merged so this can point to the correct zowe common c

Signed-off-by: sakeerthy sakeerthy@gmail.com

Signed-off-by: sakeerthy <sakeerthy@gmail.com>
Signed-off-by: sakeerthy <sakeerthy@gmail.com>
Signed-off-by: sakeerthy <sakeerthy@gmail.com>
Signed-off-by: sakeerthy <sakeerthy@gmail.com>
Signed-off-by: sakeerthy <sakeerthy@gmail.com>
Signed-off-by: sakeerthy <sakeerthy@gmail.com>
@sakeerthy sakeerthy changed the title WIP zowelog zss format handler zowelog zss format handler Feb 28, 2020
Copy link
Contributor

@ifakhrutdinov ifakhrutdinov left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This needs more core review, I have to finish it later. These changes have multiple serious issues.

unsigned int id = compID & 0xFFFFFFFF;
if(compID >= LOG_PROD_COMMON && compID < LOG_PROD_ZIS) {
snprintf(prefix,sizeof(LOG_PREFIX_ZCC),LOG_PREFIX_ZCC);
switch (id) { // most of these don't actally log, but are defined in logging.h
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you please use the switch statement format we've already used in the ZSS code?

For example,

static int translateLogLevelToClientTraceLevel(int logLevel) {

  int traceLevel = CLIENT_TRACE_LEVEL_NA;
  switch (logLevel) {
  case ZOWE_LOG_SEVERE:
    traceLevel = CLIENT_TRACE_LEVEL_SEVERE;
    break;
  case ZOWE_LOG_WARNING:
    traceLevel = CLIENT_TRACE_LEVEL_WARNING;
    break;
  case ZOWE_LOG_INFO:
    traceLevel = CLIENT_TRACE_LEVEL_INFO;
    break;
  case ZOWE_LOG_DEBUG:
    traceLevel = CLIENT_TRACE_LEVEL_FINE;
    break;
  case ZOWE_LOG_DEBUG2:
    traceLevel = CLIENT_TRACE_LEVEL_FINER;
    break;
  case ZOWE_LOG_DEBUG3:
    traceLevel = CLIENT_TRACE_LEVEL_FINEST;
    break;
  }

  return traceLevel;
}

ACEE *acee;
acee = getAddressSpaceAcee();
char user[USER_SIZE] = { 0 };
snprintf(user,sizeof(user),acee->aceeuser+1);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Consider putting spaces between argument, it's much easier to read it that way.


stck += getLocalTimeOffset();

stckToLogTimestamp(stck, timestamp);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is there anything better in LE? I think you can get pretty formatted timestamp using the standard library.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's easy to create an ISO8601 timestamp using C POSIX functions.

struct timeval tv;                                                  
struct tm tm;                                                       
gettimeofday(&tv, NULL);                                            
localtime_r(&tv.tv_sec, &tm);     
static const size_t ISO8601_LEN = 30;                                      
char datetime[ISO8601_LEN];                                         
char timestamp[ISO8601_LEN]; // ISO-8601 timestamp                  
strftime(datetime, sizeof datetime, "%Y-%m-%dT%H:%M:%S", &tm);      
snprintf(timestamp, sizeof timestamp, "%s.%d", datetime, tv.tv_usec)
puts(timestamp);                                                    


unsigned int id = compID & 0xFFFFFFFF;
if(compID >= LOG_PROD_COMMON && compID < LOG_PROD_ZIS) {
snprintf(prefix,sizeof(LOG_PREFIX_ZCC),LOG_PREFIX_ZCC);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Since you don't need to do complex formatting, consider using something more lightweight than snprintf.

}
else if (compID > LOG_PROD_PLUGINS) {
snprintf(suffix,sizeof(component->name),"%s",(strrchr(component->name, '/')+1)); // given more characters than it writes
snprintf(prefix,sizeof(component->name)-sizeof(suffix),"%s",component->name);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

sizeof(component->name) is either 4 or 8, sizeof(suffix) is 128, you'll get either 4294967172 or 4294967176.

}

char *filename;
filename = strrchr(path, '/'); // returns a pointer to the last occurence of '/'
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What if there is no /?

filename+=1;
// formatting + prefix + suffix + filename + line number
int locationSize = LOCATION_PREFIX_PADDING + strlen(prefix) + strlen(suffix) + strlen(filename) + LOCATION_SUFFIX_PADDING;
*locationInfo = (char*) safeMalloc(locationSize,"locationInfo");
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think it's a really bad idea to allocate storage in a logging function. Even so, where is the NULL check? Where do you free this storage?

break;
case LOG_COMP_CMS: snprintf(suffix,sizeof(LOG_COMP_TEXT_CMS),LOG_COMP_TEXT_CMS);
break;
case 0xC0001: snprintf(suffix,sizeof(LOG_COMP_TEXT_CMS),LOG_COMP_TEXT_CMS);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Magic numbers.

}
}
else if (compID > LOG_PROD_PLUGINS) {
snprintf(suffix,sizeof(component->name),"%s",(strrchr(component->name, '/')+1)); // given more characters than it writes
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What if strrchr is NULL.

Signed-off-by: sakeerthy <sakeerthy@gmail.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants