Du coup, je vous colle la bonne version :
# WotWizard GraphQL TypeSystem
type Query {
"'filterGroup' returns the list of uid(s) in 'group' dispatched to three parts: those whose statuses are among 'status_list', those who are not, and those whose identities are not known; if a known identity appears several times in group, every duplicate is returned in a fourth part."
filterGroup (group: [String!]!, status_list: [Identity_Status!]! = [REVOKED, MISSING, MEMBER, NEWCOMER]): GroupFilter!
"'identities' lists identities in 'group' whose status is in 'status_list' and whose uids is between 'start' (included) and 'end' (excluded), in increasing order and sorted by 'sortedBy'; if 'start' is absent or null, the list starts at the beginning, and stops at the end if 'end' is absent or null; if 'group' is null, all known identities are used (but not if 'group' is empty); if an identity in 'group' is unknown, an error is raised, and the value returned is null."
identities (group: [String!], status_list: [Identity_Status!]! = [REVOKED, MISSING, MEMBER, NEWCOMER], sortedBy: Identity_Order! = UID, start: String! = "", end: String! = ""): [Identity!]
"'idSearch' displays the list of identities whose pseudos or public keys begin with 'with.hint' and whose status is in 'with.status_list'."
idSearch (with: IdSearchInput! = {}): IdSearchOutput!
"'idFromHash' retreives the 'Identity' whose hash is 'hash'; it returns null if this identity doesn't exist"
idFromHash (hash: Hash!): Identity
"Threshold for numbers of sent and received certifications to become sentry"
sentryThreshold: Int!
"List of sentries, sorted by increasing uids"
sentries: [Identity!]!
"Present block"
now: Block!
"'wwFile' displays the WotWizard file, complete if 'full', or else with Dossier(s) containing at least 'Query.parameter(name: sigQty)' certifications only"
wwFile (full: Boolean! = false): File!
"'wwResult' displays the content of the WotWizard window"
wwResult: WWResult!
"'memEnds' displays the list of members, among the reference list 'group', who are about to loose their memberships, in the increasing order of event dates (bct); 'startFromNow' gives the period (in seconds) before the beginning of the list (0 if absent or null) , and 'period' gives the period covered by the list (infinite if absent or null). If 'group' is null or empty, the reference list is the whole Web Of Trust; if any string in 'group' is empty or doesn't refer to a known identity, it's not taken into account for the calculation, and, furthermore, if it is not empty and unknown, an error is raised"
memEnds (group: [String!], startFromNow: Int64, period: Int64): [Identity!]!
"'missEnds' displays the list of identities, among the reference list 'group', who are MISSING and about to be revoked, in the increasing order of event dates (bct); 'startFromNow' gives the period (in seconds) before the beginning of the list (0 if absent or null) , and 'period' gives the period covered by the list (infinite if absent or null). If 'group' is null or empty, the reference list is the whole Web Of Trust; if any string in 'group' is empty or doesn't refer to a known identity, it's not taken into account for the calculation, and, furthermore, if it is not empty and unknown, an error is raised"
missEnds (group: [String!], startFromNow: Int64, period: Int64): [Identity!]!
"'certEnds' displays the list of identities , among the reference list 'group', who are MEMBER or (possibly) MISSING and about to loose their 'ParameterName.sigQty'th oldest certification, in the increasing order of event dates (bct); 'startFromNow' gives the period (in seconds) before the beginning of the list (0 if absent or null) , and 'period' gives the period covered by the list (infinite if absent or null). If 'group' is null or empty, the reference list is the whole Web Of Trust; if any string in 'group' is empty or doesn't refer to a known identity, it's not taken into account for the calculation, and, furthermore, if it is not empty and unknown, an error is raised"
certEnds (group: [String!], startFromNow: Int64, period: Int64, missingIncluded: Boolean! = true): [DatedIdentity!]!
"'countMin' gives the first block of the blockchain"
countMin: Block!
"'countMax' gives the last present block of the blockchain"
countMax: Block!
"'membersCount' displays the number of active members, sorted by dates (utc0) of events (in or out the wot); if 'start' is absent or null, the display starts at 'countMin', and ends at 'countMax' if 'end' is absent or null"
membersCount (start: Int64, end: Int64): [Event!]!
"'membersFlux' displays the flux of active members by <timeUnit (s)>; if 'start' is absent or null, the display starts at 'countMin', and ends at 'countMax' if 'end' is absent or null"
membersFlux (start: Int64, end: Int64, timeUnit: Int64! = 2629800, diffPars: DifferParams! = {}): [FluxEvent!]!
"'membersFluxPM' displays the flux of active members by <timeUnit (s)> and by member; if 'start' is absent or null, the display starts at 'countMin', and ends at 'countMax' if 'end' is absent or null"
membersFluxPM (start: Int64, end: Int64, timeUnit: Int64! = 2629800, diffPars: DifferParams! = {}): [FluxEvent!]!
"'fECount' displays the number of first entries into the wot, sorted by dates (utc0) of events (entries); if 'start' is absent or null, the display starts at 'countMin', and ends at 'countMax' if 'end' is absent or null"
fECount (start: Int64, end: Int64): [Event!]!
"'fEFlux' displays the flux of first entries by <timeUnit (s)>; if 'start' is absent or null, the display starts at 'countMin', and ends at 'countMax' if 'end' is absent or null"
fEFlux (start: Int64, end: Int64, timeUnit: Int64! = 2629800, diffPars: DifferParams! = {}): [FluxEvent!]!
"'fEFluxPM' displays the flux of first entries by <timeUnit (s)> and by member; if 'start' is absent or null, the display starts at 'countMin', and ends at 'countMax' if 'end' is absent or null"
fEFluxPM (start: Int64, end: Int64, timeUnit: Int64! = 2629800, diffPars: DifferParams! = {}): [FluxEvent!]!
"'lossCount' displays the number of members exiting the wot, minus the number of reentries (losses), sorted by dates (utc0) of events (in or out the wot); if 'start' is absent or null, the display starts at 'countMin', and ends at 'countMax' if 'end' is absent or null"
lossCount (start: Int64, end: Int64): [Event!]!
"'lossFlux' displays the flux of losses by <timeUnit (s)>; if 'start' is absent or null, the display starts at 'countMin', and ends at 'countMax' if 'end' is absent or null"
lossFlux (start: Int64, end: Int64, timeUnit: Int64! = 2629800, diffPars: DifferParams! = {}): [FluxEvent!]!
"'lossFluxPM' displays the flux of losses by <timeUnit (s)> and by member; if 'start' is absent or null, the display starts at 'countMin', and ends at 'countMax' if 'end' is absent or null"
lossFluxPM (start: Int64, end: Int64, timeUnit: Int64! = 2629800, diffPars: DifferParams! = {}): [FluxEvent!]!
"'allParameters' displays all parameters of the money"
allParameters: [Parameter!]!
"'parameter' displays the parameter of the money whose name is 'name''"
parameter (name: ParameterName): Parameter
"'version' returns a string describing the version of the graphQL server"
version: String!
"'calcDist' returns the distance of the identity whose pseudo is 'uid' when the members 'certifiers' are added to her own certifiers. 'uid' may be any string, even null or empty; if 'uid' is null or empty or doesn't refer to a known identity, it's not taken into account for the calculation, and, furthermore, if it is not null, not empty and unknown, an error is raised; the same for any string in 'certifiers'"
calcDist (uid: String, certifiers: [String!]): Distance!
"'calcQual' returns the quality of the identity whose pseudo is 'uid' when the members 'certifiers' are added to her own certifiers. 'uid' may be any string, even null or empty; if 'uid' is null or empty or doesn't refer to a known identity, it's not taken into account for the calculation, and, furthermore, if it is not null, not empty and unknown, an error is raised; the same for any string in 'certifiers'"
calcQual (uid: String, certifiers: [String!]): Fraction!
"'bestDist' returns a list of members, among the reference list 'group', who could certify the identity whose pseudo is 'uid', together with the distance such a certification would give to the identity. 'certifiers' is a list of members supposed having already certified the identity in addition to her own certifiers. If 'group' is null or empty, the reference list is the whole Web Of Trust. 'uid' may be any string, even null or empty; if 'uid' is null or empty or doesn't refer to a known identity, it's not taken into account for the calculation, and, furthermore, if it is not null, not empty and unknown, an error is raised; the same for any string in 'group' or 'certifiers', and, furthermore, if the latter is not empty, it should refer to a member. 'answerNb' is the greatest number of answers in the result. If 'answerNb' is null, zero or negative, all answers are returned. Answers are sorted in the decreasing order of 'IdDist.dist.value.ratio'"
bestDist (group: [String!], uid: String, certifiers: [String!], answerNb: Int): [IdDist!]!
"'bestQual' returns a list of members, among the reference list 'group', who could certify the identity whose pseudo is 'uid', together with the quality such a certification would give to the identity. 'certifiers' is a list of members supposed having already certified the identity in addition to her own certifiers. If 'group' is null or empty, the reference list is the whole Web Of Trust. 'uid' may be any string, even null or empty; if 'uid' is null or empty or doesn't refer to a known identity, it's not taken into account for the calculation, and, furthermore, if it is not null, not empty and unknown, an error is raised; the same for any string in 'group' or 'certifiers', and, furthermore, if the latter is not empty, it should refer to a member. 'answerNb' is the greatest number of answers in the result. If 'answerNb' is null, zero or negative, all answers are returned. Answers are sorted in the decreasing order of 'IdQual.qual.ratio'"
bestQual (group: [String!], uid: String, certifiers: [String!], answerNb: Int): [IdQual!]!
} #Query
type Mutation {
"'stopSubscription' erases the subscription whose name is 'name', which sends results at address 'returnAddr'; 'varVals' is a JSON object whose fields keys are the names of the variables (without '$') used in the subscription and whose fields values are their values"
stopSubscription (returnAddr: String!, name: String!, varVals: String): Void
} #Mutation
type Subscription {
"'now' installs a subscription for the update of 'Query.now' at every new block"
now: Block!
"'wwFile' installs a subscription for the update of 'Query.wwFile' at every new block"
wwFile (full: Boolean! = false): FileS!
"'wwResult' installs a subscription for the update of 'Query.wwResult' at every new block"
wwResult: WWResultS!
"'memEnds' installs a subscription for the update of 'Query.memEnds' at every new block"
memEnds (startFromNow: Int64, period: Int64): [Identity!]!
"'missEnds' installs a subscription for the update of 'Query.missEnds' at every new block"
missEnds (startFromNow: Int64, period: Int64): [Identity!]!
"'certEnds' installs a subscription for the update of 'Query.certEnds' at every new block"
certEnds (startFromNow: Int64, period: Int64, missingIncluded: Boolean! = true): [Identity!]!
} #Subscription
"Output of Query.filterGroup, used with a list of statuses; 'selected' owns the uid(s) of identities whose statuses are in the list, 'others' owns those who are not in the list, and 'unknown' corresponds to unknown identities."
type GroupFilter {
selected: [String!]!
others: [Error!]!
unknown: [Error!]!
duplicate: [Error!]!
} #Group_Filter
type Error {
mes: String!
path: [FieldOrRank!]!
} #Error
union FieldOrRank = Field | Rank
type Field {
name: String!
} #Field
type Rank {
index: Int!
} #Rank
"WoT identity"
type Identity {
"Public key"
pubkey: Pubkey!
"Pseudo"
uid: String!
"Hash"
hash: Hash!
"Status: REVOKED, MISSING, MEMBER or NEWCOMER"
status: Identity_Status!
"Identity waiting for new membership (MISSING, MEMBER or NEWCOMER; false for REVOKED)"
membership_pending: Boolean!
"Block of new membership application; null if not membership_pending"
membership_pending_block: Block
"Limit date of new membership application; null if not membership_pending"
membership_pending_limitDate: Int64
"Block where the identity is written (entry into the web of trust); null for NEWCOMER"
id_written_block: Block
"Block of last membership application (joiners, actives, leavers), null for NEWCOMER"
lastApplication: Block
"Limit date of the membership application; null for REVOKED; limit date before revocation for MISSING"
limitDate: Int64
"Member is leaving? null for REVOKED or NEWCOMER"
isLeaving: Boolean
"Is a sentry? null if not MEMBER"
sentry: Boolean
"Active received certifications, sorted by increasing pubkeys"
received_certifications: Received_Certifications!
"Active sent certifications, sorted by increasing pubkeys"
sent_certifications: [Certification!]!
"All certifiers, old or present, but not REVOKED (empty list for NEWCOMER)"
all_certifiers: [Identity!]!
"All certified identities, old or present, but not REVOKED (empty list for NEWCOMER)"
all_certified: [Identity!]!
"All certifiers, old or present (empty list for NEWCOMER), with blocks of certification validity inputs and outputs"
all_certifiersIO: [CertHist!]!
"All certified identities, old or present (empty list for NEWCOMER), with blocks of certification validity inputs and outputs"
all_certifiedIO: [CertHist!]!
"State of the identity's distance rule"
distance: Distance!
"Expected state of the identity's distance rule, after pending certifications are aquired"
distanceE: Distance!
"Identity's quality"
quality: Fraction!
"Identity's expected quality, after pending certifications are aquired"
qualityE: Fraction!
"Identity's degree of centrality (percent)"
centrality: Float!
"History of identity's entries into and exits out of the WoT (empty list for NEWCOMER)"
history: [HistoryEvent!]!
"Minimum date of next sent certification; null if not MEMBER"
minDate: Int64
"Minimum date of next sent certification is passed; null if not MEMBER"
minDatePassed: Boolean
} #Identity
"The association of 'Identity' and date"
type DatedIdentity {
"Identity"
id: Identity!
"Associated date"
date: Int64!
}
"Status of an identity in WoT"
enum Identity_Status {
"The identity has been revoked"
REVOKED
"The identity is no more member but not revoked yet"
MISSING
"The identity is a member of the WoT"
MEMBER
"Newcomer waiting for membership"
NEWCOMER
} #Identity_Status
"Sorting order"
enum Identity_Order {
"Sorting by uid"
UID
"Sorting by pubkey"
PUBKEY
} #Identity_Order
"Used by 'Query.idSearch'"
input IdSearchInput {
"Prefix of searched keys (uid or pubkey)"
hint: String! = ""
"List of searched statuses"
status_list: [Identity_Status!]! = [REVOKED, MISSING, MEMBER, NEWCOMER]
} #IdSearchInput
"Result of 'Query.idSearch'"
type IdSearchOutput {
"Number of REVOKED identities corresponding to 'IdSearchInput.hint'"
revokedNb: Int!
"Number of MISSING identities corresponding to 'IdSearchInput.hint'"
missingNb: Int!
"Number of MEMBER identities corresponding to 'IdSearchInput.hint'"
memberNb: Int!
"Number of NEWCOMER identities corresponding to 'IdSearchInput.hint'"
newcomerNb: Int!
"All identities corresponding to 'IdSearchInput'"
ids: [Identity!]!
} #IdSearchOutput
"Certifications received by an identity"
type Received_Certifications {
"List of all valid received certifications"
certifications: [Certification!]!
"Limit date of the 'ParameterName.sigQty'th oldest received certification; or null if less than 'ParameterName.sigQty' certifications received"
limit: Int64
} #received_Certifications
"Certification sent by 'from' and received by 'to'"
type Certification {
"Sender"
from: Identity!
"Receiver"
to: Identity!
"Is certification in sandbox?"
pending: Boolean!
"Registration block"
block: Block
"Limit date (bct) of validity"
expires_on: Int64!
} #Certification
"Result of distance rule evaluation"
type Distance {
"Proportion of sentries reached in 'ParameterName.stepMax' steps or less (percent)"
value: Fraction!
"Is 'value' greater than 'ParameterName.xpercent' or equal?"
dist_ok: Boolean!
} #Distance
"Result type of 'Query.bestDist' and 'Query.bestQual'"
type IdDist {
"Identity of the certifier"
id: Identity!
"Distance or quality the certification, in addition to all the previous ones, gives to the certified identity"
dist: Distance!
} #IdDist
"Result type of 'Query.bestDist' and 'Query.bestQual'"
type IdQual {
"Identity of the certifier"
id: Identity!
"Distance or quality the certification, in addition to all the previous ones, gives to the certified identity"
qual: Fraction!
} #IdQual
"History of entries into the WoT and exits of an identity"
type HistoryEvent {
"Entry?"
in: Boolean!
"Registration block"
block: Block!
} #HistoryEvent
"History of certifications from or to an identity"
type CertHist {
"Certifier or certified identity"
id: Identity!
"Beginning and ending blocks of certifications validities"
hist: [CertEvent!]!
} #CertHist
"Beginning or ending block of a certification validity"
type CertEvent {
"Beginning?"
in: Boolean!
"Beginning or ending block"
block: Block!
} #CertEvent
"Number & dates of a block"
type Block {
"Block number"
number: Int!
"Blockchain time"
bct: Int64!
"UTC+0 real time"
utc0: Int64!
} #Block
"Differentiation filter parameters (Savitzky-Golay filter)"
input DifferParams {
"Number of points over which the filter is calculated"
pointsNb: Int! = 80
"Degree of polynomial used by the filter (usually 2 or 4)"
degree: Int! = 2
} #DifferParams
"Set of internal certifications and membership application dossiers available in sandbox"
interface File {
"List of internal certifications and membership application dossiers"
certifs_dossiers: [CertifOrDossier!]!
"Number of dossiers"
dossiers_nb: Int!
"Number of internal certifications"
certifs_nb: Int!
} #File
"Set of internal certifications and membership application dossiers available in sandbox; dated"
type FileS implements File {
"Present block"
now: Block!
"List of internal certifications and membership application dossiers"
certifs_dossiers: [CertifOrDossier!]!
"Number of dossiers"
dossiers_nb: Int!
"Number of internal certifications"
certifs_nb: Int!
} #FileS
"Internal certification or membership application dossier"
union CertifOrDossier = MarkedDatedCertification | MarkedDossier
"Inserted type used to distinguish 'DatedCertification'(s) and 'Dossier'(s) in 'CertifOrDossier'"
type MarkedDatedCertification {
datedCertification: DatedCertification!
} #MarkedDatedCertification
"Inserted type used to distinguish 'DatedCertification'(s) and 'Dossier'(s) in 'CertifOrDossier'"
type MarkedDossier {
dossier: Dossier!
} #MarkedDossier
"Certification in a 'File'"
type DatedCertification {
certification: Certification!
"Date of availability"
date: Int64!
} #DatedCertification
"Newcomer's membership application dossier"
type Dossier {
newcomer: Identity!
"Minimum number of certifications needed to fulfill the distance rule"
main_certifs: Int!
"External certifications"
certifications: [DatedCertification!]!
"'ParameterName.msPeriod' after the last membership application (or 0 if none)"
minDate: Int64!
"Date of availability"
date: Int64!
"Expiration date"
limit: Int64!
} #Dossier
"Result of 'Query.wwResult'"
interface WWResult {
"Total time of computation, 'File' included"
computation_duration: Int!
"Number of permutations used; this number may be very big"
permutations_nb: Int!
"Number of NEWCOMER(s)' dossiers"
dossiers_nb: Int!
"Number of internal certifications"
certifs_nb: Int!
"'permutations' displays the list of WotWizard permutations; their number may be very big"
permutations: [WeightedPermutation!]!
"Forecasts of NEWCOMER(s)' entries, sorted by dates of entries"
forecastsByDates: [Forecast!]!
"Forecasts of entries of the NEWCOMER(s) whose uid(s) begin with the 'with' parameter (or of all NEWCOMER(s) if 'with' is absent or null); the selection is not case sensitive"
forecastsByNames (with: String! = ""): [Forecast!]!
} #WWResult
"Result of 'Subscription.wwResult; dated'"
type WWResultS implements WWResult {
"Present block"
now: Block!
"Total time of computation, 'File' included"
computation_duration: Int!
"Number of permutations used; this number may be very big"
permutations_nb: Int!
"Number of NEWCOMER(s)' dossiers"
dossiers_nb: Int!
"Number of internal certifications"
certifs_nb: Int!
"'permutations' displays the list of WotWizard permutations; their number may be very big"
permutations: [WeightedPermutation!]!
"Forecasts of NEWCOMER(s)' entries, sorted by dates of entries"
forecastsByDates: [Forecast!]!
"Forecasts of entries of the NEWCOMER(s) whose uid(s) begin with the 'with' parameter (or of all NEWCOMER(s) if 'with' is absent or null); the selection is not case sensitive"
forecastsByNames (with: String! = ""): [Forecast!]!
} #WWResultS
"A permutation weighted by a probability"
type WeightedPermutation {
"Probability of occurrence"
proba: Float!
"Ordered list of NEWCOMER(s)' entries"
permutation: [PermutationElem!]!
} #WeightedPermutation
"An expected NEWCOMER's entry"
type PermutationElem {
id: Identity!
"Expected date of entry"
date: Int64!
"The expected date of entry may be later than 'date' (the computing was interrupted by lack of memory space)"
after: Boolean!
} #PermutationElem
"Forecast of a NEWCOMER's entry"
type Forecast {
id: Identity!
"Expected date of entry"
date: Int64!
"The expected date of entry may be later than 'date' (the computing was interrupted by lack of memory space)"
after: Boolean!
"Probability of the forecast"
proba: Float!
} #Forecast
"Entry or exit of an identity"
type EventId {
id: Identity!
"Entry or exit; true if entry"
inOut: Boolean!
} #EventId
"Entries and exits of identities happening in a block"
type Event {
"List of concerned identities"
idList: [EventId!]!
"Block where the event happens"
block: Block!
"Number of concerned identities in the WoT after the event"
number: Int!
} #Event
"An event with non-integer value, typically a flux of entries/exits"
type FluxEvent {
"Block where the event happens"
block: Block!
"Value of the flux at the event"
value: Float!
} #FluxEvent
"A parameter of the money"
type Parameter {
name: ParameterName!
par_type: ParameterType!
value: Number!
comment: String
} #Parameter
enum ParameterType {
INTEGER
FLOAT
DURATION
DATE
} #ParameterType
enum ParameterName {
"The relative growth of the UD every [dtReeval] period"
c
"Time period between two UD"
dt
"UD(0), i.e. initial Universal Dividend"
ud0
"Minimum delay between two certifications of a same issuer"
sigPeriod
"Maximum quantity of active certifications made by member"
sigStock
"Maximum delay a certification can wait before being expired for non-writing"
sigWindow
"Maximum age of an active certification"
sigValidity
"Minimum delay before replaying a certification"
sigReplay
"Minimum quantity of signatures to be part of the WoT"
sigQty
"Maximum delay an identity can wait before being expired for non-writing"
idtyWindow
"Maximum delay a membership can wait before being expired for non-writing"
msWindow
"Minimum delay between 2 memberships of a same issuer"
msPeriod
"Minimum percent of sentries to reach to match the distance rule"
xpercent
"Maximum age of an active membership"
msValidity
"Maximum distance between a WOT member and [xpercent] of sentries"
stepMax
"Number of blocks used for calculating median time"
medianTimeBlocks
"The average time for writing 1 block (wished time)"
avgGenTime
"The number of blocks required to evaluate again PoWMin value"
dtDiffEval
"The proportion of calculating members not excluded from the proof of work"
percentRot
"Time of first UD"
udTime0
"Time of first reevaluation of the UD"
udReevalTime0
"Time period between two re-evaluation of the UD"
dtReeval
"Maximum delay a transaction can wait before being expired for non-writing"
txWindow
} #ParameterName
"Fraction"
type Fraction {
"Numerator"
num: Int!
"Denominator"
denom: Int!
"Value of 'num' / 'denom'"
ratio: Float!
} #fraction
"64 bits signed integer"
scalar Int64
"Avatar of String"
scalar Hash
"Avatar of String"
scalar Pubkey
"Empty result"
scalar Void
"Int, Int64 or Float"
scalar Number