/**
* Copyright (C) 2013 Romain Guefveneu.
*
* This file is part of naonedbus.
*
* Naonedbus is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Naonedbus is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package net.naonedbus.provider.impl;
import net.naonedbus.provider.ReadOnlyContentProvider;
import net.naonedbus.provider.table.ArretTable;
import net.naonedbus.provider.table.EquipementTable;
import android.content.UriMatcher;
import android.database.Cursor;
import android.database.sqlite.SQLiteQueryBuilder;
import android.net.Uri;
public class ArretProvider extends ReadOnlyContentProvider {
/**
* Récupérer tous les arrêts
*/
private static final int ARRETS = 20;
/**
* Récupérer un arrêt par son id
*/
private static final int ARRET_ID = 30;
/**
* Récupérer un arrêt par son code ligne et code sens.
*/
private static final int ARRET_CODESENS_CODELIGNE = 40;
public static final String ARRET_CODESENS_CODELIGNE_URI_PATH_QUERY = "codeSensLigne";
/**
* Récupérer un arrêt par son code arret, code ligne et code sens
*/
private static final int ARRET_CODEARRET_CODESENS_CODELIGNE = 41;
public static final String ARRET_CODEARRET_CODESENS_CODELIGNE_URI_PATH_QUERY = "arretSensLigne";
private static final String AUTHORITY = "net.naonedbus.provider.ArretProvider";
private static final String ARRETS_BASE_PATH = "arrets";
public static final Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/" + ARRETS_BASE_PATH);
private static final UriMatcher URI_MATCHER = new UriMatcher(UriMatcher.NO_MATCH);
static {
URI_MATCHER.addURI(AUTHORITY, ARRETS_BASE_PATH, ARRETS);
URI_MATCHER.addURI(AUTHORITY, ARRETS_BASE_PATH + "/#", ARRET_ID);
URI_MATCHER.addURI(AUTHORITY, ARRET_CODESENS_CODELIGNE_URI_PATH_QUERY, ARRET_CODESENS_CODELIGNE);
URI_MATCHER.addURI(AUTHORITY, ARRET_CODEARRET_CODESENS_CODELIGNE_URI_PATH_QUERY,
ARRET_CODEARRET_CODESENS_CODELIGNE);
}
@Override
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
Cursor cursor;
SQLiteQueryBuilder queryBuilder = new SQLiteQueryBuilder();
queryBuilder.setTables(ArretTable.TABLE_NAME + ArretTable.TABLE_JOIN_STATIONS);
projection = ArretTable.PROJECTION;
int uriType = URI_MATCHER.match(uri);
switch (uriType) {
case ARRET_ID:
queryBuilder.appendWhere(ArretTable.TABLE_NAME + "." + ArretTable._ID + "=");
queryBuilder.appendWhereEscapeString(uri.getLastPathSegment());
break;
case ARRET_CODESENS_CODELIGNE:
queryBuilder.appendWhere(ArretTable.TABLE_NAME + "." + ArretTable.CODE_SENS + " = ");
queryBuilder.appendWhereEscapeString(uri.getQueryParameter("codeSens"));
queryBuilder.appendWhere(" AND ");
queryBuilder.appendWhere(ArretTable.TABLE_NAME + "." + ArretTable.CODE_LIGNE + " = ");
queryBuilder.appendWhereEscapeString(uri.getQueryParameter("codeLigne"));
break;
case ARRET_CODEARRET_CODESENS_CODELIGNE:
queryBuilder.appendWhere(ArretTable.TABLE_NAME + "." + ArretTable.CODE + " = ");
queryBuilder.appendWhereEscapeString(uri.getQueryParameter("codeArret"));
queryBuilder.appendWhere(" AND ");
queryBuilder.appendWhere(ArretTable.TABLE_NAME + "." + ArretTable.CODE_SENS + " = ");
queryBuilder.appendWhereEscapeString(uri.getQueryParameter("codeSens"));
queryBuilder.appendWhere(" AND ");
queryBuilder.appendWhere(ArretTable.TABLE_NAME + "." + ArretTable.CODE_LIGNE + " = ");
queryBuilder.appendWhereEscapeString(uri.getQueryParameter("codeLigne"));
break;
case ARRETS:
// no filter
break;
default:
throw new IllegalArgumentException("Unknown URI (" + uri + ")");
}
cursor = queryBuilder.query(getReadableDatabase(), projection, selection, selectionArgs, null, null,
sortOrder);
cursor.setNotificationUri(getContext().getContentResolver(), uri);
return cursor;
}
}