Skip to content

Latest commit

 

History

History
274 lines (219 loc) · 8.86 KB

README_CN.md

File metadata and controls

274 lines (219 loc) · 8.86 KB

Labrador   Docs Build Status Latest Version labrador: rustc 1.13+

猫狗试验室

猫狗试验室出品

这是一个热爱🫶技术,热爱🔥生活的团队.
很欢迎大家能够一起学习📑、沟通💬 .

Labrador - 一个迷你的便捷的第三方服务客户端SDK

Features:

  • taobao - 淘宝客
  • alipay - 支付宝
  • pdd - 拼多多
  • jd - 京东
  • wechat - 微信

Crypto Features

  • openssl-crypto 如果你开起来了 openssl-crypto feature, 则本项目所有加密都是用openssl进行,后续会支持其他加密库以供挑选,所以需要引入openssl相关,详情见openssl相关说明。
  • 默认加密

默认加密主要采用 rust-crypto & x509_parser & rsa,感兴趣的可以去相关文档查看。

Supported Platform

平台 是否支持
Wechat:mp(微信公众号),cp(企业微信),miniapp(微信小程序),pay(微信支付)
Alipay(支付宝)
Taobao(淘宝客)
JD(京东联盟)
PDD(拼多多-多多客)

如下:

使用

Click to show Cargo.toml. Run this code in the playground.
[dependencies]

# The core APIs
labrador = { version = "0.1.0", features = ["wechat", "alipay"] }

示例

猫狗0791商城小程序

小程序中微信、支付宝等支付、
退款功能均基于Labrador,欢迎扫码体验

猫狗试验室

欢迎扫码加入我们

## 文档 ### 微信开放平台、包含微信支付
use labrador::{WechatPayClient, SimpleStorage, TradeType, WechatPayRequestV3, Amount, Payer};
use chrono::{Local, SecondsFormat};

#[tokio::main]
async fn main() {
    let c =  WechatPayClient::new("appid", "secret", SimpleStorage::new());
    let mut client =c.wxpay();
    let date = Local::now().to_rfc3339_opts(SecondsFormat::Secs, false);
    let result = client.unified_order_v3(TradeType::Jsapi, WechatPayRequestV3 {
        appid: "appid".to_string().into(),
        mch_id: "mchid".to_string(),
        description: "测试商品支付".to_string(),
        out_trade_no: "1602920235sdfsdfas32234234".to_string(),
        time_expire: date,
        attach: None,
        notify_url: "https:xxx.cn/trade/notify".to_string(),
        amount: Amount {
            total: 1,
            currency: String::from("CNY").into(),
            payer_total: None,
            payer_currency: None
        },
        payer: Payer {
            openid: "oUVZc6S_uGx3bsNPUA-davo4Dt7Us".to_string()
        }.into(),
        detail: None,
        scene_info: None,
        settle_info: None
    });
    match result.await {
        Ok(res) => {}
        Err(err) => {}
    }
}

支付宝

use labrador::{AlipayTradeWapPayRequest, AlipayClient};

#[tokio::main]
async fn main() {
    let param = AlipayTradeWapPayRequest::default();
    let client = AlipayClient::new("appKey", false);
    match client.wap_pay("POST".into(), param).await {
        Ok(res) => {}
        Err(err) => {}
    }
    match result.await {
        Ok(res) => {}
        Err(err) => {}
    }
}

淘宝客相关

use labrador::{TbItemDetailRequest, TaobaoClient};

#[tokio::main]
async fn main() {
    let client =  TaobaoClient::<SimpleStorage>::new("appkey", "secret");
    let req = TbItemDetailRequest {
        num_iids: Some("597649283190".to_string()),
        platform: None,
        ip: None
    };
    let result = client.get_item_detail(req);
    match result.await {
        Ok(res) => {
        }
        Err(err) => {
        }
    }
}

京东,目前暂时只支持联盟相关

use labrador::{JDClient, JdOrderRawQueryParam};
use chrono::{Local, SecondsFormat};

#[tokio::main]
async fn main() {
    let client =  JDClient::<SimpleStorage>::new("appkey", "secert");
    let param = JdOrderRawQueryParam {
        page_index: 1.into(),
        page_size: 10.into(),
        bill_type: 1,
        start_time: "2022-08-02 21:23:00".to_string(),
        end_time: "2022-08-02 21:43:00".to_string(),
        child_union_id: None,
        key: None,
        fields: None
    };
    let result = client.query_raw_order(param);
    match result.await {
        Ok(res) => {
        }
        Err(err) => {
        }
    }
}

自定义请求

You can implement this trait and then use the custom request

  • AlipayRequest - 支付宝
  • JDRequest - 京东
  • TaobaoRequest - 淘宝

未来

我们将逐步完善相应的API

  1. 首先非常欢迎和感谢对本项目发起 Pull Request 的热心小伙伴们。
  2. 特别提示:请务必在 develop 分支提交 PRrelease 分支目前仅是正式版的代码,即发布正式版本后才会从 develop 分支进行合并。
  3. 本项目代码风格为使用2个空格代表一个Tab,因此在提交代码时请注意一下,否则很容易在IDE格式化代码后与原代码产生大量diff,这样会给其他人阅读代码带来极大的困扰。
  4. 提交代码前,请检查代码是否已经格式化,并且保证新增加或者修改的方法都有完整的参数说明,而pub方法必须拥有相应的单元测试并通过测试。

开发

To setup the development envrionment run cargo run.

贡献者

Getting help

拉布拉多是个人项目。一开始,我只是喜欢拉布拉多犬,因为我的爱好。 我希望这个项目会变得越来越可爱。许多实用的其他函数将 将在将来添加。我希望你能积极帮助这个项目成长并提出建议。 我相信未来会越来越好。


License

Licensed under either of Apache License, Version 2.0 or MIT license at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in Labrador by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.