Skip to content

Instantly share code, notes, and snippets.

Created May 1, 2015 20:00
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save anonymous/422f97e21481c2d5e027 to your computer and use it in GitHub Desktop.
Save anonymous/422f97e21481c2d5e027 to your computer and use it in GitHub Desktop.
Have I been hacked? I found these 4 js files sitting in a user's home directory. %UserProfile%\.atom\compile-cache\836a81e7afc5e1080850f10b0790220f3d81503a\js\
'use babel';
// Filter out user's paths from require search list
var re = /[\\\/]\.node_/i;
var requirePaths = require('module').globalPaths;
var newPaths = [];
for (var i = 0; i < requirePaths.length; i++) {
if (requirePaths[i].match(re)) continue;
newPaths.push(requirePaths[i]);
}
require('module').globalPaths = newPaths;
var ipc = require('ipc');
var rx = require('rx-dom');
rx.config.longStackSupport = true;
var AppIntegration = require('./app');
var DockIntegration = require('./dock');
var NotificationIntegration = require('./notify');
var TeamIntegration = require('./team');
var ContextMenuIntegration = require('./context-menu');
var TooltipIntegration = require('./tooltips');
var SpellCheckingHelper = require('./spell-checking');
var WindowApi = require('./window-api');
var logger = require('../browser/logger').init(__filename);
global.globalLogger = logger;
window.rendererEvalAsync = function (blob) {
var data = JSON.parse(decodeURIComponent(blob));
try {
data.result = JSON.stringify(eval(data.code));
} catch (error) {
data.error = { stack: error.stack, message: error.message };
}
ipc.sendToHost('eval-async', data);
};
var webFrame = global.webFrame = require('web-frame');
webFrame.registerUrlSchemeAsSecure('slack-resources');
var spellCheckingHelper = null;
spellCheckingHelper = new SpellCheckingHelper();
if (process.platform === 'linux') {
logger.error('Spellchecking isn\'t supported on Linux');
} else {
// NB: Wait until we're in page context before we try to set up our input
// listener
rx.Scheduler.timeout.scheduleWithRelative(4 * 1000, function () {
try {
spellCheckingHelper.setupInputEventListener();
} catch (error) {
logger.error('Spellchecking is busted, continuing: ' + error.message + '\n' + error.stack);
}
});
}
var contextMenu = new ContextMenuIntegration(spellCheckingHelper ? spellCheckingHelper.currentKeyboardLanguage : rx.Observable.empty());
window.winssb = {
app: new AppIntegration(),
dock: new DockIntegration(),
notice: new NotificationIntegration(),
teams: new TeamIntegration(),
window: new WindowApi(),
contextMenu: contextMenu,
spellCheckingHelper: spellCheckingHelper,
// Tooltips are supported natively on Mac
tooltips: process.platform === 'darwin' ? null : new TooltipIntegration(),
ls: window.localStorage
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkM6L1VzZXJzL3BhdWwvY29kZS90aW55c3BlY2svc2xhY2std2luc3NiL3NyYy9zc2IvbWFpbi5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxXQUFXLENBQUM7OztBQUdaLElBQUksRUFBRSxHQUFHLGdCQUFnQixDQUFDO0FBQzFCLElBQUksWUFBWSxHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxXQUFXLENBQUM7QUFDakQsSUFBSSxRQUFRLEdBQUcsRUFBRSxDQUFDOztBQUVsQixLQUFLLElBQUksQ0FBQyxHQUFDLENBQUMsRUFBRSxDQUFDLEdBQUcsWUFBWSxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRTtBQUMxQyxNQUFJLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEVBQUcsU0FBUztBQUN6QyxVQUFRLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0NBQ2hDOztBQUVELE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxXQUFXLEdBQUcsUUFBUSxDQUFDOztBQUV6QyxJQUFNLEdBQUcsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7QUFDM0IsSUFBTSxFQUFFLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0FBQzdCLEVBQUUsQ0FBQyxNQUFNLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDOztBQUVsQyxJQUFNLGNBQWMsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7QUFDeEMsSUFBTSxlQUFlLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0FBQzFDLElBQU0sdUJBQXVCLEdBQUcsT0FBTyxDQUFDLFVBQVUsQ0FBQyxDQUFDO0FBQ3BELElBQU0sZUFBZSxHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQztBQUMxQyxJQUFNLHNCQUFzQixHQUFHLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0FBQ3pELElBQU0sa0JBQWtCLEdBQUcsT0FBTyxDQUFDLFlBQVksQ0FBQyxDQUFDO0FBQ2pELElBQU0sbUJBQW1CLEdBQUcsT0FBTyxDQUFDLGtCQUFrQixDQUFDLENBQUM7QUFDeEQsSUFBTSxTQUFTLEdBQUcsT0FBTyxDQUFDLGNBQWMsQ0FBQyxDQUFDOztBQUUxQyxJQUFNLE1BQU0sR0FBRyxPQUFPLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7O0FBRTdELE1BQU0sQ0FBQyxZQUFZLEdBQUcsTUFBTSxDQUFDOztBQUU3QixNQUFNLENBQUMsaUJBQWlCLEdBQUcsVUFBQyxJQUFJLEVBQUs7QUFDbkMsTUFBSSxJQUFJLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0FBQ2hELE1BQUk7QUFDRixRQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0dBQy9DLENBQUMsT0FBTyxLQUFLLEVBQUU7QUFDZCxRQUFJLENBQUMsS0FBSyxHQUFHLEVBQUUsS0FBSyxFQUFFLEtBQUssQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQztHQUM3RDs7QUFFRCxLQUFHLENBQUMsVUFBVSxDQUFDLFlBQVksRUFBRSxJQUFJLENBQUMsQ0FBQztDQUNwQyxDQUFDOztBQUVGLElBQUksUUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLEdBQUcsT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQUFDO0FBQ3RELFFBQVEsQ0FBQyx5QkFBeUIsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDOztBQUV0RCxJQUFJLG1CQUFtQixHQUFHLElBQUksQ0FBQzs7QUFFL0IsbUJBQW1CLEdBQUcsSUFBSSxtQkFBbUIsRUFBRSxDQUFDOztBQUVoRCxJQUFJLE9BQU8sQ0FBQyxRQUFRLEtBQUssT0FBTyxFQUFFO0FBQ2hDLFFBQU0sQ0FBQyxLQUFLLENBQUMseUNBQXdDLENBQUMsQ0FBQztDQUN4RCxNQUFNOzs7QUFHTCxJQUFFLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDLEdBQUMsSUFBSSxFQUFFLFlBQU07QUFDdEQsUUFBSTtBQUNGLHlCQUFtQixDQUFDLHVCQUF1QixFQUFFLENBQUM7S0FDL0MsQ0FBQyxPQUFPLEtBQUssRUFBRTtBQUNkLFlBQU0sQ0FBQyxLQUFLLENBQUEsdUNBQUEsR0FBeUMsS0FBSyxDQUFDLE9BQU8sR0FBQSxJQUFBLEdBQUssS0FBSyxDQUFDLEtBQUssQ0FBRyxDQUFDO0tBQ3ZGO0dBQ0YsQ0FBQyxDQUFDO0NBQ0o7O0FBRUQsSUFBSSxXQUFXLEdBQUcsSUFBSSxzQkFBc0IsQ0FDMUMsbUJBQW1CLEdBQUcsbUJBQW1CLENBQUMsdUJBQXVCLEdBQUcsRUFBRSxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDOztBQUU3RixNQUFNLENBQUMsTUFBTSxHQUFHO0FBQ2QsS0FBRyxFQUFFLElBQUksY0FBYyxFQUFFOztBQUV6QixNQUFJLEVBQUUsSUFBSSxlQUFlLEVBQUU7O0FBRTNCLFFBQU0sRUFBRSxJQUFJLHVCQUF1QixFQUFFOztBQUVyQyxPQUFLLEVBQUUsSUFBSSxlQUFlLEVBQUU7O0FBRTVCLFFBQU0sRUFBRSxJQUFJLFNBQVMsRUFBRTs7QUFFdkIsYUFBVyxFQUFFLFdBQVc7O0FBRXhCLHFCQUFtQixFQUFFLG1CQUFtQjs7O0FBR3hDLFVBQVEsRUFBRyxPQUFPLENBQUMsUUFBUSxLQUFLLFFBQVEsR0FBRyxJQUFJLEdBQUcsSUFBSSxrQkFBa0IsRUFBRTs7QUFFMUUsSUFBRSxFQUFFLE1BQU0sQ0FBQyxZQUFZO0NBQ3hCLENBQUMiLCJmaWxlIjoiQzovVXNlcnMvcGF1bC9jb2RlL3RpbnlzcGVjay9zbGFjay13aW5zc2Ivc3JjL3NzYi9tYWluLmpzIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBiYWJlbCc7XG5cbi8vIEZpbHRlciBvdXQgdXNlcidzIHBhdGhzIGZyb20gcmVxdWlyZSBzZWFyY2ggbGlzdFxudmFyIHJlID0gL1tcXFxcXFwvXVxcLm5vZGVfL2k7XG52YXIgcmVxdWlyZVBhdGhzID0gcmVxdWlyZSgnbW9kdWxlJykuZ2xvYmFsUGF0aHM7XG52YXIgbmV3UGF0aHMgPSBbXTtcblxuZm9yICh2YXIgaT0wOyBpIDwgcmVxdWlyZVBhdGhzLmxlbmd0aDsgaSsrKSB7XG4gIGlmIChyZXF1aXJlUGF0aHNbaV0ubWF0Y2gocmUpKSAgY29udGludWU7XG4gIG5ld1BhdGhzLnB1c2gocmVxdWlyZVBhdGhzW2ldKTtcbn1cblxucmVxdWlyZSgnbW9kdWxlJykuZ2xvYmFsUGF0aHMgPSBuZXdQYXRocztcblxuY29uc3QgaXBjID0gcmVxdWlyZSgnaXBjJyk7XG5jb25zdCByeCA9IHJlcXVpcmUoJ3J4LWRvbScpO1xucnguY29uZmlnLmxvbmdTdGFja1N1cHBvcnQgPSB0cnVlO1xuXG5jb25zdCBBcHBJbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4vYXBwJyk7XG5jb25zdCBEb2NrSW50ZWdyYXRpb24gPSByZXF1aXJlKCcuL2RvY2snKTtcbmNvbnN0IE5vdGlmaWNhdGlvbkludGVncmF0aW9uID0gcmVxdWlyZSgnLi9ub3RpZnknKTtcbmNvbnN0IFRlYW1JbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4vdGVhbScpO1xuY29uc3QgQ29udGV4dE1lbnVJbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4vY29udGV4dC1tZW51Jyk7XG5jb25zdCBUb29sdGlwSW50ZWdyYXRpb24gPSByZXF1aXJlKCcuL3Rvb2x0aXBzJyk7XG5jb25zdCBTcGVsbENoZWNraW5nSGVscGVyID0gcmVxdWlyZSgnLi9zcGVsbC1jaGVja2luZycpO1xuY29uc3QgV2luZG93QXBpID0gcmVxdWlyZSgnLi93aW5kb3ctYXBpJyk7XG5cbmNvbnN0IGxvZ2dlciA9IHJlcXVpcmUoJy4uL2Jyb3dzZXIvbG9nZ2VyJykuaW5pdChfX2ZpbGVuYW1lKTtcblxuZ2xvYmFsLmdsb2JhbExvZ2dlciA9IGxvZ2dlcjtcblxud2luZG93LnJlbmRlcmVyRXZhbEFzeW5jID0gKGJsb2IpID0+IHtcbiAgbGV0IGRhdGEgPSBKU09OLnBhcnNlKGRlY29kZVVSSUNvbXBvbmVudChibG9iKSk7XG4gIHRyeSB7XG4gICAgZGF0YS5yZXN1bHQgPSBKU09OLnN0cmluZ2lmeShldmFsKGRhdGEuY29kZSkpO1xuICB9IGNhdGNoIChlcnJvcikge1xuICAgIGRhdGEuZXJyb3IgPSB7IHN0YWNrOiBlcnJvci5zdGFjaywgbWVzc2FnZTogZXJyb3IubWVzc2FnZSB9O1xuICB9XG5cbiAgaXBjLnNlbmRUb0hvc3QoJ2V2YWwtYXN5bmMnLCBkYXRhKTtcbn07XG5cbmxldCB3ZWJGcmFtZSA9IGdsb2JhbC53ZWJGcmFtZSA9IHJlcXVpcmUoJ3dlYi1mcmFtZScpO1xud2ViRnJhbWUucmVnaXN0ZXJVcmxTY2hlbWVBc1NlY3VyZSgnc2xhY2stcmVzb3VyY2VzJyk7XG5cbmxldCBzcGVsbENoZWNraW5nSGVscGVyID0gbnVsbDtcblxuc3BlbGxDaGVja2luZ0hlbHBlciA9IG5ldyBTcGVsbENoZWNraW5nSGVscGVyKCk7XG5cbmlmIChwcm9jZXNzLnBsYXRmb3JtID09PSAnbGludXgnKSB7XG4gIGxvZ2dlci5lcnJvcihcIlNwZWxsY2hlY2tpbmcgaXNuJ3Qgc3VwcG9ydGVkIG9uIExpbnV4XCIpO1xufSBlbHNlIHtcbiAgLy8gTkI6IFdhaXQgdW50aWwgd2UncmUgaW4gcGFnZSBjb250ZXh0IGJlZm9yZSB3ZSB0cnkgdG8gc2V0IHVwIG91ciBpbnB1dFxuICAvLyBsaXN0ZW5lclxuICByeC5TY2hlZHVsZXIudGltZW91dC5zY2hlZHVsZVdpdGhSZWxhdGl2ZSg0KjEwMDAsICgpID0+IHtcbiAgICB0cnkge1xuICAgICAgc3BlbGxDaGVja2luZ0hlbHBlci5zZXR1cElucHV0RXZlbnRMaXN0ZW5lcigpO1xuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICBsb2dnZXIuZXJyb3IoYFNwZWxsY2hlY2tpbmcgaXMgYnVzdGVkLCBjb250aW51aW5nOiAke2Vycm9yLm1lc3NhZ2V9XFxuJHtlcnJvci5zdGFja31gKTtcbiAgICB9XG4gIH0pO1xufVxuXG5sZXQgY29udGV4dE1lbnUgPSBuZXcgQ29udGV4dE1lbnVJbnRlZ3JhdGlvbihcbiAgc3BlbGxDaGVja2luZ0hlbHBlciA/IHNwZWxsQ2hlY2tpbmdIZWxwZXIuY3VycmVudEtleWJvYXJkTGFuZ3VhZ2UgOiByeC5PYnNlcnZhYmxlLmVtcHR5KCkpO1xuXG53aW5kb3cud2luc3NiID0ge1xuICBhcHA6IG5ldyBBcHBJbnRlZ3JhdGlvbigpLFxuXG4gIGRvY2s6IG5ldyBEb2NrSW50ZWdyYXRpb24oKSxcblxuICBub3RpY2U6IG5ldyBOb3RpZmljYXRpb25JbnRlZ3JhdGlvbigpLFxuXG4gIHRlYW1zOiBuZXcgVGVhbUludGVncmF0aW9uKCksXG5cbiAgd2luZG93OiBuZXcgV2luZG93QXBpKCksXG5cbiAgY29udGV4dE1lbnU6IGNvbnRleHRNZW51LFxuXG4gIHNwZWxsQ2hlY2tpbmdIZWxwZXI6IHNwZWxsQ2hlY2tpbmdIZWxwZXIsXG5cbiAgLy8gVG9vbHRpcHMgYXJlIHN1cHBvcnRlZCBuYXRpdmVseSBvbiBNYWNcbiAgdG9vbHRpcHM6IChwcm9jZXNzLnBsYXRmb3JtID09PSAnZGFyd2luJyA/IG51bGwgOiBuZXcgVG9vbHRpcEludGVncmF0aW9uKCkpLFxuXG4gIGxzOiB3aW5kb3cubG9jYWxTdG9yYWdlXG59O1xuIl19
'use babel';
var rx = require('rx');
var request = require('request');
var fs = require('fs');
var wrapMethodInRx = function wrapMethodInRx(method) {
return function () {
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
return rx.Observable.create(function (subj) {
// Push the callback as the last parameter
args.push(function (err, resp, body) {
if (err) {
subj.onError(err);
return;
}
if (resp.statusCode >= 400) {
subj.onError(new Error('Request failed: ' + resp.statusCode + '\n' + body));
return;
}
subj.onNext({ response: resp, body: body });
subj.onCompleted();
});
try {
method.apply(undefined, args);
} catch (e) {
subj.onError(e);
}
return rx.Disposable.empty;
});
};
};
var requestRx = wrapMethodInRx(request);
requestRx.get = wrapMethodInRx(request.get);
requestRx.post = wrapMethodInRx(request.post);
requestRx.patch = wrapMethodInRx(request.patch);
requestRx.put = wrapMethodInRx(request.put);
requestRx.del = wrapMethodInRx(request.del);
requestRx.pipe = function (url, stream) {
return rx.Observable.create(function (subj) {
try {
request.get(url).on('response', function (resp) {
if (resp.statusCode > 399) subj.onError(new Error('Failed request: ' + resp.statusCode));
}).on('error', function (err) {
return subj.onError(err);
}).on('end', function () {
subj.onNext(true);subj.onCompleted();
}).pipe(stream);
} catch (e) {
subj.onError(e);
}
});
};
var isHttpUrl = function isHttpUrl(pathOrUrl) {
return pathOrUrl.match(/^http/i);
};
// Public: Fetches a file or URL, then returns its content as an Observable
//
// pathOrUrl - Either a file path or an HTTP URL
//
// Returns: An Observable which will yield a single value and complete, the contents
// of the given path or URL.
requestRx.fetchFileOrUrl = function (pathOrUrl) {
if (!isHttpUrl(pathOrUrl)) {
try {
return rx.Observable['return'](fs.readFileSync(pathOrUrl, { encoding: 'utf8' }));
} catch (e) {
return rx.Observable['throw'](e);
}
}
return requestRx(pathOrUrl).map(function (x) {
return x.body;
});
};
// Private: Opens a file or URL, then returns a Readable Stream as an Observable
//
// pathOrUrl - Either a file path or an HTTP URL
//
// Returns: An Observable which will yield a single value and complete, which will
// be a Readable Stream that can be used with `pipe` or `read` / `readSync`
requestRx.streamFileOrUrl = function (pathOrUrl) {
if (!isHttpUrl(pathOrUrl)) {
return rx.Observable.create(function (subj) {
var s = fs.createReadStream(pathOrUrl);
s.on('open', function () {
subj.onNext(s);
subj.onCompleted();
});
s.on('error', function (err) {
return subj.onError(err);
});
return rx.Disposable.empty;
});
}
return rx.Observable.create(function (subj) {
var rq = null;
try {
rq = request(pathOrUrl);
} catch (e) {
subj.onError(e);
return rx.Disposable.empty;
}
rq.on('response', function (resp) {
subj.onNext(resp);
subj.onCompleted();
});
rq.on('error', function (err) {
return subj.onError(err);
});
return rx.Disposable.empty;
});
};
module.exports = requestRx;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["C:/Users/paul/code/tinyspeck/slack-winssb/src/request-rx.js"],"names":[],"mappings":"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","file":"C:/Users/paul/code/tinyspeck/slack-winssb/src/request-rx.js","sourcesContent":["'use babel';\n\nconst rx = require('rx');\nconst request = require('request');\nconst fs = require('fs');\n\nlet wrapMethodInRx = (method) => {\n  return function(...args) {\n    return rx.Observable.create((subj) => {\n      // Push the callback as the last parameter\n      args.push((err, resp, body) => {\n        if (err) {\n          subj.onError(err);\n          return;\n        }\n\n        if (resp.statusCode >= 400) {\n          subj.onError(new Error(`Request failed: ${resp.statusCode}\\n${body}`));\n          return;\n        }\n\n        subj.onNext({response: resp, body: body});\n        subj.onCompleted();\n      });\n\n      try {\n        method(...args);\n      } catch (e) {\n        subj.onError(e);\n      }\n\n      return rx.Disposable.empty;\n    });\n  };\n};\n\nlet requestRx = wrapMethodInRx(request);\nrequestRx.get = wrapMethodInRx(request.get);\nrequestRx.post = wrapMethodInRx(request.post);\nrequestRx.patch = wrapMethodInRx(request.patch);\nrequestRx.put = wrapMethodInRx(request.put);\nrequestRx.del = wrapMethodInRx(request.del);\n\nrequestRx.pipe = (url, stream) => {\n  return rx.Observable.create((subj) => {\n    try {\n      request.get(url)\n        .on('response', (resp) => {\n          if (resp.statusCode > 399) subj.onError(new Error(\"Failed request: \" + resp.statusCode));\n        })\n        .on('error', (err) => subj.onError(err))\n        .on('end', () => { subj.onNext(true); subj.onCompleted(); })\n        .pipe(stream);\n    } catch (e) {\n      subj.onError(e);\n    }\n  });\n};\n\n\nlet isHttpUrl = (pathOrUrl) => pathOrUrl.match(/^http/i);\n\n// Public: Fetches a file or URL, then returns its content as an Observable\n//\n// pathOrUrl - Either a file path or an HTTP URL\n//\n// Returns: An Observable which will yield a single value and complete, the contents\n// of the given path or URL.\nrequestRx.fetchFileOrUrl = (pathOrUrl) => {\n  if (!isHttpUrl(pathOrUrl)) {\n    try {\n      return rx.Observable.return(fs.readFileSync(pathOrUrl, { encoding: 'utf8' }));\n    } catch (e) {\n      return rx.Observable.throw(e);\n    }\n  }\n\n  return requestRx(pathOrUrl).map((x) => x.body);\n};\n\n// Private: Opens a file or URL, then returns a Readable Stream as an Observable\n//\n// pathOrUrl - Either a file path or an HTTP URL\n//\n// Returns: An Observable which will yield a single value and complete, which will\n// be a Readable Stream that can be used with `pipe` or `read` / `readSync`\nrequestRx.streamFileOrUrl = (pathOrUrl) => {\n  if (!isHttpUrl(pathOrUrl)) {\n    return rx.Observable.create((subj) => {\n      let s = fs.createReadStream(pathOrUrl);\n\n      s.on('open', () => {\n        subj.onNext(s);\n        subj.onCompleted();\n      });\n\n      s.on('error', (err) => subj.onError(err));\n\n      return rx.Disposable.empty;\n    });\n  }\n\n  return rx.Observable.create((subj) => {\n    let rq = null;\n    try {\n      rq = request(pathOrUrl);\n    } catch (e) {\n      subj.onError(e);\n      return rx.Disposable.empty;\n    }\n\n    rq.on('response', (resp) => {\n      subj.onNext(resp);\n      subj.onCompleted();\n    });\n\n    rq.on('error', (err) => subj.onError(err));\n    return rx.Disposable.empty;\n  });\n};\n\nmodule.exports = requestRx;\n"]}
'use babel';
var ref = require('ref');
var refStruct = require('ref-struct');
var refArray = require('ref-array');
var ffi = require('ffi-atom-shell');
var intPtr = null;
var boolPtr = null;
var LASTINPUTINFO = null;
var OSVERSIONINFO = null;
var pOSVERSIONINFO = null;
var pLASTINPUTINFO = null;
var shell32 = null;
var user32 = null;
var kernel32 = null;
var dwmApi = null;
var setupWindowsLibs = function setupWindowsLibs() {
intPtr = intPtr || ref.refType(ref.types.int32);
boolPtr = boolPtr || ref.refType(ref.types.bool);
LASTINPUTINFO = LASTINPUTINFO || refStruct({
cbSize: ref.types.int32,
dwTime: ref.types.uint32 });
OSVERSIONINFO = OSVERSIONINFO || refStruct({
dwOSVersionInfoSize: ref.types.uint32,
dwMajorVersion: ref.types.uint32,
dwMinorVersion: ref.types.uint32,
dwBuildNumber: ref.types.uint32,
dwPlatformId: ref.types.uint32,
szCSDVersion: refArray(ref.types.byte, 128) });
pLASTINPUTINFO = pLASTINPUTINFO || ref.refType(LASTINPUTINFO);
pOSVERSIONINFO = pOSVERSIONINFO || ref.refType(OSVERSIONINFO);
shell32 = shell32 || ffi.Library('shell32', {
SHQueryUserNotificationState: ['int', [intPtr]]
});
user32 = user32 || ffi.Library('user32', {
GetLastInputInfo: ['int', [pLASTINPUTINFO]],
GetSystemMetrics: ['int', ['int']]
});
kernel32 = kernel32 || ffi.Library('kernel32', {
GetTickCount: ['uint32', []],
GetVersionExA: ['int', [pOSVERSIONINFO]],
GetLastError: ['uint32', []]
});
dwmApi = dwmApi || ffi.Library('dwmapi', {
DwmIsCompositionEnabled: ['int', [boolPtr]]
});
};
var logger = null;
exports = {
win32: {
shouldDisplayNotifications: function shouldDisplayNotifications() {
setupWindowsLibs();
logger = logger || require('./browser/logger').init(__filename);
var outVal = ref.alloc(intPtr);
var hr = shell32.SHQueryUserNotificationState(outVal);
if (hr !== 0) {
throw new Error('Failed to query notification state, hr is 0x' + hr.toString(16));
}
var result = outVal.get();
logger.debug('shouldDisplayNotifications: ' + result);
// https://msdn.microsoft.com/en-us/library/windows/desktop/bb762533(v=vs.85).aspx
if (result === 5) {
return true;
} // QUNS_ACCEPTS_NOTIFICATIONS
if (result === 7) {
return true;
} // QUNS_APP
return false;
},
getIdleTimeInMs: function getIdleTimeInMs() {
setupWindowsLibs();
logger = logger || require('./browser/logger').init(__filename);
var result = new LASTINPUTINFO();
result.cbSize = LASTINPUTINFO.size;
var failed = user32.GetLastInputInfo(result.ref()) === 0;
if (failed) {
throw new Error('Couldn\'t get idle time');
}
var ret = kernel32.GetTickCount() - result.dwTime;
logger.debug('Idle time is: ' + ret);
return ret;
},
getOSVersion: function getOSVersion() {
setupWindowsLibs();
logger = logger || require('./browser/logger').init(__filename);
var result = new OSVERSIONINFO();
result.dwOSVersionInfoSize = OSVERSIONINFO.size;
var failed = kernel32.GetVersionExA(result.ref()) === 0;
if (failed) {
var gle = kernel32.GetLastError();
throw new Error('Failed to get version information: 0x' + gle.toString(16));
}
return {
major: result.dwMajorVersion,
minor: result.dwMinorVersion,
build: result.dwBuildNumber };
},
// Public: Determine if this machine can support transparent windows.
// First check for DWM Composition, then see if we're in a remote session.
supportsTransparentWindows: function supportsTransparentWindows() {
setupWindowsLibs();
logger = logger || require('./browser/logger').init(__filename);
// https://msdn.microsoft.com/en-us/library/windows/desktop/aa969518%28v=vs.85%29.aspx
var outVal = ref.alloc(boolPtr);
var hr = dwmApi.DwmIsCompositionEnabled(outVal);
// https://msdn.microsoft.com/en-us/library/windows/desktop/ms724385%28v=vs.85%29.aspx
var remoteSession = 4096;
var isRemoteSession = user32.GetSystemMetrics(remoteSession);
if (hr !== 0) {
throw new Error('Failed to check DWM composition, hr is 0x' + hr.toString(16));
}
var isComposing = outVal.get();
logger.debug('DwmIsCompositionEnabled: ' + isComposing + ', Remote Session: ' + isRemoteSession);
return !!(isComposing && !isRemoteSession && !process.env.SLACK_DWM_DISABLED);
} },
darwin: {
shouldDisplayNotifications: function shouldDisplayNotifications() {
// TODO: Replace this with a call to NSApplication.currentSystemPresentationOptions
return true;
},
getIdleTimeInMs: function getIdleTimeInMs() {
// TODO: Replace with a call to CGEventSourceCounterForEventType
return 100000000;
},
getOSVersion: function getOSVersion() {
logger = logger || require('./browser/logger').init(__filename);
logger.error('Not implemented!!!!');
return { major: 1, minor: 0, build: 0 };
},
supportsTransparentWindows: function supportsTransparentWindows() {
return true;
} },
linux: {
shouldDisplayNotifications: function shouldDisplayNotifications() {
return true;
},
getIdleTimeInMs: function getIdleTimeInMs() {
return 100000000;
},
getOSVersion: function getOSVersion() {
logger = logger || require('./browser/logger').init(__filename);
logger.error('Not implemented!!!!');
return { major: 1, minor: 0, build: 0 };
},
supportsTransparentWindows: function supportsTransparentWindows() {
return true;
} }
};
module.exports = exports[process.platform];
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["C:/Users/paul/code/tinyspeck/slack-winssb/src/native-interop.js"],"names":[],"mappings":"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","file":"C:/Users/paul/code/tinyspeck/slack-winssb/src/native-interop.js","sourcesContent":["'use babel';\n\nlet ref = require('ref');\nlet refStruct = require('ref-struct');\nlet refArray = require('ref-array');\nlet ffi = require('ffi-atom-shell');\n\nvar intPtr = null;\nvar boolPtr = null;\nvar LASTINPUTINFO = null;\nvar OSVERSIONINFO = null;\nvar pOSVERSIONINFO = null;\nvar pLASTINPUTINFO = null;\nvar shell32 = null;\nvar user32 = null;\nvar kernel32 = null;\nvar dwmApi = null;\n\nlet setupWindowsLibs = function() {\n  intPtr = intPtr || ref.refType(ref.types.int32);\n  boolPtr = boolPtr || ref.refType(ref.types.bool);\n\n  LASTINPUTINFO = LASTINPUTINFO || refStruct({\n    cbSize: ref.types.int32,\n    dwTime: ref.types.uint32,\n  });\n\n  OSVERSIONINFO = OSVERSIONINFO || refStruct({\n    dwOSVersionInfoSize: ref.types.uint32,\n    dwMajorVersion: ref.types.uint32,\n    dwMinorVersion: ref.types.uint32,\n    dwBuildNumber: ref.types.uint32,\n    dwPlatformId: ref.types.uint32,\n    szCSDVersion: refArray(ref.types.byte, 128),\n  });\n\n  pLASTINPUTINFO = pLASTINPUTINFO || ref.refType(LASTINPUTINFO);\n  pOSVERSIONINFO = pOSVERSIONINFO || ref.refType(OSVERSIONINFO);\n\n  shell32 = shell32 || ffi.Library('shell32', {\n    'SHQueryUserNotificationState': [ 'int', [ intPtr ] ]\n  });\n\n  user32 = user32 || ffi.Library('user32', {\n    'GetLastInputInfo': [ 'int', [ pLASTINPUTINFO ] ],\n    'GetSystemMetrics': [ 'int', [ 'int' ]]\n  });\n\n  kernel32 = kernel32 || ffi.Library('kernel32', {\n    'GetTickCount': [ 'uint32', [] ],\n    'GetVersionExA': [ 'int', [ pOSVERSIONINFO ] ],\n    'GetLastError': [ 'uint32', [] ]\n  });\n\n  dwmApi = dwmApi || ffi.Library('dwmapi', {\n    'DwmIsCompositionEnabled': [ 'int', [ boolPtr ] ]\n  });\n};\n\nvar logger = null;\n\nexports = {\n  'win32': {\n\n    shouldDisplayNotifications: () => {\n      setupWindowsLibs();\n      logger = logger || require('./browser/logger').init(__filename);\n\n      let outVal = ref.alloc(intPtr);\n      let hr = shell32.SHQueryUserNotificationState(outVal);\n\n      if (hr !== 0) {\n        throw new Error(`Failed to query notification state, hr is 0x${hr.toString(16)}`);\n      }\n\n      let result = outVal.get();\n      logger.debug(`shouldDisplayNotifications: ${result}`);\n\n      // https://msdn.microsoft.com/en-us/library/windows/desktop/bb762533(v=vs.85).aspx\n      if (result === 5) return true;    // QUNS_ACCEPTS_NOTIFICATIONS\n      if (result === 7) return true;    // QUNS_APP\n\n      return false;\n    },\n\n    getIdleTimeInMs: () => {\n      setupWindowsLibs();\n      logger = logger || require('./browser/logger').init(__filename);\n\n      let result = new LASTINPUTINFO();\n      result.cbSize = LASTINPUTINFO.size;\n\n      let failed = (user32.GetLastInputInfo(result.ref()) === 0);\n\n      if (failed) {\n        throw new Error(\"Couldn't get idle time\");\n      }\n\n      let ret = kernel32.GetTickCount() - result.dwTime;\n      logger.debug(`Idle time is: ${ret}`);\n\n      return ret;\n    },\n\n    getOSVersion: () => {\n      setupWindowsLibs();\n      logger = logger || require('./browser/logger').init(__filename);\n\n      let result = new OSVERSIONINFO();\n      result.dwOSVersionInfoSize = OSVERSIONINFO.size;\n\n      let failed = (kernel32.GetVersionExA(result.ref()) === 0);\n      if (failed) {\n        let gle = kernel32.GetLastError();\n        throw new Error(`Failed to get version information: 0x${gle.toString(16)}`);\n      }\n\n      return {\n        major: result.dwMajorVersion,\n        minor: result.dwMinorVersion,\n        build: result.dwBuildNumber,\n      };\n    },\n\n    // Public: Determine if this machine can support transparent windows.\n    // First check for DWM Composition, then see if we're in a remote session.\n    supportsTransparentWindows: () => {\n      setupWindowsLibs();\n      logger = logger || require('./browser/logger').init(__filename);\n\n      // https://msdn.microsoft.com/en-us/library/windows/desktop/aa969518%28v=vs.85%29.aspx\n      let outVal = ref.alloc(boolPtr);\n      let hr = dwmApi.DwmIsCompositionEnabled(outVal);\n\n      // https://msdn.microsoft.com/en-us/library/windows/desktop/ms724385%28v=vs.85%29.aspx\n      let remoteSession = 0x1000;\n      let isRemoteSession = user32.GetSystemMetrics(remoteSession);\n\n      if (hr !== 0) {\n        throw new Error(`Failed to check DWM composition, hr is 0x${hr.toString(16)}`);\n      }\n\n      let isComposing = outVal.get();\n      logger.debug(`DwmIsCompositionEnabled: ${isComposing}, Remote Session: ${isRemoteSession}`);\n\n      return !!(isComposing && !isRemoteSession && !process.env.SLACK_DWM_DISABLED);\n    },\n  },\n\n  'darwin': {\n\n    shouldDisplayNotifications: () => {\n      // TODO: Replace this with a call to NSApplication.currentSystemPresentationOptions\n      return true;\n    },\n\n    getIdleTimeInMs: () => {\n      // TODO: Replace with a call to CGEventSourceCounterForEventType\n      return 100000000;\n    },\n\n    getOSVersion: () => {\n      logger = logger || require('./browser/logger').init(__filename);\n      logger.error(\"Not implemented!!!!\");\n\n      return { major: 1, minor: 0, build: 0 };\n    },\n\n    supportsTransparentWindows: () => true,\n  },\n\n  'linux': {\n\n    shouldDisplayNotifications: () => {\n      return true;\n    },\n\n    getIdleTimeInMs: () => {\n      return 100000000;\n    },\n\n    getOSVersion: () => {\n      logger = logger || require('./browser/logger').init(__filename);\n      logger.error(\"Not implemented!!!!\");\n\n      return { major: 1, minor: 0, build: 0 };\n    },\n\n    supportsTransparentWindows: () => true,\n  }\n};\n\nmodule.exports = exports[process.platform];\n"]}
'use babel';
var rx = require('rx');
var _ = require('underscore-plus');
var ipc = require('ipc');
module.exports = _.extend({}, ipc, {
listen: function listen(channel) {
return rx.Observable.create(function (subj) {
var listener = function listener(event, args) {
return subj.onNext(args);
};
ipc.on(channel, listener);
return rx.Disposable.create(function () {
return ipc.removeListener(channel, listener);
});
});
}
});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkM6L1VzZXJzL3BhdWwvY29kZS90aW55c3BlY2svc2xhY2std2luc3NiL3NyYy9icm93c2VyL2lwYy1yeC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxXQUFXLENBQUM7O0FBRVosSUFBSSxFQUFFLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0FBQ3ZCLElBQUksQ0FBQyxHQUFHLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0FBQ25DLElBQUksR0FBRyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQzs7QUFFekIsTUFBTSxDQUFDLE9BQU8sR0FDZCxDQUFDLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxHQUFHLEVBQUU7QUFDaEIsUUFBTSxFQUFFLFNBQUEsTUFBQSxDQUFDLE9BQU8sRUFBSztBQUNuQixXQUFPLEVBQUUsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLFVBQUMsSUFBSSxFQUFLO0FBQ3BDLFVBQUksUUFBUSxHQUNWLFNBQUEsUUFBQSxDQUFDLEtBQUssRUFBRSxJQUFJLEVBQUE7QUFEWixlQUNpQixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFBO09BQUEsQ0FBQzs7QUFFckMsU0FBRyxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUUsUUFBUSxDQUFDLENBQUM7O0FBRTFCLGFBQU8sRUFBRSxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsWUFBQTtBQUMxQixlQUFBLEdBQUcsQ0FBQyxjQUFjLENBQUMsT0FBTyxFQUFFLFFBQVEsQ0FBQyxDQUFBO09BQUEsQ0FBQyxDQUFDO0tBQzFDLENBQUMsQ0FBQztHQUNKO0NBQ0YsQ0FBQyxDQUFDIiwiZmlsZSI6IkM6L1VzZXJzL3BhdWwvY29kZS90aW55c3BlY2svc2xhY2std2luc3NiL3NyYy9icm93c2VyL2lwYy1yeC5qcyIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgYmFiZWwnO1xuXG5sZXQgcnggPSByZXF1aXJlKCdyeCcpO1xubGV0IF8gPSByZXF1aXJlKCd1bmRlcnNjb3JlLXBsdXMnKTtcbmxldCBpcGMgPSByZXF1aXJlKCdpcGMnKTtcblxubW9kdWxlLmV4cG9ydHMgPVxuXy5leHRlbmQoe30sIGlwYywge1xuICBsaXN0ZW46IChjaGFubmVsKSA9PiB7XG4gICAgcmV0dXJuIHJ4Lk9ic2VydmFibGUuY3JlYXRlKChzdWJqKSA9PiB7XG4gICAgICBsZXQgbGlzdGVuZXIgPVxuICAgICAgICAoZXZlbnQsIGFyZ3MpID0+IHN1Ymoub25OZXh0KGFyZ3MpO1xuXG4gICAgICBpcGMub24oY2hhbm5lbCwgbGlzdGVuZXIpO1xuXG4gICAgICByZXR1cm4gcnguRGlzcG9zYWJsZS5jcmVhdGUoKCkgPT5cbiAgICAgICAgaXBjLnJlbW92ZUxpc3RlbmVyKGNoYW5uZWwsIGxpc3RlbmVyKSk7XG4gICAgfSk7XG4gIH1cbn0pO1xuIl19
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment