Radko Krowicki
Radko Krowicki

Reputation: 33

"Make sure to call FirebaseApp.initializeApp(Context) first." How to fix this error?

So I'm trying to create an easy android App using Android Studio and when I build it seems fine but when I run the app crashes so I 've been told to check the Logcat and there it says that FirebaseApp is not initialized in my main activity. So i Added

FirebaseApp.initializeApp(this);

to onCreate() and it cannot resolve symbol FirebaseApp so what can I do to fix this?

Heres my Github with it:

https://github.com/radekkrowicki/Cv4

and theres my Mainactivity:

import android.content.Intent;
import android.support.annotation.NonNull;
import android.support.design.widget.FloatingActionButton;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.Toast;

import com.firebase.ui.auth.AuthUI;
import com.firebase.ui.database.FirebaseListAdapter;
import com.google.android.gms.tasks.OnCompleteListener;
import com.google.android.gms.tasks.Task;
import com.google.firebase.auth.FirebaseAuth;
import com.google.firebase.database.FirebaseDatabase;

public class MainActivity extends AppCompatActivity {
private static final int SIGN_IN_REQUEST_CODE = 111;
private FirebaseListAdapter<ChatMessage> adapter;
private ListView listView;
private String loggedInUserName = "";
private FirebaseAuth mAuth;


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    FirebaseApp.initializeApp(this);

    //find views by Ids
    FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
    final EditText input = (EditText) findViewById(R.id.input);
    listView = (ListView) findViewById(R.id.list);

    if (FirebaseAuth.getInstance().getCurrentUser() == null) {
        // Start sign in/sign up activity
        startActivityForResult(AuthUI.getInstance()
                .createSignInIntentBuilder()
                .build(), SIGN_IN_REQUEST_CODE);
    } else {
        // User is already signed in, show list of messages
        showAllOldMessages();
    }

    fab.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            if (input.getText().toString().trim().equals("")) {
                Toast.makeText(MainActivity.this, "Please enter some texts!", Toast.LENGTH_SHORT).show();
            } else {
                FirebaseDatabase.getInstance()
                        .getReference()
                        .push()
                        .setValue(new ChatMessage(input.getText().toString(),
                                FirebaseAuth.getInstance().getCurrentUser().getDisplayName(),
                                FirebaseAuth.getInstance().getCurrentUser().getUid())
                        );
                input.setText("");
            }
        }
    });
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    if (item.getItemId() == R.id.menu_sign_out) {
        AuthUI.getInstance().signOut(this)
                .addOnCompleteListener(new OnCompleteListener<Void>() {
                    @Override
                    public void onComplete(@NonNull Task<Void> task) {
                        Toast.makeText(MainActivity.this, "You have logged out!", Toast.LENGTH_SHORT).show();
                        finish();
                    }
                });
    }
    return true;
}

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);

    if (requestCode == SIGN_IN_REQUEST_CODE) {
        if (resultCode == RESULT_OK) {
            Toast.makeText(this, "Signed in successful!", Toast.LENGTH_LONG).show();
            showAllOldMessages();
        } else {
            Toast.makeText(this, "Sign in failed, please try again later", Toast.LENGTH_LONG).show();

            // Close the app
            finish();
        }
    }
}

private void showAllOldMessages() {
    loggedInUserName = FirebaseAuth.getInstance().getCurrentUser().getUid();
    Log.d("Main", "user id: " + loggedInUserName);

    adapter = new MessageAdapter(this, ChatMessage.class, R.layout.item_in_message,
            FirebaseDatabase.getInstance().getReference());
    listView.setAdapter(adapter);
}

public String getLoggedInUserName() {
    return loggedInUserName;
}
}

Thanks for the help in advance.

Upvotes: 3

Views: 447

Answers (3)

user24367423
user24367423

Reputation: 1

Paste this line in the header part of the MainActivity CLass... "import com.google.firebase.FirebaseApp"

Upvotes: 0

Mayur Gajra
Mayur Gajra

Reputation: 9073

Just cloned your repo and everything seemed fine except for this line

classpath 'com.google.gms:google-services:4.1.0'

in project level gradle file.

It seems like a bug in that version just upgraded it to

classpath 'com.google.gms:google-services:4.2.0'

And everything works fine. try it and let me know if you face any issue.

Upvotes: 0

Jorgesys
Jorgesys

Reputation: 126455

This must be an issue of synchronization, you are correctly initializing Firebase:

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    FirebaseApp.initializeApp(this);
    ...
    ...
}

be sure to clean and build your project again.

Also be sure to have apply plugin: 'com.google.gms.google-services' at the end of /app/build.grade file:

 dependencies {
    ...
    ...
}

apply plugin: 'com.google.gms.google-services'

Upvotes: 3

Related Questions