Research
Security News
Malicious npm Packages Inject SSH Backdoors via Typosquatted Libraries
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
hyperloop-macros
Advanced tools
Sweet.js macros to accelerate Hyperloop development.
By now only utilities for Objective-C and Java were implemented;
# Install in your project
npm install --save-dev hyperloop-macros
# Compile your source
sjs my_hyperloop_source.js --module hyperloop-macros/obj-c
// Activate Hyperloop for this file
use hyperloop;
See the example application.
// The `native` keyword makes the class compile to Hyperloop
class native LocDelegate
// For clarity `implements` is (also) aliased as extends
extends NSObject
// Protocol the class responds to
protocol CLLocationManagerDelegate {
// Objective-C style message definition (copy-paste-proof)
- (void) locationManager:(CLLocationManager *) locationManager
didUpdateLocations:(NSArray *) locations {
// Casting is done with the `as` keyword, but for arguments is not necessary
var locationsRecasted = locations as (NSArray *);
// Message passing is activated with `@` in dot-notation style
locationManager@startUpdatingLocation();
// Since the second argument we follow Swift’s form
locationManager@allowDeferredLocationUpdatesUntilTraveled(null, timeout: null);
// But Hyperloop supports actual dot notation too!
locationManager.startUpdatingLocation();
// so do we! Attention! not for 1 argument methods!
// see https://github.com/appcelerator/hyperloop-ios/issues/82
locationManager.allowDeferredLocationUpdatesUntilTraveled(null, timeout: null);
}
}
// `import`s let you skip the package later in the code
import java.lang.Runnable;
import java.lang.Object;
import java.lang.Import;
// The `native` keyword makes the class compile to Hyperloop
class native public com.company.MyRunnable
extends Object
implements Runnable {
// Java style properties...
String aField;
String anotherField;
// And transparent transformation of expressions!
int aPrimitive = 42;
// Java style annotations...
@Override
// Method modifiers and return types
public void run() {
console.log('Here we are!');
}
// And Java style method arguments too!
public Integer someOtherMethod(Integer boxed, int unboxed) {
// Casting is done with the `as` keyword
return (boxed as int) + unboxed;
}
}
TODO
This library, Hyperloop Macros, is free software ("Licensed Software"); you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; including but not limited to, the implied warranty of MERCHANTABILITY, NONINFRINGEMENT, or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License along with this library; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
FAQs
Macros to accelerate Hyperloop development
The npm package hyperloop-macros receives a total of 2 weekly downloads. As such, hyperloop-macros popularity was classified as not popular.
We found that hyperloop-macros demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.