mirror of
				https://github.com/yggdrasil-network/yggdrasil-android.git
				synced 2025-11-04 11:15:08 +03:00 
			
		
		
		
	Merge branch 'main' into main
This commit is contained in:
		
						commit
						978c446016
					
				
					 7 changed files with 151 additions and 20 deletions
				
			
		
							
								
								
									
										69
									
								
								.github/workflows/android.yml
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								.github/workflows/android.yml
									
										
									
									
										vendored
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,69 @@
 | 
			
		|||
name: Build
 | 
			
		||||
 | 
			
		||||
on:
 | 
			
		||||
  push:
 | 
			
		||||
    branches: [ "main" ]
 | 
			
		||||
  pull_request:
 | 
			
		||||
    branches: [ "main" ]
 | 
			
		||||
  workflow_dispatch:
 | 
			
		||||
 | 
			
		||||
jobs:
 | 
			
		||||
  build:
 | 
			
		||||
    name: Build
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
 | 
			
		||||
    steps:
 | 
			
		||||
    - name: Check out
 | 
			
		||||
      uses: actions/checkout@v3
 | 
			
		||||
        
 | 
			
		||||
    - name: Check out Yggdrasil
 | 
			
		||||
      uses: actions/checkout@v3
 | 
			
		||||
      with:
 | 
			
		||||
        repository: yggdrasil-network/yggdrasil-go
 | 
			
		||||
        path: yggdrasil-go
 | 
			
		||||
        ref: develop
 | 
			
		||||
        fetch-depth: 0
 | 
			
		||||
    
 | 
			
		||||
    - name: Setup Go environment
 | 
			
		||||
      uses: actions/setup-go@v3.3.1
 | 
			
		||||
    
 | 
			
		||||
    - name: Install gomobile
 | 
			
		||||
      run: |
 | 
			
		||||
        go install golang.org/x/mobile/cmd/gomobile@latest
 | 
			
		||||
        ~/go/bin/gomobile init
 | 
			
		||||
    
 | 
			
		||||
    - name: Set up JDK 11
 | 
			
		||||
      uses: actions/setup-java@v3
 | 
			
		||||
      with:
 | 
			
		||||
        java-version: '11'
 | 
			
		||||
        distribution: 'temurin'
 | 
			
		||||
        cache: gradle
 | 
			
		||||
        
 | 
			
		||||
    - name: Install NDK
 | 
			
		||||
      uses: nttld/setup-ndk@v1
 | 
			
		||||
      id: setup-ndk
 | 
			
		||||
      with:
 | 
			
		||||
        ndk-version: r21e
 | 
			
		||||
        add-to-path: false
 | 
			
		||||
      
 | 
			
		||||
    - name: Build Yggdrasil
 | 
			
		||||
      run: |
 | 
			
		||||
        mkdir app/libs
 | 
			
		||||
        cd yggdrasil-go
 | 
			
		||||
        PATH=$PATH:~/go/bin/ ./contrib/mobile/build -a
 | 
			
		||||
        cp {yggdrasil.aar,yggdrasil-sources.jar} ../app/libs
 | 
			
		||||
      env:
 | 
			
		||||
        ANDROID_NDK_HOME: ${{ steps.setup-ndk.outputs.ndk-path }}
 | 
			
		||||
 | 
			
		||||
    - name: Gradle build
 | 
			
		||||
      run: |
 | 
			
		||||
        echo "${{ secrets.RELEASE_KEYSTORE }}" > app/gha.keystore.asc
 | 
			
		||||
        gpg -d --passphrase "${{ secrets.RELEASE_KEYSTORE_PASSWORD }}" --batch app/gha.keystore.asc > app/gha.jks
 | 
			
		||||
        chmod +x gradlew
 | 
			
		||||
        ./gradlew assembleYggdrasil
 | 
			
		||||
 | 
			
		||||
    - name: Upload artifact
 | 
			
		||||
      uses: actions/upload-artifact@v3
 | 
			
		||||
      with:
 | 
			
		||||
        name: yggdrasil-android
 | 
			
		||||
        path: app/build/outputs/apk/yggdrasil/app-yggdrasil.apk
 | 
			
		||||
							
								
								
									
										62
									
								
								.github/workflows/nightlylink.yml
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								.github/workflows/nightlylink.yml
									
										
									
									
										vendored
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,62 @@
 | 
			
		|||
name: Comment
 | 
			
		||||
on:
 | 
			
		||||
  workflow_run:
 | 
			
		||||
    workflows: ['Build']
 | 
			
		||||
    types: [completed]
 | 
			
		||||
jobs:
 | 
			
		||||
  pr_comment:
 | 
			
		||||
    if: github.event.workflow_run.event == 'pull_request' && github.event.workflow_run.conclusion == 'success'
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/github-script@v6
 | 
			
		||||
        with:
 | 
			
		||||
          # This snippet is public-domain, taken from
 | 
			
		||||
          # https://github.com/oprypin/nightly.link/blob/master/.github/workflows/pr-comment.yml
 | 
			
		||||
          script: |
 | 
			
		||||
            async function upsertComment(owner, repo, issue_number, purpose, body) {
 | 
			
		||||
              const {data: comments} = await github.rest.issues.listComments(
 | 
			
		||||
                {owner, repo, issue_number});
 | 
			
		||||
 | 
			
		||||
              const marker = `<!-- bot: ${purpose} -->`;
 | 
			
		||||
              body = marker + "\n" + body;
 | 
			
		||||
 | 
			
		||||
              const existing = comments.filter((c) => c.body.includes(marker));
 | 
			
		||||
              if (existing.length > 0) {
 | 
			
		||||
                const last = existing[existing.length - 1];
 | 
			
		||||
                core.info(`Updating comment ${last.id}`);
 | 
			
		||||
                await github.rest.issues.updateComment({
 | 
			
		||||
                  owner, repo,
 | 
			
		||||
                  body,
 | 
			
		||||
                  comment_id: last.id,
 | 
			
		||||
                });
 | 
			
		||||
              } else {
 | 
			
		||||
                core.info(`Creating a comment in issue / PR #${issue_number}`);
 | 
			
		||||
                await github.rest.issues.createComment({issue_number, body, owner, repo});
 | 
			
		||||
              }
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            const {owner, repo} = context.repo;
 | 
			
		||||
            const run_id = ${{github.event.workflow_run.id}};
 | 
			
		||||
 | 
			
		||||
            const pull_requests = ${{ toJSON(github.event.workflow_run.pull_requests) }};
 | 
			
		||||
            if (!pull_requests.length) {
 | 
			
		||||
              return core.error("This workflow doesn't match any pull requests!");
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            const artifacts = await github.paginate(
 | 
			
		||||
              github.rest.actions.listWorkflowRunArtifacts, {owner, repo, run_id});
 | 
			
		||||
            if (!artifacts.length) {
 | 
			
		||||
              return core.error(`No artifacts found`);
 | 
			
		||||
            }
 | 
			
		||||
            let body = `Download the artifacts for this pull request:\n`;
 | 
			
		||||
            for (const art of artifacts) {
 | 
			
		||||
              body += `\n* [${art.name}.zip](https://nightly.link/${owner}/${repo}/actions/artifacts/${art.id}.zip)`;
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            core.info("Review thread message body:", body);
 | 
			
		||||
 | 
			
		||||
            for (const pr of pull_requests) {
 | 
			
		||||
              await upsertComment(owner, repo, pr.number,
 | 
			
		||||
                "nightly-link", body);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										2
									
								
								.gitignore
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.gitignore
									
										
									
									
										vendored
									
									
								
							| 
						 | 
				
			
			@ -16,3 +16,5 @@
 | 
			
		|||
local.properties
 | 
			
		||||
/app/libs/yggdrasil.aar
 | 
			
		||||
/app/libs/yggdrasil-sources.jar
 | 
			
		||||
/app/release/*
 | 
			
		||||
/app/release
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -17,11 +17,27 @@ android {
 | 
			
		|||
        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    signingConfigs {
 | 
			
		||||
        create("yggdrasil") {
 | 
			
		||||
            // You need to specify either an absolute path or include the
 | 
			
		||||
            // keystore file in the same directory as the build.gradle file.
 | 
			
		||||
            storeFile = file("gha.jks")
 | 
			
		||||
            storePassword = "g1thub4ct10n34yggdr4s1l4ndr01d"
 | 
			
		||||
            keyAlias = "yggdrasil-android"
 | 
			
		||||
            keyPassword = "g1thub4ct10n34yggdr4s1l4ndr01d"
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    buildTypes {
 | 
			
		||||
        release {
 | 
			
		||||
            minifyEnabled false
 | 
			
		||||
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
 | 
			
		||||
        }
 | 
			
		||||
        yggdrasil {
 | 
			
		||||
            minifyEnabled false
 | 
			
		||||
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
 | 
			
		||||
            signingConfig = signingConfigs.getByName("yggdrasil")
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
    compileOptions {
 | 
			
		||||
        sourceCompatibility JavaVersion.VERSION_1_8
 | 
			
		||||
| 
						 | 
				
			
			@ -43,4 +59,4 @@ dependencies {
 | 
			
		|||
    testImplementation 'junit:junit:4.+'
 | 
			
		||||
    androidTestImplementation 'androidx.test.ext:junit:1.1.2'
 | 
			
		||||
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.3.0'
 | 
			
		||||
}
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
										
											Binary file not shown.
										
									
								
							| 
						 | 
				
			
			@ -1,18 +0,0 @@
 | 
			
		|||
{
 | 
			
		||||
  "version": 2,
 | 
			
		||||
  "artifactType": {
 | 
			
		||||
    "type": "APK",
 | 
			
		||||
    "kind": "Directory"
 | 
			
		||||
  },
 | 
			
		||||
  "applicationId": "eu.neilalexander.yggdrasil",
 | 
			
		||||
  "variantName": "release",
 | 
			
		||||
  "elements": [
 | 
			
		||||
    {
 | 
			
		||||
      "type": "SINGLE",
 | 
			
		||||
      "filters": [],
 | 
			
		||||
      "versionCode": 1,
 | 
			
		||||
      "versionName": "1.0",
 | 
			
		||||
      "outputFile": "app-release.apk"
 | 
			
		||||
    }
 | 
			
		||||
  ]
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -26,7 +26,7 @@ cp /tmp/yggdrasil-go/yggdrasil.aar /tmp/yggdrasil-android/app/libs/
 | 
			
		|||
 | 
			
		||||
```
 | 
			
		||||
cd /tmp/yggdrasil-android
 | 
			
		||||
./gradlew assemble
 | 
			
		||||
./gradlew assembleRelease
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
note: you will need to use jdk-11 as jdk-16 `"doesn't work" ™`
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue