|
|
|
@ -25,6 +25,8 @@ import java.util.concurrent.ExecutionException;
|
|
|
|
|
|
|
|
|
|
import dev.garrettmills.starship.hyperlink.scanner.QRCodeImageAnalyzer;
|
|
|
|
|
import dev.garrettmills.starship.hyperlink.scanner.QRCodeListener;
|
|
|
|
|
import dev.garrettmills.starship.hyperlink.util.InvalidLoginTokenException;
|
|
|
|
|
import dev.garrettmills.starship.hyperlink.util.LoginToken;
|
|
|
|
|
|
|
|
|
|
public class LoginTokenScannerActivity extends AppCompatActivity implements QRCodeListener {
|
|
|
|
|
private PreviewView previewView;
|
|
|
|
@ -45,21 +47,22 @@ public class LoginTokenScannerActivity extends AppCompatActivity implements QRCo
|
|
|
|
|
if (ActivityCompat.checkSelfPermission(this, Manifest.permission.CAMERA) == PackageManager.PERMISSION_GRANTED) {
|
|
|
|
|
startCamera();
|
|
|
|
|
} else {
|
|
|
|
|
if (ActivityCompat.shouldShowRequestPermissionRationale(this, Manifest.permission.CAMERA)) {
|
|
|
|
|
ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.CAMERA}, Hyperlink.PERMISSION_REQUEST_CAMERA);
|
|
|
|
|
} else {
|
|
|
|
|
ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.CAMERA}, Hyperlink.PERMISSION_REQUEST_CAMERA);
|
|
|
|
|
}
|
|
|
|
|
ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.CAMERA}, Hyperlink.REQUEST_PERMISSION_CAMERA);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
|
|
|
|
|
if (requestCode == Hyperlink.PERMISSION_REQUEST_CAMERA) {
|
|
|
|
|
if (requestCode == Hyperlink.REQUEST_PERMISSION_CAMERA) {
|
|
|
|
|
if (grantResults.length == 1 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
|
|
|
|
|
startCamera();
|
|
|
|
|
} else {
|
|
|
|
|
Toast.makeText(this, "Camera Permission Denied", Toast.LENGTH_SHORT).show();
|
|
|
|
|
if ( BuildConfig.DEBUG ) {
|
|
|
|
|
Toast.makeText(this, "Camera permission denied", Toast.LENGTH_SHORT).show();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// If we denied, go back up to the main activity, w/o any login token
|
|
|
|
|
finish();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
@ -70,7 +73,11 @@ public class LoginTokenScannerActivity extends AppCompatActivity implements QRCo
|
|
|
|
|
ProcessCameraProvider cameraProvider = cameraProviderFuture.get();
|
|
|
|
|
bindCameraPreview(cameraProvider);
|
|
|
|
|
} catch (ExecutionException | InterruptedException e) {
|
|
|
|
|
Toast.makeText(this, "Error starting camera: " + e.getMessage(), Toast.LENGTH_LONG).show();
|
|
|
|
|
if ( BuildConfig.DEBUG ) {
|
|
|
|
|
Toast.makeText(this, "Error starting camera: " + e.getMessage(), Toast.LENGTH_LONG).show();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
finish();
|
|
|
|
|
}
|
|
|
|
|
}, ContextCompat.getMainExecutor(this));
|
|
|
|
|
}
|
|
|
|
@ -109,6 +116,11 @@ public class LoginTokenScannerActivity extends AppCompatActivity implements QRCo
|
|
|
|
|
public void onQRCodeNotFound() {}
|
|
|
|
|
|
|
|
|
|
public boolean isValidLoginToken(String token) {
|
|
|
|
|
return true;
|
|
|
|
|
try {
|
|
|
|
|
new LoginToken(token);
|
|
|
|
|
return true;
|
|
|
|
|
} catch (InvalidLoginTokenException e) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|