data:image/s3,"s3://crabby-images/9fef7/9fef7e77a4ff9a4c39b8a32ffd7ebda8c2145888" alt="Malicious PyPI Package Exploits Deezer API for Coordinated Music Piracy"
Research
Security News
Malicious PyPI Package Exploits Deezer API for Coordinated Music Piracy
Socket researchers uncovered a malicious PyPI package exploiting Deezer’s API to enable coordinated music piracy through API abuse and C2 server control.
A natty little data fetching tool for react project that no longer needs to use jQuery/Zepto.
A natty little data fetching tool for react project that no longer needs to use jQuery/Zepto's Ajax.
先将NattyDB和RSVP安装到项目本地
RSVP小而美地实现了
Promise
的概念。
$ npm install natty-db rsvp --save
NattyDB同时包含H5和PC两个版本,请根据项目具体需求来选用。两个版本分别对应的文件路径为:
.pc
)script
标签RSVP + H5版NattyDB
<script src="./node_modules/rsvp/dist/rsvp.min.js"></script>
<script src="./node_modules/natty-db/dist/natty-db.min.js"></script>
RSVP + PC版NattyDB
<script type="text/javascript" src="./node_modules/rsvp/dist/rsvp.min.js"></script>
<script type="text/javascript" src="./node_modules/natty-db/dist/natty-db.pc.min.js"></script>
此处的文档,是假设了项目中使用Webpack作为模块管理工具。
RSVP
依赖如果以模块方式(非script
标签方式)加载RSVP依赖,需要在Webpack配置中使用ProvidePlugin插件将全局RSVP变量引用转换为require('rsvp')
模块引用。
plugins: [
new webpack.ProvidePlugin({
RSVP: 'rsvp'
})
]
在NattyDB模块的package.json
中配置的默认版本就是H5版本,文件路径为:dist/natty-db.min.js
。
$ let NattyDB = require('natty-db');
如果项目需要同时兼容移动端和PC端(目前NattyDB支持到IE8+
),需要在Webpack中配置resolve.alias,将NattyDB指向PC版,引用方式保持和H5版本一样。
Webpack中的配置:
resolve: {
alias: {
'natty-db': 'natty-db/dist/natty-db.pc.min.js'
}
}
NattyDB中一共有三个层级的配置,由上至下分别是全局配置(Global Setting),上下文配置(Context Setting)和接口配置(API Setting),上游配置作为下游配置的默认值,同时又被下游配置所覆盖。
创建项目或模块的db
文件。如db.js
// 引入`natty-db`模块
const NattyDB = request('natty-db');
// 创建一个`DB上下文(DB-Context)`,用于多个`DB`共享默认配置。
let DBC = new NattyDB.Context({
urlPrefix: 'your-url-prefix',
mock: false,
data: {
token: 'your-token'
},
timeout: 5000,
// 数据格式预处理
fix: function(resp) {
return {
success: !resp.hasError,
content: resp.content,
error: resp.error
}
}
});
// 在一个DB上下文中创建一个`DB`,同时指定该`DB`所具有的方法。
DBC.create('User', {
getPhone: {
url: 'xxx',
method: 'GET', // GET|POST
data: {}, // 静态参数
header: {}, // 非jsonp时才生效
timeout: 5000, // 如果超时了,会触发error
jsonp: false, // true
jsonp: [true, 'cb', 'j{id}'], // 自定义的jsonp fit: fn,
process: fn,
once: false,
retry: 0,
ignoreSelfConcurrent: true
},
...
});
// 创建更多`DB`
DBC.create('Order', {...});
// 返回DB上下文,供业务逻辑调用
module.exports = DBC;
// 引入`db`文件
const DB = require('path/to/db');
DB.User.getPhone({
// 动态参数
}).then(function (data) {
// 成功回调,`data`是`process`处理后的数据
}, function (error) {
// 失败回调
if (error.status == 404) {} // ajax方法才有error.status
if (error.status == 500) {} // ajax方法才有error.status
if (error.status == 0) // ajax方法才有error.status 0表示不确定的错误 可能是跨域时使用了非法Header
if (error.timeout) {
console.log(error.message)
}
// 服务器端返回的约定错误,以具体项目而定
if (error.code == 10001) {}
});
启动数据端服务器,用于测试返回的数据。
$ npm run server
启动实时编译的开发环境
$ npm start
(The MIT License)
Copyright (c) 2015 jias gnosaij@yeah.net
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the 'Software'), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
FAQs
A natty semantic data-fetching tool for project that no longer needs to use jQuery/Zepto's Ajax.
The npm package natty-db receives a total of 1 weekly downloads. As such, natty-db popularity was classified as not popular.
We found that natty-db 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 researchers uncovered a malicious PyPI package exploiting Deezer’s API to enable coordinated music piracy through API abuse and C2 server control.
Research
The Socket Research Team discovered a malicious npm package, '@ton-wallet/create', stealing cryptocurrency wallet keys from developers and users in the TON ecosystem.
Security News
Newly introduced telemetry in devenv 1.4 sparked a backlash over privacy concerns, leading to the removal of its AI-powered feature after strong community pushback.