This file is indexed.

/usr/include/evolution-data-server/libedataserver/e-source-credentials-provider-impl-google.h is in libedataserver1.2-dev 3.22.7-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
/*
 * Copyright (C) 2015 Red Hat, Inc. (www.redhat.com)
 *
 * This library is free software: you can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation.
 *
 * This library 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 Lesser General Public License
 * for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this library. If not, see <http://www.gnu.org/licenses/>.
 *
 */

#if !defined (__LIBEDATASERVER_H_INSIDE__) && !defined (LIBEDATASERVER_COMPILATION)
#error "Only <libedataserver/libedataserver.h> should be included directly."
#endif

#ifndef E_SOURCE_CREDENTIALS_PROVIDER_IMPL_GOOGLE_H
#define E_SOURCE_CREDENTIALS_PROVIDER_IMPL_GOOGLE_H

#include <glib.h>
#include <glib-object.h>

#include <libedataserver/e-source.h>
#include <libedataserver/e-source-credentials-provider-impl.h>

/* Standard GObject macros */
#define E_TYPE_SOURCE_CREDENTIALS_PROVIDER_IMPL_GOOGLE \
	(e_source_credentials_provider_impl_google_get_type ())
#define E_SOURCE_CREDENTIALS_PROVIDER_IMPL_GOOGLE(obj) \
	(G_TYPE_CHECK_INSTANCE_CAST \
	((obj), E_TYPE_SOURCE_CREDENTIALS_PROVIDER_IMPL_GOOGLE, ESourceCredentialsProviderImplGoogle))
#define E_SOURCE_CREDENTIALS_PROVIDER_IMPL_GOOGLE_CLASS(cls) \
	(G_TYPE_CHECK_CLASS_CAST \
	((cls), E_TYPE_SOURCE_CREDENTIALS_PROVIDER_IMPL_GOOGLE, ESourceCredentialsProviderImplGoogleClass))
#define E_IS_SOURCE_CREDENTIALS_PROVIDER_IMPL_GOOGLE(obj) \
	(G_TYPE_CHECK_INSTANCE_TYPE \
	((obj), E_TYPE_SOURCE_CREDENTIALS_PROVIDER_IMPL_GOOGLE))
#define E_IS_SOURCE_CREDENTIALS_PROVIDER_IMPL_GOOGLE_CLASS(cls) \
	(G_TYPE_CHECK_CLASS_TYPE \
	((cls), E_TYPE_SOURCE_CREDENTIALS_PROVIDER_IMPL_GOOGLE))
#define E_SOURCE_CREDENTIALS_PROVIDER_IMPL_GOOGLE_GET_CLASS(obj) \
	(G_TYPE_INSTANCE_GET_CLASS \
	((obj), E_TYPE_SOURCE_CREDENTIALS_PROVIDER_IMPL_GOOGLE, ESourceCredentialsProviderImplGoogleClass))

/* The key names used in crendetials ENamedParameters structure */
#define E_SOURCE_CREDENTIAL_GOOGLE_SECRET "Google-secret"

/* Secret key names, saved by the code; not the names returned by the Google server */
#define E_GOOGLE_SECRET_REFRESH_TOKEN "refresh_token"
#define E_GOOGLE_SECRET_ACCESS_TOKEN "access_token"
#define E_GOOGLE_SECRET_EXPIRES_AFTER "expires_after"

G_BEGIN_DECLS

typedef struct _ESourceCredentialsProviderImplGoogle ESourceCredentialsProviderImplGoogle;
typedef struct _ESourceCredentialsProviderImplGoogleClass ESourceCredentialsProviderImplGoogleClass;
typedef struct _ESourceCredentialsProviderImplGooglePrivate ESourceCredentialsProviderImplGooglePrivate;

/**
 * ESourceCredentialsProviderImplGoogle:
 *
 * Google based credentials provider implementation.
 *
 * Since: 3.20
 **/
struct _ESourceCredentialsProviderImplGoogle {
	ESourceCredentialsProviderImpl parent;
	ESourceCredentialsProviderImplGooglePrivate *priv;
};

struct _ESourceCredentialsProviderImplGoogleClass {
	ESourceCredentialsProviderImplClass parent_class;
};

GType		e_source_credentials_provider_impl_google_get_type	(void);

gboolean	e_source_credentials_google_is_supported		(void);
gboolean	e_source_credentials_google_get_access_token_sync	(ESource *source,
									 const ENamedParameters *credentials,
									 gchar **out_access_token,
									 gint *out_expires_in_seconds,
									 GCancellable *cancellable,
									 GError **error);
gboolean	e_source_credentials_google_util_generate_secret_uid	(ESource *source,
									 gchar **out_uid);
gboolean	e_source_credentials_google_util_encode_to_secret	(gchar **out_secret,
									 const gchar *key1_name,
									 const gchar *value1,
									 ...) G_GNUC_NULL_TERMINATED;
gboolean	e_source_credentials_google_util_decode_from_secret	(const gchar *secret,
									 const gchar *key1_name,
									 gchar **out_value1,
									 ...) G_GNUC_NULL_TERMINATED;
gboolean	e_source_credentials_google_util_extract_from_credentials
									(const ENamedParameters *credentials,
									 gchar **out_access_token,
									 gint *out_expires_in_seconds);
G_END_DECLS

#endif /* E_SOURCE_CREDENTIALS_PROVIDER_IMPL_GOOGLE_H */