English | 中文
一款Android原生的开源Github客户端App,提供更丰富的功能,更好体验,旨在更好的日常管理和维护个人Github,提供更好更方便的驾车体验~~Σ( ̄。 ̄ノ)ノ。项目使用Retrofit2 + RxJava2 + Dagger2 + DataBinding + LiveData + Navigation 等,MVVM 配合 Android JetPack,涉及各种常用控件、 AIDL 、 CMake,提供丰富的同款对比:
-
同款Flutter版 ( https://github.com/CarGuo/gsy_github_app_flutter )
-
同款HarmonyOS ArkUI版 ( https://github.com/CarGuo/GSYGithubAppOH )
-
同款Android Compose版 ( https://github.com/CarGuo/GSYGithubAppCompose )
-
同款Compose Multiplatform版 ( https://github.com/CarGuo/GSYGithubAppCMP )
-
同款Weex版 ( https://github.com/CarGuo/GSYGithubAppWeex )
-
同款ReactNative版 ( https://github.com/CarGuo/GSYGithubApp )
| 公众号 | 掘金 | 知乎 | CSDN | 简书 |
|---|---|---|---|---|
| GSYTech | 点我 | 点我 | 点我 | 点我 |
基于 Kotlin 开发的原生 App 。目前初版,持续完善中。
项目的目的是为方便个人日常维护和查阅 Github ,更好的沉浸于码友之间的互基,Github 就是你的家。
项目同时适合 Android 和 Kotlin 的练手学习,覆盖了各种框架的使用。
随着项目的使用情况和反馈,将时不时根据更新并完善用户体验与功能优化吗,欢迎提出问题。
敬请期待
ndk.dir="xxxxxxxx"
CLIENT_ID = "xxxxxx"
CLIENT_SECRET = "xxxxxx"
如果需要测试
CMake,要打开 Gradle 中的needCMakeTest,记得配置CMake环境。
注册 Github APP 传送门,当然,前提是你现有一个github账号(~ ̄▽ ̄)~ 。
3、现在 Github API 需要使用安全登录(授权登录),那么在上述注册 Github App 的 Authorization callback URL 一栏必须填入 gsygithubapp://authed
4、登录页除了 OAuth 授权登录外,还提供「使用 Token 登陆」入口:在 Github Personal Access Tokens 生成具备
repo / user / notifications权限的 token,点击登录页「使用 TOKEN 登陆」按钮粘贴即可登录,无需配置 client_id/client_secret。
当前主线已完成 Realm → Room、kapt → KSP2、AGP 8 → AGP 9 的整体迁移,并新增 Personal Access Token 登录入口。下图概览本次迁移与登录链路:
查看 Mermaid 源码(GitHub 原生支持渲染)
flowchart LR
A[Realm + kapt + AGP 8] -->|d32a935| B[Room + KSP2 + AGP 9.0.0-alpha14]
B -->|da13df9| C[新增 PAT Token 登录]
C --> D[Login UI]
C --> E[LoginRepository.loginWithToken]
E --> F[accessTokenStorage]
F --> G[RetrofitFactory Authorization]
G --> H[GitHub GET /user 校验]
H -->|成功| I[MainActivity]
H -->|失败| J[clearTokenStorage]
style A fill:#fff3e0,color:#e65100
style B fill:#bbdefb,color:#0d47a1
style C fill:#c8e6c9,color:#1a5e20
style F fill:#fff3e0,color:#e65100
style J fill:#fff3e0,color:#e65100
style I fill:#c8e6c9,color:#1a5e20
登录页底部「使用 Token 登陆」按钮会弹出输入对话框:粘贴 GitHub Personal Access Token(建议勾选 repo / user / notifications / gist 权限)即可登录。Token 默认遮蔽显示,可点击右侧眼睛图标切换可见;对话框内的「如何创建 Token?」会跳转到 GitHub 设置页带预选 scopes。Token 仅写入本机 SharedPreferences,校验失败会自动清空。
仓库内 settings.gradle 仅声明 Gradle 标准仓库,便于 GitHub Actions / 海外网络构建。Gradle 9 在镜像偶发 5xx 时会直接禁用该仓库,因此不要把 aliyun 镜像写进项目脚本。国内开发者请在用户级 init script 中加镜像:
// ~/.gradle/init.d/repo-mirror.gradle
allprojects {
repositories {
maven { url "https://maven.aliyun.com/repository/public" }
maven { url "https://maven.aliyun.com/repository/google" }
maven { url "https://maven.aliyun.com/repository/gradle-plugin" }
}
}
settingsEvaluated { settings ->
settings.pluginManagement {
repositories {
maven { url "https://maven.aliyun.com/repository/public" }
maven { url "https://maven.aliyun.com/repository/google" }
maven { url "https://maven.aliyun.com/repository/gradle-plugin" }
}
}
}Apk下载链接: Apk下载链接
敬请期待
| 库 | 功能 |
|---|---|
| retrofit2 | 网络 |
| okHttp3 | 网络 |
| rxJava2 | 异步事件处理 |
| dagger2 | 依赖注入 |
| dataBinding | 数据绑定 |
| liveData/viewModel | 数据订阅 |
| navigation | Android JetPack 导航 |
| aRouter | 组件化路由 |
| glide | 图片加载 |
| room | 数据库 |
| iconics | 矢量图标 |
| navigationtabbar | TabBar |
| lazyRecyclerAdapter | 通用绑定RecyclerView适配器 |
| markdownView | Markdown解析 |
| prism4j | 代码高亮 |
| materialDrawer | drawer |
| lottie | svg动画 |
| gson | json解析 |
- ThirtyDegreesRay/OpenHub : 基于 Java + Retrofit + RxJava + MVP 的开源 github app(本项目的部分数据实体是从 OpenHub 拷贝而来。)
CarGuo/GSYGithubAppKotlin is licensed under the
Apache License 2.0
A permissive license whose main conditions require preservation of copyright and license notices.
Contributors provide an express grant of patent rights.
Licensed works, modifications, and larger works may be distributed under different terms and without source code.














