mirror of
https://gitlab.gnome.org/GNOME/libsecret.git
synced 2025-01-03 02:28:53 +00:00
WIP schemas
This commit is contained in:
parent
966c1da87b
commit
65969cf82e
@ -83,42 +83,6 @@
|
|||||||
* to store integer and boolean values as strings.
|
* to store integer and boolean values as strings.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static const SecretSchema network_schema = {
|
|
||||||
SECRET_SCHEMA_IDENTIFIER_NETWORK,
|
|
||||||
SECRET_SCHEMA_NONE,
|
|
||||||
{
|
|
||||||
{ "user", SECRET_SCHEMA_ATTRIBUTE_STRING },
|
|
||||||
{ "domain", SECRET_SCHEMA_ATTRIBUTE_STRING },
|
|
||||||
{ "object", SECRET_SCHEMA_ATTRIBUTE_STRING },
|
|
||||||
{ "protocol", SECRET_SCHEMA_ATTRIBUTE_STRING },
|
|
||||||
{ "port", SECRET_SCHEMA_ATTRIBUTE_INTEGER },
|
|
||||||
{ "server", SECRET_SCHEMA_ATTRIBUTE_STRING },
|
|
||||||
{ "NULL", 0 },
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const SecretSchema * SECRET_SCHEMA_NETWORK = &network_schema;
|
|
||||||
|
|
||||||
static const SecretSchema generic_schema = {
|
|
||||||
SECRET_SCHEMA_IDENTIFIER_GENERIC,
|
|
||||||
SECRET_SCHEMA_ALLOW_UNDEFINED,
|
|
||||||
{
|
|
||||||
{ "NULL", 0 },
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const SecretSchema * SECRET_SCHEMA_GENERIC = &generic_schema;
|
|
||||||
|
|
||||||
static const SecretSchema note_schema = {
|
|
||||||
SECRET_SCHEMA_IDENTIFIER_NOTE,
|
|
||||||
SECRET_SCHEMA_ALLOW_UNDEFINED,
|
|
||||||
{
|
|
||||||
{ "NULL", 0 },
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const SecretSchema * SECRET_SCHEMA_NOTE = ¬e_schema;
|
|
||||||
|
|
||||||
static SecretSchemaAttribute *
|
static SecretSchemaAttribute *
|
||||||
schema_attribute_copy (SecretSchemaAttribute *attribute)
|
schema_attribute_copy (SecretSchemaAttribute *attribute)
|
||||||
{
|
{
|
||||||
|
@ -21,10 +21,6 @@
|
|||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
#define SECRET_SCHEMA_IDENTIFIER_GENERIC "org.freedesktop.Secret.Generic"
|
|
||||||
#define SECRET_SCHEMA_IDENTIFIER_NETWORK "org.gnome.keyring.NetworkPassword"
|
|
||||||
#define SECRET_SCHEMA_IDENTIFIER_NOTE "org.gnome.keyring.Note"
|
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
SECRET_SCHEMA_ATTRIBUTE_STRING = 0,
|
SECRET_SCHEMA_ATTRIBUTE_STRING = 0,
|
||||||
SECRET_SCHEMA_ATTRIBUTE_INTEGER = 1,
|
SECRET_SCHEMA_ATTRIBUTE_INTEGER = 1,
|
||||||
@ -39,6 +35,7 @@ typedef struct {
|
|||||||
typedef enum {
|
typedef enum {
|
||||||
SECRET_SCHEMA_NONE = 0,
|
SECRET_SCHEMA_NONE = 0,
|
||||||
SECRET_SCHEMA_ALLOW_UNDEFINED = 1 << 0,
|
SECRET_SCHEMA_ALLOW_UNDEFINED = 1 << 0,
|
||||||
|
SECRET_SCHEMA_IGNORE_IDENTIFIER = 1 << 1
|
||||||
} SecretSchemaFlags;
|
} SecretSchemaFlags;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
@ -57,12 +54,6 @@ typedef struct {
|
|||||||
gpointer reserved7;
|
gpointer reserved7;
|
||||||
} SecretSchema;
|
} SecretSchema;
|
||||||
|
|
||||||
extern const SecretSchema * SECRET_SCHEMA_NETWORK;
|
|
||||||
|
|
||||||
extern const SecretSchema * SECRET_SCHEMA_GENERIC;
|
|
||||||
|
|
||||||
extern const SecretSchema * SECRET_SCHEMA_NOTE;
|
|
||||||
|
|
||||||
GType secret_schema_get_type (void) G_GNUC_CONST;
|
GType secret_schema_get_type (void) G_GNUC_CONST;
|
||||||
|
|
||||||
SecretSchema * secret_schema_new (const gchar *identifier,
|
SecretSchema * secret_schema_new (const gchar *identifier,
|
||||||
|
31
library/secret-schemas.c
Normal file
31
library/secret-schemas.c
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
/* libsecret - GLib wrapper for Secret Service
|
||||||
|
*
|
||||||
|
* Copyright 2012 Stef Walter
|
||||||
|
*
|
||||||
|
* This program 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; either version 2 of the licence or (at
|
||||||
|
* your option) any later version.
|
||||||
|
*
|
||||||
|
* See the included COPYING file for more information.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
#include "secret-schema.h"
|
||||||
|
|
||||||
|
static const SecretSchema network_schema = {
|
||||||
|
"org.gnome.keyring.NetworkPassword",
|
||||||
|
SECRET_SCHEMA_NONE,
|
||||||
|
{
|
||||||
|
{ "user", SECRET_SCHEMA_ATTRIBUTE_STRING },
|
||||||
|
{ "domain", SECRET_SCHEMA_ATTRIBUTE_STRING },
|
||||||
|
{ "object", SECRET_SCHEMA_ATTRIBUTE_STRING },
|
||||||
|
{ "protocol", SECRET_SCHEMA_ATTRIBUTE_STRING },
|
||||||
|
{ "port", SECRET_SCHEMA_ATTRIBUTE_INTEGER },
|
||||||
|
{ "server", SECRET_SCHEMA_ATTRIBUTE_STRING },
|
||||||
|
{ "NULL", 0 },
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const SecretSchema * SECRET_SCHEMA_COMPAT_NETWORK = &network_schema;
|
35
library/secret-schemas.h
Normal file
35
library/secret-schemas.h
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
/* libsecret - GLib wrapper for Secret Service
|
||||||
|
*
|
||||||
|
* Copyright 2012 Stef Walter
|
||||||
|
*
|
||||||
|
* This program 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; either version 2 of the licence or (at
|
||||||
|
* your option) any later version.
|
||||||
|
*
|
||||||
|
* See the included COPYING file for more information.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#if !defined (__SECRET_INSIDE_HEADER__) && !defined (SECRET_COMPILATION)
|
||||||
|
#error "Only <secret/secret.h> can be included directly."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef __SECRET_SCHEMAS_H__
|
||||||
|
#define __SECRET_SCHEMAS_H__
|
||||||
|
|
||||||
|
#include <glib.h>
|
||||||
|
|
||||||
|
#include "secret-schema.h"
|
||||||
|
|
||||||
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This schema is here for compatibility with libgnome-keyring's network
|
||||||
|
* password functions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern const SecretSchema * SECRET_SCHEMA_COMPAT_NETWORK;
|
||||||
|
|
||||||
|
G_END_DECLS
|
||||||
|
|
||||||
|
#endif /* __SECRET_SCHEMAS_H___ */
|
Loading…
Reference in New Issue
Block a user