Page Menu
Home
Software Heritage
Search
Configure Global Search
Log In
Files
F8322638
logger.js
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Flag For Later
Size
2 KB
Subscribers
None
logger.js
View Options
import
{
__read
,
__spread
}
from
"tslib"
;
import
{
IS_DEBUG_BUILD
}
from
'./flags'
;
import
{
getGlobalObject
,
getGlobalSingleton
}
from
'./global'
;
// TODO: Implement different loggers for different environments
var
global
=
getGlobalObject
();
/** Prefix for logging strings */
var
PREFIX
=
'Sentry Logger '
;
export
var
CONSOLE_LEVELS
=
[
'debug'
,
'info'
,
'warn'
,
'error'
,
'log'
,
'assert'
];
/**
* Temporarily disable sentry console instrumentations.
*
* @param callback The function to run against the original `console` messages
* @returns The results of the callback
*/
export
function
consoleSandbox
(
callback
)
{
var
global
=
getGlobalObject
();
if
(
!
(
'console'
in
global
))
{
return
callback
();
}
var
originalConsole
=
global
.
console
;
var
wrappedLevels
=
{};
// Restore all wrapped console methods
CONSOLE_LEVELS
.
forEach
(
function
(
level
)
{
// TODO(v7): Remove this check as it's only needed for Node 6
var
originalWrappedFunc
=
originalConsole
[
level
]
&&
originalConsole
[
level
].
__sentry_original__
;
if
(
level
in
global
.
console
&&
originalWrappedFunc
)
{
wrappedLevels
[
level
]
=
originalConsole
[
level
];
originalConsole
[
level
]
=
originalWrappedFunc
;
}
});
try
{
return
callback
();
}
finally
{
// Revert restoration to wrapped state
Object
.
keys
(
wrappedLevels
).
forEach
(
function
(
level
)
{
originalConsole
[
level
]
=
wrappedLevels
[
level
];
});
}
}
function
makeLogger
()
{
var
enabled
=
false
;
var
logger
=
{
enable
:
function
()
{
enabled
=
true
;
},
disable
:
function
()
{
enabled
=
false
;
},
};
if
(
IS_DEBUG_BUILD
)
{
CONSOLE_LEVELS
.
forEach
(
function
(
name
)
{
// eslint-disable-next-line @typescript-eslint/no-explicit-any
logger
[
name
]
=
function
()
{
var
args
=
[];
for
(
var
_i
=
0
;
_i
<
arguments
.
length
;
_i
++
)
{
args
[
_i
]
=
arguments
[
_i
];
}
if
(
enabled
)
{
consoleSandbox
(
function
()
{
var
_a
;
(
_a
=
global
.
console
)[
name
].
apply
(
_a
,
__spread
([
PREFIX
+
"["
+
name
+
"]:"
],
args
));
});
}
};
});
}
else
{
CONSOLE_LEVELS
.
forEach
(
function
(
name
)
{
logger
[
name
]
=
function
()
{
return
undefined
;
};
});
}
return
logger
;
}
// Ensure we only have a single logger instance, even if multiple versions of @sentry/utils are being used
var
logger
;
if
(
IS_DEBUG_BUILD
)
{
logger
=
getGlobalSingleton
(
'logger'
,
makeLogger
);
}
else
{
logger
=
makeLogger
();
}
export
{
logger
};
//# sourceMappingURL=logger.js.map
File Metadata
Details
Attached
Mime Type
text/x-java
Expires
Tue, Jun 3, 7:41 AM (4 d, 5 h ago)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
3352200
Attached To
rDWAPPS Web applications
Event Timeline
Log In to Comment