Ovaj članak je preveden pomoću veštačke inteligencije

Konfigurisanje ONLYOFFICE Docs Developer izdanja

Uvod

Da biste promenili bilo koje postavke servera ONLYOFFICE Docs, konfigurišite odgovarajući parametar u konfiguracionoj datoteci ONLYOFFICE Docs, koja se nalazi na sledećoj putanji:

  • Za Linux - /etc/onlyoffice/documentserver/default.json
  • Za Windows - %ProgramFiles%\ONLYOFFICE\DocumentServer\config\default.json

Ako želite da ga promenite, možete koristiti datoteku local.json, gde bi svi izmenjeni parametri trebalo da budu sačuvani. Ova datoteka se nalazi u istom direktorijumu kao i datoteka default.json, i cela struktura objekta za potrebni parametar mora biti zadržana.

Molimo vas da ne menjate sadržaj datoteke default.json direktno. Podrazumevane vrednosti će biti vraćene svaki put kada ponovo pokrenete Docker kontejner ili nadogradite ONLYOFFICE Docs na novu verziju, i sve vaše promene će biti izgubljene.

Podrazumevane postavke servera su opisane ispod.

Administratorska tabla

ParametarOpisTipPodrazumevano
Definiše port na kojem se pokreće usluga Administratorske table.integer9000
Definiše heš lozinke koji se koristi za zaštitu lozinke pomoću PBKDF2-SHA256 algoritma.
Vrednost ovog parametra se čuva u datoteci runtime.json. Na primer, za Linux verziju, ova datoteka se može naći ovde: /var/www/onlyoffice/Data/runtime.json
string""

Ovi parametri definišu svojstva Administratorske table. Za više detalja o korišćenju Administratorske table, možete se obratiti ovom članku.

Primer
"adminPanel": {
    "port": 9000
  }

StatsD

ParametarOpisTipPodrazumevano
Definiše da li su StatsD metrike omogućene za ONLYOFFICE Docs ili ne.booleanfalse
Definiše StatsD server host (ime hosta ili IP adresu).string"localhost"
Definiše port StatsD servera.string"8125"
Definiše string koji će biti dodat na početak svih statističkih podataka automatski. Pomaže u razlikovanju različitih aplikacija koje koriste isti StatsD server.string"ds."

Ovi parametri definišu svojstva StatsD servera, specificirajući agregator metrika.

Primer
"statsd": {
    "useMetrics": false,
    "host": "localhost",
    "port": "8125",
    "prefix": "ds."
}

Postavke AI dodatka

ParametarOpisTipPodrazumevano
Definiše akcije koje obavlja AI, npr. Chat, Sažimanje, Prevod, Analiza teksta, Generisanje slike, OCR, Vizija.object
Definiše AI modele, npr. gemini-1.5-pro-latest, llama3.2:latest, itd.array[]
Definiše AI provajdere, npr. OpenAI, Google Gemini, Anthropic, itd.object
Definiše verziju AI SDK-a.integer3
Definiše timeout AI proxy-a (meri se u minutima).string"5m"
Definiše koje spoljne veb stranice smeju da vrše cross-origin zahteve prema serveru.array of strings["https://onlyoffice.github.io", "https://onlyoffice-plugins.github.io"]
Podržava rutiranje AI zahteva putem proxy-a.string""

Ovi parametri definišu svojstva AI dodatka.

Primer
"aiSettings": {
    "actions": {},
    "models": [],
    "providers": {},
    "version": 3,
    "timeout": "5m",
    "allowedCorsOrigins": ["https://onlyoffice.github.io", "https://onlyoffice-plugins.github.io"],
    "proxy": ""
  }

Logger

ParametarOpisTipPodrazumevano
Definiše putanju do log datoteke.string""
Definiše opcije logovanja.object
Definiše da li se informacije o logovanju ispisuju na konzolu ili ne.booleantrue

Ovi parametri definišu svojstva logera.

Primer
"log": {
    "filePath": "",
    "options": {
        "replaceConsole": true
    }
}

Runtime konfiguracija

ParametarOpisTipPodrazumevano
Definiše putanju do dinamičke konfiguracione datoteke runtime.json. Podrazumevano se koristi putanja /var/www/onlyoffice/Data/runtime.json.string""
Definiše opcije keširanja za runtime.json.object
Definiše TTL (vreme trajanja) za svaki generisani element keša (meri se u sekundama).integer300
Definiše period korišćen za interval automatske provere brisanja (meri se u sekundama).integer60
Definiše da li će keširane promenljive biti klonirane ili ne. Ako je true, kreiraće se kopija keširane promenljive. Ako je false, samo referenca će biti sačuvana.booleanfalse

Ovi parametri definišu svojstva dinamičkog konfiguracionog fajla runtime.json. Ovaj fajl vam omogućava da promenite parametre bez ponovnog pokretanja. Fajl se ponovo čita na osnovu događaja nadgledanja ili svakih 5 minuta.

Primer
"runtimeConfig": {
    "filePath": "",
    "cache": {
      "stdTTL": 300,
      "checkperiod": 60,
      "useClones": false
    }
  }

Redovi

ParametarOpisTipPodrazumevano
Definiše tip posrednika poruka.string"rabbitmq"
Definiše vreme isteka konverzije (meri se u sekundama).integer300
Definiše TTL (vreme trajanja) svih poruka u redu (meri se u sekundama).integer900

Ovi parametri definišu red poruka primljenih od posrednika poruka.

Primer
"queue": {
    "type": "rabbitmq",
    "visibilityTimeout": 300,
    "retentionPeriod": 900
}

Email

ParametarOpisTipPodrazumevano
Definiše osnovna podešavanja za povezivanje sa SMTP serverom.object
Definiše naziv hosta ili IP adresu SMTP servera.string"localhost"
Definiše port SMTP servera.integer587
Definiše podatke za autentifikaciju.object

Definiše korisničko ime za autentifikaciju.

Napomena: počevši od verzije 8.3, vrednosti ovog parametra u fajlovima default.json i local.json su različite.
string""

Definiše lozinku za autentifikaciju.

Napomena: počevši od verzije 8.3, vrednosti ovog parametra u fajlovima default.json i local.json su različite.
string""
Definiše tehničke opcije za povezivanje sa SMTP serverom.object
Definiše da li je dozvoljeno korišćenje fajlova kao sadržaja. Ako je ovaj parametar postavljen na true, onda se JSON podaci iz nepouzdanog izvora ne mogu koristiti kao email. Ako prilog ili čvor poruke pokušaju da preuzmu nešto iz fajla, slanje vraća grešku. booleanfalse
Definiše da li je dozvoljeno korišćenje URL-ova kao sadržaja.booleanfalse
Definiše podešavanja email poruka.object
Definiše email adresu pošiljaoca. Sve email adrese mogu biti jednostavne "sender@server.com" ili sa formatiranim imenom '"Ime Pošiljaoca" sender@server.com'. string"from@example.com"
Definiše listu email adresa primalaca odvojenih zarezom ili niz primalaca koji će se pojaviti u polju To:.string"to@example.com"

Ovi parametri definišu podešavanja eksternog mail servera, koji se koristi za slanje obaveštenja. Za povezivanje sa mail serverom, koristite biblioteku nodemailer. Mnoga podešavanja konfiguracije se direktno prosleđuju ovoj biblioteci.

Primer
"email": {
    "smtpServerConfiguration": {
        "host": "localhost",
        "port": 587,
        "auth": {
            "user": "",
            "pass": ""
        }
    },
    "connectionConfiguration": {
        "disableFileAccess": false,
        "disableUrlAccess": false
    },
    "contactDefaults": {
        "from": "from@example.com",
        "to": "to@example.com"
    }
}

Obaveštenje

ParametarOpisTipPodrazumevano
Definiše pravila podešavanja obaveštenja za četiri tipa obaveštenja: licenseExpirationWarning, licenseExpirationError, licenseLimitEdit, licenseLimitLiveViewer. object
Definiše pravila za podešavanje obaveštenja licenseExpirationWarning.object
Definiše da li je obaveštenje licenseExpirationWarning omogućeno. Svaki tip obaveštenja mora biti posebno omogućen.booleanfalse
Definiše način slanja obaveštenja licenseExpirationWarning. Trenutno je dostupan samo tip email.array of strings["email"]
Definiše šablon naslova i tela obaveštenja licenseExpirationWarning.object
Definiše šablon naslova obaveštenja licenseExpirationWarning.string"%s Docs upozorenje o isteku licence"
Definiše šablon tela obaveštenja licenseExpirationWarning.string"Pažnja! Vaša licenca ističe %s.\nNakon ovog datuma, više nećete imati pravo na personalizovanu tehničku podršku i instalaciju novih verzija Docs-a koje su objavljene nakon ovog datuma."
Definiše politiku slanja obaveštenja licenseExpirationWarning.object
Definiše vreme kada će obaveštenje licenseExpirationWarning biti poslato (ne češće od navedenog perioda).string"1d"
Definiše pravila za podešavanje obaveštenja licenseExpirationError.object
Definiše da li je obaveštenje licenseExpirationError omogućeno. Svaki tip obaveštenja mora biti posebno omogućen.booleanfalse
Definiše način slanja obaveštenja licenseExpirationError. Trenutno je dostupan samo tip email.array of strings["email"]
Definiše šablon naslova i tela obaveštenja licenseExpirationError.object
Definiše šablon naslova obaveštenja licenseExpirationError.string"%s Docs upozorenje o isteku licence"
Definiše šablon tela obaveštenja licenseExpirationError.string"Pažnja! Vaša licenca je istekla %s.\nViše nemate pravo na personalizovanu tehničku podršku i instalaciju novih verzija Docs-a objavljenih nakon ovog datuma.\nMolimo kontaktirajte sales@onlyoffice.com za dogovor o obnovi licence."
Definiše politiku slanja obaveštenja licenseExpirationError.object
Definiše vreme kada će obaveštenje licenseExpirationError biti poslato (ne češće od navedenog perioda).string"1d"
Definiše pravila za podešavanje obaveštenja licenseLimitEdit.object
Definiše da li je obaveštenje licenseLimitEdit omogućeno. Svaki tip obaveštenja mora biti posebno omogućen.booleanfalse
Definiše način slanja obaveštenja licenseLimitEdit. Trenutno je dostupan samo tip email.array of strings["email"]
Definiše šablon naslova i tela obaveštenja licenseLimitEdit.object
Definiše šablon naslova obaveštenja licenseLimitEdit.string"%s Docs upozorenje o ograničenju konekcija licence"
Definiše šablon tela obaveštenja licenseLimitEdit.string"Pažnja! Dostigli ste %s%% od %s ograničenja postavljenog vašom licencom."
Definiše politiku slanja obaveštenja licenseLimitEdit.object
Definiše vreme kada će obaveštenje licenseLimitEdit biti poslato (ne češće od navedenog perioda).string"1d"
Definiše pravila za podešavanje obaveštenja licenseLimitLiveViewer.object
Definiše da li je obaveštenje licenseLimitLiveViewer omogućeno. Svaki tip obaveštenja mora biti posebno omogućen.booleanfalse
Definiše način slanja obaveštenja licenseLimitLiveViewer. Trenutno je dostupan samo tip email.array of strings["email"]
Definiše šablon za naslov i telo obaveštenja licenseLimitLiveViewer.objekat
Definiše šablon za naslov obaveštenja licenseLimitLiveViewer.string"%s Docs upozorenje o ograničenju konekcija licence"
Definiše šablon za telo obaveštenja licenseLimitLiveViewer.string"Pažnja! Dostigli ste %s%% od %s limita postavljenog vašom licencom."
Definiše politiku slanja obaveštenja licenseLimitLiveViewer.objekat
Definiše vreme kada će obaveštenje licenseLimitLiveViewer biti poslato (ne češće od navedenog perioda).string"1d"

Ovi parametri definišu postavke obaveštenja.

Obaveštenja sa sledećim tipovima događaja i sadržajem se šalju:

  • Prekoračeno je 70% kvote konekcija (kvota jedinstvenih korisnika).

    Upozorenje o ograničenju konekcija licence: "Pažnja! Dostigli ste 70% limita konekcija postavljenog vašom licencom."

  • Dosegnuta je kvota konekcija (kvota jedinstvenih korisnika).

    Upozorenje o ograničenju konekcija licence: "Pažnja! Dostigli ste 100% limita konekcija postavljenog vašom licencom."

  • 30 dana pre nego što licenca istekne.

    Upozorenje o isteku licence: "Pažnja! Vaša licenca ističe 8. septembra 2024. Nakon ovog datuma, više nećete imati pravo na ličnu tehničku podršku i instalaciju novih verzija Docs-a objavljenih nakon ovog datuma."

  • Licenca je istekla.

    Upozorenje o ograničenju konekcija licence: "Pažnja! Vaša licenca je istekla 8. septembra 2024. Više nemate pravo na ličnu tehničku podršku i instalaciju novih verzija Docs-a objavljenih nakon ovog datuma. Molimo kontaktirajte sales@onlyoffice.com za razgovor o obnovi licence."

Ova obaveštenja se beleže u server log sa WARN ili ERROR nivoom.

Primer
"notification": {
"rules": {
"licenseExpirationWarning": {
"enable": false,
"transportType": [
"email"
],
"template": {
"title": "%s Docs upozorenje o isteku licence",
"body": "Pažnja! Vaša licenca ističe %s.\nNakon ovog datuma, više nećete imati pravo na ličnu tehničku podršku i instalaciju novih verzija Docs-a objavljenih nakon ovog datuma."
},
"policies": {
"repeatInterval": "1d"
}
},
"licenseExpirationError": {
"enable": false,
"transportType": [
"email"
],
"template": {
"title": "%s Docs upozorenje o isteku licence",
"body": "Pažnja! Vaša licenca je istekla %s.\nViše nemate pravo na ličnu tehničku podršku i instalaciju novih verzija Docs-a objavljenih nakon ovog datuma.\nMolimo kontaktirajte sales@onlyoffice.com za razgovor o obnovi licence."
},
"policies": {
"repeatInterval": "1d"
}
},
"licenseLimitEdit": {
"enable": false,
"transportType": [
"email"
],
"template": {
"title": "%s Docs upozorenje o ograničenju konekcija licence",
"body": "Pažnja! Dostigli ste %s%% od %s limita postavljenog vašom licencom."
},
"policies": {
"repeatInterval": "1h"
}
},
"licenseLimitLiveViewer": {
"enable": false,
"transportType": [
"email"
],
"template": {
"title": "%s Docs upozorenje o ograničenju konekcija licence",
"body": "Pažnja! Dostigli ste %s%% od limita za live viewer %s postavljenog vašom licencom."
},
"policies": {
"repeatInterval": "1h"
}
}
}
}

Servis za skladištenje dokumenata

ParametarOpisTipPodrazumevano
Definiše naziv servisa za skladištenje dokumenata. Na primer, vrednost "storage-s3" omogućava povezivanje Amazon S3 bucket-a kao keš. Vrednost "storage-az" omogućava povezivanje MS Azure Blob Storage-a kao keš.string"storage-fs"
Definiše parametre objekta fileSystem.objekat
Definiše putanju do foldera App_Data gde su svi fajlovi skladišteni.string""
Definiše vreme kada privremeni URL do objekta fileSystem ističe (mereno u sekundama).integer900
Definiše tajni string koji se koristi za potpisivanje URL-a.string"verysecretstring"
Definiše AWS region gde se nalazi vaš Amazon bucket.string""
Definiše endpoint S3 AWS skladišta dokumenata ili MS Azure Blob Storage-a.string"http://localhost/s3"
Definiše jedinstveni naziv S3 AWS skladišta dokumenata ili MS Azure Blob Storage-a.string"cache"
Definiše naziv foldera S3 AWS skladišta dokumenata gde su svi fajlovi skladišteni.string"files"
Definiše naziv keš foldera za rad u multi-tenant režimu.string"data"
Definiše parametre koji omogućavaju prilagođavanje komandi za skladište, na primer, omogućavanje AWS KMS.objekat
Definiše parametre koji omogućavaju prilagođavanje komandi za S3 AWS skladište dokumenata.objekat
Definiše parametre tipa komande putObject koji se koristi za upload objekta u određeni S3 bucket.objekat
Definiše tip enkripcije za novouploadovani objekat. Dostupne vrednosti su "aws:kms" ili "AES256".string
Ovo je opcionalna postavka. Optimizuje troškove po zahtevu smanjenjem poziva KMS API-ju.boolean
Definiše identifikator (ARN ili ključ) ključa kojim upravlja korisnik u AWS KMS koji se koristi za šifrovanje objekta nakon što je otpremljen.string
Definiše parametre tipa komande getObject koji se koristi za preuzimanje objekta iz određenog S3 bucket-a.object
Definiše parametre tipa komande copyObject koji se koristi za kreiranje kopije objekta smeštenog u određenom S3 bucket-u.object
Definiše tip šifrovanja za novo kopirani objekat. Dostupne vrednosti su "aws:kms" ili "AES256".string
Ovo je opcionalna postavka. Optimizuje troškove po zahtevu smanjenjem poziva KMS API-ju.boolean
Definiše identifikator (ARN ili ključ) ključa kojim upravlja korisnik u AWS KMS koji se koristi za šifrovanje objekta nakon što je kopiran.string
Definiše kako Amazon S3 treba da rukuje metapodacima odredišnog objekta tokom operacije kopiranja. Ako je vrednost postavljena na "COPY", metapodaci iz izvornog objekta se kopiraju na odredišni objekat. Ako je vrednost postavljena na "REPLACE", metapodaci odredišnog objekta se zamenjuju metapodacima navedenim u zahtevu copyObject i metapodaci iz izvornog objekta se ne kopiraju.string"COPY"
Definiše parametre tipa komande listObjects koji se koristi za preuzimanje liste objekata unutar određenog S3 bucket-a.object
Definiše maksimalan broj objekata koji se vraćaju u odgovoru.integer1000
Definiše parametre tipa komande deleteObject koji se koristi za uklanjanje objekta iz određenog S3 bucket-a.object
Definiše parametre koji omogućavaju prilagođavanje komandi za MS Azure Blob Storage.object
Definiše parametre tipa komande uploadData koji se koristi za otpremanje podataka na MS Azure Blob Storage.object
Definiše ime opsega šifrovanja koji se koristi za šifrovanje otpremljenog blob-a.string
Definiše parametre tipa komande uploadStream koji se koristi za otpremanje podataka iz toka na MS Azure Blob Storage.object
Definiše ime opsega šifrovanja koji se koristi za šifrovanje blob-a otpremljenog iz toka.string
Definiše parametre tipa komande download koji se koristi za preuzimanje podataka sa MS Azure Blob Storage.object
Definiše parametre tipa komande syncCopyFromURL koji se koristi za kopiranje blob-a sa izvornog URL-a na odredišni blob.object
Definiše ime opsega šifrovanja koji se koristi za šifrovanje kopiranog blob-a.string
Definiše parametre tipa komande listBlobsFlat koji se koristi za preuzimanje liste svih blob-ova u kontejneru.object
Definiše maksimalan broj blob-ova za povratak.integer1000
Definiše parametre tipa komande deleteBlob koji se koristi za uklanjanje blob-a.object
Definiše vreme kada URL do S3 AWS skladišta dokumenata ističe (mereno u milisekundama).integer604800
Definiše ID ključa za pristup S3 AWS skladištu dokumenata ili MS Azure Blob Storage.string""
Definiše tajni ključ za pristup S3 AWS skladištu dokumenata ili MS Azure Blob Storage.string""
Definiše da li je SSL za S3 AWS skladište dokumenata omogućen ili ne.booleanfalse
Definiše da li zahtevi ka S3 AWS skladištu dokumenata uvek koriste adresiranje putem putanje.booleantrue
Definiše eksterni host koji se koristi umesto hosta navedenog u zahtevu.string""
Definiše izdavanje linkova ka eksternom skladištu: direktni linkovi ili linkovi koji su proksirani kroz Document Server. Postavljanje ovog parametra na true omogućava direktne linkove, dok vrednost false omogućava korišćenje internih linkova (server proksira zahteve ka skladištu).booleanfalse

Ovi parametri definišu konfiguraciju usluge skladištenja dokumenata.

Primer
"storage": {
    "name": "storage-fs",
    "fs": {
      "folderPath": "",
      "urlExpires": 900,
      "secretString": "verysecretstring"
    },
    "region": "",
    "endpoint": "http://localhost/s3",
    "bucketName": "cache",
    "storageFolderName": "files",
    "cacheFolderName": "data",
    "commandOptions": {
      "s3": {
        "putObject": {},
        "getObject": {},
        "copyObject": {
          "MetadataDirective": "COPY"
        },
        "listObjects": {
          "MaxKeys": 1000
        },
        "deleteObject": {}
      },
      "az": {
        "uploadData": {},
        "uploadStream": {},
        "download": {},
        "syncCopyFromURL": {},
        "listBlobsFlat": {
          "maxPageSize": 1000
        },
        "deleteBlob": {}
      }
    },
    "urlExpires": 604800,
    "accessKeyId": "",
    "secretAccessKey": "",
    "sslEnabled": false,
    "s3ForcePathStyle": true,
    "externalHost": "",
    "useDirectStorageUrls": false
  }

Persistentno skladište

Ovi parametri definišu podešavanja za persistentno skladište, koje se koristi za odvajanje podešavanja za skladištenje keširanih dokumenata i skladištenje zaboravljenih i greškom nastalih fajlova. Podešavanja koja nisu navedena u ovom objektu nasleđuju se iz storage objekta. Ovo odvajanje je pogodno za nadogradnje servera.

Primer
"persistentStorage": {
}

RabbitMQ

ParametarOpisTipPodrazumevano

Definiše RabbitMQ URL.

Napomena: počevši od verzije 8.3, vrednosti ovog parametra u fajlovima default.json i local.json su različite.
string"amqp://localhost:5672"

Definiše RabbitMQ opcije za soket koje će biti prosleđene biblioteci za soket (net ili tls). Ove opcije moraju biti polja postavljena na objektu koji se prosleđuje. Opcije za soket mogu se koristiti za SSL konekciju i mogu sadržati sledeća polja:

  • cert - definiše sertifikat koji se predstavlja serveru (u PEM ili pkcs12 formatu),
    tip: string,
    primer: "";
  • key - definiše privatni ključ za sertifikat (u PEM ili pkcs12 formatu),
    tip: string,
    primer: "";
  • passphrase - definiše lozinku za privatni ključ,
    tip: string,
    primer: "MySecretPassword";
  • ca - definiše listu CA sertifikata u PEM formatu kojima verujemo, s obzirom da koristimo samopotpisani sertifikat,
    tip: niz,
    primer: [];
  • noDelay - definiše da li je TCP_NODELAY (Nagleov algoritam) postavljen na osnovnom soketu ili ne,
    tip: boolean,
    primer: true.
objekat{}
Definiše Publisher Subscriber exchange server.objekat
Definiše ime Publisher Subscriber servera.string"ds.pubsub"
Definiše podešavanja Publisher Subscriber servera.objekat
Definiše da li će red preživeti restart brokera.booleantrue
Definiše Publisher Subscriber red.objekat
Definiše ime Publisher Subscriber reda.string""
Definiše podešavanja Publisher Subscriber reda.objekat
Definiše da li će red biti obrisan kada broj korisnika padne na nulu.booleantrue
Definiše da li će red biti vezan za konekciju.booleantrue
Definiše dodatne argumente, obično parametre za neku vrstu brokerske ekstenzije, npr. visoku dostupnost, TTL.objekat
Definiše vrednost x-queue-type zaglavlja koje specificira tip reda. Mogu se koristiti samo klasični redovi.string"classic"
Definiše red zadataka.objekat
Definiše ime reda zadataka.string"ds.converttask6"
Definiše podešavanja reda zadataka.objekat
Definiše da li će red preživeti restart brokera.booleantrue
Definiše prioritet reda.integer6
Definiše dodatne argumente, obično parametre za neku vrstu brokerske ekstenzije, npr. visoku dostupnost, TTL.objekat
Definiše vrednost zaglavlja x-queue-type koja specificira tip reda. Ovo podešavanje može se koristiti za postavljanje quorum redova.string"classic"
Definiše red odgovora.object
Definiše ime reda odgovora.string"ds.convertresponse"
Definiše podešavanja reda odgovora.object
Definiše da li će red preživeti restart brokera.booleantrue
Definiše dodatne argumente, obično parametre za neku vrstu brokerske ekstenzije, npr. visoka dostupnost, TTL.object
Definiše vrednost zaglavlja x-queue-type koja specificira tip reda. Ovo podešavanje može se koristiti za postavljanje quorum redova.string"classic"
Definiše razmenu mrtvih poruka.object
Definiše ime razmene mrtvih poruka.string"ds.exchangeconvertdead"
Definiše podešavanja razmene mrtvih poruka.object
Definiše da li će red preživeti restart brokera.booleantrue
Definiše red mrtvih poruka.object
Definiše ime reda mrtvih poruka.string"ds.convertdead"
Definiše podešavanja reda mrtvih poruka.object
Definiše da li će red preživeti restart brokera.booleantrue
Definiše dodatne argumente, obično parametre za neku vrstu brokerske ekstenzije, npr. visoka dostupnost, TTL.object
Definiše vrednost zaglavlja x-queue-type koja specificira tip reda. Ovo podešavanje može se koristiti za postavljanje quorum redova.string"classic"
Definiše red sa odlaganjem.object
Definiše ime reda sa odlaganjem.string"ds.delayed"
Definiše podešavanja reda sa odlaganjem.object
Definiše da li će red preživeti restart brokera.booleantrue
Definiše dodatne argumente, obično parametre za neku vrstu brokerske ekstenzije, npr. visoka dostupnost, TTL.object
Definiše vrednost zaglavlja x-queue-type koja specificira tip reda. Ovo podešavanje može se koristiti za postavljanje quorum redova.string"classic"

Ovi parametri definišu konfiguraciju RabbitMQ posrednika poruka.

Primer
"rabbitmq": {
"url": "amqp://localhost:5672",
"socketOptions": {},
"exchangepubsub": {
    "name": "ds.pubsub",
    "options": {
        "durable": true
    }
},
"queuepubsub": {
    "name": "",
    "options": {
        "autoDelete": true,
        "exclusive": true,
        "arguments": {
            "x-queue-type": "classic"
        }
    }
},
"queueconverttask": {
    "name": "ds.converttask6",
    "options": {
        "durable": true,
        "maxPriority": 6,
        "arguments": {
            "x-queue-type": "classic"
        }
    }
},
"queueconvertresponse": {
    "name": "ds.convertresponse",
    "options": {
        "durable": true,
        "arguments": {
            "x-queue-type": "classic"
        }
    }
},
"exchangeconvertdead": {
    "name": "ds.exchangeconvertdead",
    "options": {
        "durable": true
    }
},
"queueconvertdead": {
    "name": "ds.convertdead",
    "options": {
        "durable": true,
        "arguments": {
            "x-queue-type": "classic"
        }
    }
},
"queuedelayed": {
    "name": "ds.delayed",
    "options": {
        "durable": true,
        "arguments": {
            "x-queue-type": "classic"
        }
    }
}
}

ActiveMQ

ParametarOpisTipPodrazumevano
Definiše opcije povezivanja za ActiveMQ.object
Definiše port servera na koji je povezan ActiveMQ kontejner.integer5672
Definiše host (ime hosta ili IP adresu) servera na koji je povezan ActiveMQ kontejner.string"localhost"
Definiše da li će se ActiveMQ modul automatski pokušati ponovo povezati ako dođe do prekida (true) ili ne (false).booleanfalse
Definiše red zadataka.string"ds.converttask"
Definiše red odgovora.string"ds.convertresponse"
Definiše red mrtvih pisama.string"ActiveMQ.DLQ"
Definiše odloženi red.string"ds.delayed"
Definiše temu za Publisher Subscriber.string"ds.pubsub"

Ovi parametri definišu konfiguraciju ActiveMQ posrednika poruka.

Primer
"activemq": {
    "connectOptions": {
        "port": 5672,
        "host": "localhost",
        "reconnect": false
    },
    "queueconverttask": "ds.converttask",
    "queueconvertresponse": "ds.convertresponse",
    "queueconvertdead": "ActiveMQ.DLQ",
    "queuedelayed": "ds.delayed",
    "topicpubsub": "ds.pubsub"
}

DNS keš

ParametarOpisTipPodrazumevano
Definiše da li je DNS keš omogućen ili ne.booleantrue
Definiše vreme kada DNS zapisi ističu (mereno u sekundama).integer300
Definiše veličinu DNS keša.integer1000

Ovi parametri definišu konfiguraciju DNS keša koji se koristi za IP-filter.

Primer
"dnscache": {
    "enable" : true,
    "ttl" : 300,
    "cachesize" : 1000
}

OpenPGP protokol

ParametarOpisTipPodrazumevano
Definiše konfiguraciju OpenPGP protokola.object{}
Definiše postavke za OpenPGP enkripciju.object
Definiše lozinku koja se koristi za OpenPGP enkripciju.array of strings["verysecretstring"]
Definiše postavke za OpenPGP dekripciju.object
Definiše lozinku koja se koristi za OpenPGP dekripciju.array of strings["verysecretstring"]

Ovi parametri definišu postavke OpenPGP protokola, koji se koristi za enkripciju lozinke prilikom otvaranja enkriptovanog dokumenta za uređivanje.

Primer
"openpgpjs": {
    "config": {
    },
    "encrypt": {
        "passwords": ["verysecretstring"]
    },
    "decrypt": {
        "passwords": ["verysecretstring"]
    }
}

AES-256-GCM algoritam

ParametarOpisTipPodrazumevano
Definiše konfiguraciju AES-256-GCM algoritma.object
Definiše dužinu ključa mereno u bajtovima.integer32
Definiše dužinu soli mereno u bajtovima.integer64
Definiše dužinu inicijalizacionog vektora mereno u bajtovima.integer16
Definiše dužinu iteracija mereno u bajtovima.integer5
Definiše lozinku koja se koristi za AES-256-GCM enkripciju.string"verysecretstring"

Ovi parametri definišu postavke AES-256-GCM algoritma enkripcije koji se koristi za zaštitu lozinkom dokumenata.

Primer
"aesEncrypt": {
    "config": {
        "keyByteLength": 32,
        "saltByteLength": 64,
        "initializationVectorByteLength": 16,
        "iterationsByteLength": 5
    },
    "secret": "verysecretstring"
}

Bottleneck

ParametarOpisTipPodrazumevano
Definiše opcije konstruktora za generisanje limitera za ograničavanje zahteva prema bazi podataka.object{}

Ovaj parametar definiše konfiguraciju Bottleneck-a.

Primer
"bottleneck": {
    "getChanges": {
    }
}

Windows System Root certifikati

ParametarOpisTipPodrazumevano
Definiše način ubrizgavanja Windows System Root sertifikata. Znak "+" označava da se koristi nova eksperimentalna metoda za instalaciju sertifikata.string"+"

Ovaj parametar definiše podešavanja za Windows System Root certifikate.

Primer
"win-ca": {
    "inject": "+"
}

WOPI

ParametarOpisTipPodrazumevano
Definiše da li je WOPI omogućen ili ne.booleanfalse
Definiše WOPI host (ime hosta ili IP adresa).string""
Definiše putanju do WOPI HTML šablona.string"../../web-apps/apps/api/wopi"
Definiše zonu koju Document Server koristi za navigaciju pregledača ka WOPI aplikaciji.string"external-http"
Definiše putanju do favikone za uređivač dokumenata.string"/web-apps/apps/documenteditor/main/resources/img/favicon.ico"
Definiše putanju do favikone za uređivač tabela.string"/web-apps/apps/spreadsheeteditor/main/resources/img/favicon.ico"
Definiše putanju do favikone za uređivač prezentacija.string"/web-apps/apps/presentationeditor/main/resources/img/favicon.ico"
Definiše putanju do favikone za uređivač PDF dokumenata.string"/web-apps/apps/pdfeditor/main/resources/img/favicon.ico"
Definiše putanju do favikone za uređivač dijagrama.string"/web-apps/apps/visioeditor/main/resources/img/favicon.ico"
Definiše listu WOPI parametara informacija o fajlu koji su blokirani prilikom slanja ovog niza u pregledač. Međutim, ovi parametri su dostupni na serveru.niz stringova["FileUrl"]
Definiše tipove fajlova koji se mogu pregledati u PDF uređivaču.
Vrednost ovog parametra je sačuvana u fajlu onlyoffice-docs-formats.json.
niz stringova[]
Definiše tipove fajlova koji se mogu uređivati u PDF uređivaču.
Vrednost ovog parametra je sačuvana u fajlu onlyoffice-docs-formats.json.
niz stringova[]
Definiše tipove fajlova za forme.
Vrednost ovog parametra je sačuvana u fajlu onlyoffice-docs-formats.json.
niz stringova[]
Definiše tipove fajlova koji se mogu pregledati u uređivaču dokumenata.
Vrednost ovog parametra je sačuvana u fajlu onlyoffice-docs-formats.json.
niz stringova[]
Definiše tipove fajlova koji se mogu uređivati u uređivaču dokumenata.
Vrednost ovog parametra je sačuvana u fajlu onlyoffice-docs-formats.json.
niz stringova[]
Definiše tipove fajlova koji se mogu pregledati u uređivaču tabela.
Vrednost ovog parametra je sačuvana u fajlu onlyoffice-docs-formats.json.
niz stringova[]
Definiše tipove fajlova koji se mogu uređivati u uređivaču tabela.
Vrednost ovog parametra je sačuvana u fajlu onlyoffice-docs-formats.json.
niz stringova[]
Definiše tipove fajlova koji se mogu pregledati u uređivaču prezentacija.
Vrednost ovog parametra je sačuvana u fajlu onlyoffice-docs-formats.json.
niz stringova[]
Definiše tipove fajlova koji se mogu uređivati u uređivaču prezentacija.
Vrednost ovog parametra je sačuvana u fajlu onlyoffice-docs-formats.json.
niz stringova[]
Definiše tipove fajlova koji se mogu pregledati u uređivaču dijagrama.
Vrednost ovog parametra je sačuvana u fajlu onlyoffice-docs-formats.json.
niz stringova[]
Definiše tipove fajlova koji se mogu uređivati u uređivaču dijagrama.
Vrednost ovog parametra je sačuvana u fajlu onlyoffice-docs-formats.json.
niz stringova[]

Definiše javni ključ koji integrator koristi za proveru privatnog ključa.

Napomena: počevši od verzije 8.3, vrednosti ovog parametra u fajlovima default.json i local.json su različite.
string""

Definiše RSA modulus u Base64-enkodiranom formatu koji se koristi za dobijanje javnog ključa.

Napomena: počevši od verzije 8.3, vrednosti ovog parametra u datotekama default.json i local.json su različite.
string""
Definiše RSA eksponent u Base64-enkodiranom formatu koji se koristi za dobijanje javnog ključa.string65537

Definiše privatni ključ koji potpisuje zahtev Document Server-a.

Napomena: počevši od verzije 8.3, vrednosti ovog parametra u datotekama default.json i local.json su različite.
string""

Definiše stari javni ključ koji je integrator koristio za proveru privatnog ključa.

Napomena: počevši od verzije 8.3, vrednosti ovog parametra u datotekama default.json i local.json su različite.
string""

Definiše stari RSA modulus u Base64-enkodiranom formatu koji je korišćen za dobijanje javnog ključa.

Napomena: počevši od verzije 8.3, vrednosti ovog parametra u datotekama default.json i local.json su različite.
string""
Definiše stari RSA eksponent u Base64-enkodiranom formatu koji je korišćen za dobijanje javnog ključa.string65537

Definiše stari privatni ključ koji je potpisivao zahtev Document Server-a.

Napomena: počevši od verzije 8.3, vrednosti ovog parametra u datotekama default.json i local.json su različite.
string""
Definiše interval u minutima za osvežavanje zaključavanja datoteke resetovanjem automatskog tajmera isteka na 30 minuta.string"10m"
Definiše svojstva dummy handlera za stres testiranje.object
Definiše da li su dummy handleri omogućeni ili ne.booleanfalse
Definiše dummy putanju do uzorka datoteke.string""

Ovi parametri definišu konfiguraciju WOPI protokola.

Primer
"wopi": {
"enable": false,
"host": "",
"htmlTemplate": "../../web-apps/apps/api/wopi",
"wopiZone": "external-http",
"favIconUrlWord": "/web-apps/apps/documenteditor/main/resources/img/favicon.ico",
"favIconUrlCell": "/web-apps/apps/spreadsheeteditor/main/resources/img/favicon.ico",
"favIconUrlSlide": "/web-apps/apps/presentationeditor/main/resources/img/favicon.ico",
"favIconUrlPdf": "/web-apps/apps/pdfeditor/main/resources/img/favicon.ico",
"favIconUrlDiagram": "/web-apps/apps/visioeditor/main/resources/img/favicon.ico",
"fileInfoBlockList": ["FileUrl"],
"pdfView": [],
"pdfEdit": [],
"forms": [],
"wordView": [],
"wordEdit": [],
"cellView": [],
"cellEdit": [],
"slideView": [],
"slideEdit": [],
"diagramView": [],
"diagramEdit": [],
"publicKey": "",
"modulus": "",
"exponent": 65537,
"privateKey": "",
"publicKeyOld": "",
"modulusOld": "",
"exponentOld": 65537,
"privateKeyOld": "",
"refreshLockInterval": "10m",
"dummy": {
  "enable": false,
  "sampleFilePath": ""
}
}

Stanari

ParametarOpisTipPodrazumevano
Definiše direktorijum koji ograničava datoteke koje ONLYOFFICE Docs može da pristupi.string""
Definiše osnovno ime domena stanara.string""
Definiše naziv konfiguracione datoteke u fascikli stanara za nadjačavanje default.json. Koristi se u režimu sa više stanara za inicijalizaciju specifičnih podešavanja stanara (wopi, ipfilter, jwt secret itd.). string"config.json"
Definiše .pem naziv datoteke gde je čuvan tajni ključ stanara.string"secret.key"
Definiše naziv datoteke gde je čuvana licenca stanara.string"license.lic"
Definiše ime domena podrazumevanog stanara.string"localhost"
Definiše svojstva keša za čitanje multi-tenant licence i tajne.object
Definiše TTL (vreme trajanja) za svaki generisani element keša (izraženo u sekundama).integer300
Definiše period koji se koristi za automatski interval provere brisanja (izraženo u sekundama).integer60
Definiše da li će keširane promenljive biti klonirane ili ne. Ako je true, kreiraće se kopija keširane promenljive. Ako je false, sačuvaće se samo referenca.booleanfalse

Ovi parametri definišu svojstva stanara za rad u režimu sa više stanara.

Primer
"tenants": {
"baseDir" : "",
"baseDomain" : "",
"filenameConfig" : "config.json",
"filenameSecret" : "secret.key",
"filenameLicense" : "license.lic",
"defaultTenant" : "localhost",
"cache": {
    "stdTTL": 300,
    "checkperiod": 60,
    "useClones": false
},
}

Eksterni zahtev

ParametarOpisTipPodrazumevano
Definiše IP adrese koje su dozvoljene za direktne zahteve.object
Definiše listu IP adresa koje su pouzdane za direktne zahteve.list[]
Definiše da li su pouzdane IP adrese u JWT ili ne.booleantrue
Definiše opcije za eksterne zahteve.object
Definiše da li su eksterni zahtevi dozvoljeni ili ne.booleantrue
Definiše da li će privatna IP adresa biti blokirana ili ne.booleantrue
Definiše proxy URL.string""
Definiše parametre za autentifikaciju proxy-ja.object
Definiše korisničko ime za autentifikaciju proxy-ja.string""
Definiše lozinku za autentifikaciju proxy-ja.string""
Definiše zaglavlja proxy-ja.object{}

Ovi parametri definišu konfiguraciju eksternih zahteva.

Primer
"externalRequest": {
    "directIfIn" : {
        "allowList": [],
        "jwtToken": true
    },
    "action": {
        "allow": true,
        "blockPrivateIP": true,
        "proxyUrl": "",
        "proxyUser": {
            "username": "",
            "password": ""
        },
        "proxyHeaders": {
        }
    }
}

Document Server usluge

Ovi parametri definišu podešavanja za Document Server usluge.

ParametarOpisTipPodrazumevano
Definiše podešavanja za sesiju zajedničkog uređivanja.object

Server

ParametarOpisTipPodrazumevano
Definiše port servera.integer8000
Definiše broj radnih niti po CPU.integer1
Definiše režim rada servera.string"development"
Definiše maksimalnu veličinu za sve privremeno otpremljene fajlove koje koristi svaki proces (mereno u bajtovima).integer104857600
Definiše maksimalnu veličinu za sve slike otpremljene u svakom procesu (mereno u bajtovima).integer26214400
Definiše svojstva tajmauta za preuzimanje slika.object

Definiše period koji specificira dva tajmauta:

  • tajmaut čitanja - vreme čekanja da server pošalje zaglavlja odgovora (i započne telo odgovora) pre nego što se zahtev prekine;
  • tajmaut konekcije - postavlja tajmaut za soket nakon perioda neaktivnosti. Imajte na umu da povećanje tajmauta preko OS-širokog TCP tajmauta konekcije neće imati efekta.

Ovaj parametar se šalje npm modulu.

string"2m"
Definiše ceo ciklus zahteva - period od početka preuzimanja do potpunog preuzimanja.string"2m"
Definiše svojstva tajmauta za zahtev povratnog poziva.object

Definiše period koji specificira dva tajmauta:

  • tajmaut čitanja - vreme čekanja da server pošalje zaglavlja odgovora (i započne telo odgovora) pre nego što se zahtev prekine;
  • tajmaut konekcije - postavlja tajmaut za soket nakon perioda neaktivnosti. Imajte na umu da povećanje tajmauta preko OS-širokog TCP tajmauta konekcije neće imati efekta.

Ovaj parametar se šalje npm modulu.

string"10m"
Definiše tajmaut za ceo ciklus zahteva.string"10m"
Definiše putanju gde će se slati zahtevi za proveru zdravlja sistema.string"../public/healthcheck.docx"
Definiše vreme odlaganja početka konverzije (mereno u milisekundama) nakon što je uređena datoteka zatvorena.integer5000
Definiše da li se singleton može uređivati ili ne.booleanfalse
Definiše naziv foldera gde se čuvaju sve zaboravljene datoteke.string"forgotten"
Definiše naziv zaboravljene datoteke.string"output"
Definiše maksimalnu veličinu promena zahteva.integer20000
Definiše da li se datoteke zaštićene lozinkom mogu otvoriti ili ne.booleantrue
Definiše da li anonimni korisnici imaju pristup uređivaču ili prikazu uživo ili ne.booleantrue
Definiše skladište podataka uređivača. Moguće vrednosti: "editorDataRedis", "".string"editorDataRedis"
Definiše skladište podataka uređivača za obračun licence i statistiku (lokalna memorija ili redis). Moguće vrednosti su "editorDataMemory", "editorDataRedis", ili "". Podrazumevana vrednost "" znači da će se koristiti vrednost parametra editorDataStorage. Ovaj parametar se prvenstveno koristi za šardirani klaster.string""
Definiše da li se sastavljena datoteka čuva u svom originalnom formatu ili ne.booleantrue
Definiše putanju do šablona "nove" datoteke ako je primljena datoteka od 0 bajta iz linka za otvaranje.string"../../document-templates/new"
Definiše putanju do datoteke "onlyoffice-docs-formats".string"../../document-formats/onlyoffice-docs-formats.json"
Definiše ekstenzije koje je dozvoljeno preuzeti putem handlera za preuzimanje datoteka.array of strings["pdf", "xlsx"]
Definiše da li će potrebni parametri tokena biti validirani. Ovo je potrebno zbog sigurnosti. Na primer, token za konverziju neće se koristiti za otvaranje dokumenta.booleantrue
Definiše da li se datoteka bez ikakvih promena može prisilno sačuvati klikom na dugme Sačuvaj.booleanfalse

Ovi parametri definišu konfiguraciju servera.

Primer
"services": {
    "CoAuthoring": {
        "server": {
            "port": 8000,
            "workerpercpu": 1,
            "mode": "development",
            "limits_tempfile_upload": 104857600,
            "limits_image_size": 26214400,
            "limits_image_download_timeout": {
                "connectionAndInactivity": "2m",
                "wholeCycle": "2m"
            },
            "callbackRequestTimeout": {
                "connectionAndInactivity": "10m",
                "wholeCycle": "10m"
            },
            "healthcheckfilepath": "../public/healthcheck.docx",
            "savetimeoutdelay": 5000,
            "edit_singleton": false,
            "forgottenfiles": "forgotten",
            "forgottenfilesname": "output",
            "maxRequestChanges": 20000,
            "openProtectedFile": true,
            "isAnonymousSupport": true,
            "editorDataStorage": "editorDataRedis",
            "editorStatStorage": "",
            "assemblyFormatAsOrigin": true,
            "newFileTemplate" : "../../document-templates/new",
            "documentFormatsFile": "../../document-formats/onlyoffice-docs-formats.json",
            "downloadFileAllowExt": ["pdf", "xlsx"],
            "tokenRequiredParams": true,
            "forceSaveUsingButtonWithoutChanges": false
        }
    }
}

Podrazumevani zahtev

ParametarOpisTipPodrazumevano
Definiše podrazumevane HTTP zaglavlja zahteva.object
Definiše podrazumevano User-Agent zaglavlje zahteva.string"Node.js/6.13"
Definiše podrazumevano Connection zaglavlje zahteva.string"Keep-Alive"
Definiše da li će sertifikati biti verifikovani od strane Document Server-a ili ne.booleantrue

Ovi parametri definišu podrazumevanu konfiguraciju zahteva.

Primer
"services": {
    "CoAuthoring": {
        "requestDefaults": {
            "headers": {
                "User-Agent": "Node.js/6.13",
                "Connection": "Keep-Alive"
            },
            "rejectUnauthorized": true
        }
    }
}

Automatsko sastavljanje

ParametarOpisTipPodrazumevano
Definiše da li je automatsko prisilno čuvanje omogućeno ili ne.booleanfalse
Definiše interval vremena u minutima za pokretanje automatskog prisilnog čuvanja.string"5m"
Definiše kašnjenje u minutima između intervala.string"1m"

Ovi parametri definišu konfiguraciju automatskog forcesaving.

Automatsko forcesaving će biti pokrenuto samo nakon što su napravljene neke izmene u dokumentu. Prazne verzije neće biti automatski sačuvane. Pored toga, verzionisanje fajlova mora biti implementirano na strani sistema za upravljanje dokumentima kako bi ovaj parametar funkcionisao.
Primer
"services": {
    "CoAuthoring": {
        "autoAssembly": {
            "enable": false,
            "interval": "5m",
            "step": "1m"
        }
    }
}

Utils

ParametarOpisTipPodrazumevano
Definiše direktorijum gde su svi fontovi sačuvani.string"null"
Definiše obrasce za pretragu font fajlova odgovarajućih ekstenzija.string"*.ttf;*.ttc;*.otf"
Definiše podržane formate slika za učitavanje.string"jpg;jpeg;jpe;png;gif;bmp;svg;tiff;tif"

Ovi parametri definišu konfiguraciju utils-a.

Primer
"services": {
    "CoAuthoring": {
        "utils": {
            "utils_common_fontdir": "null",
            "utils_fonts_search_patterns": "*.ttf;*.ttc;*.otf",
            "limits_image_types_upload": "jpg;jpeg;jpe;png;gif;bmp;svg;tiff;tif"
        }
    }
}

SQL

ParametarOpisTipPodrazumevano
Definiše tip baze podataka (mysql, mariadb, mssql, postgres, dameng, oracle).string"postgres"
Definiše ime tabele baze podataka gde su sve izmene dokumenta sačuvane.string"doc_changes"
Definiše ime tabele baze podataka gde je rezultat upita sačuvan.string"task_result"
Definiše host servera baze podataka (ime hosta ili IP adresa).string"localhost"
Definiše port servera baze podataka.integer5432
Definiše ime baze podataka koje će biti kreirano pri pokretanju slike.string"onlyoffice"
Definiše novo korisničko ime sa superuser dozvolama za nalog baze podataka.string"onlyoffice"
Definiše lozinku postavljenu za nalog baze podataka.string"onlyoffice"
Definiše charset baze podataka.string"utf8"
Definiše maksimalan broj istovremenih korisničkih konekcija na server baze podataka.integer10
Definiše maksimalnu veličinu podataka koja može biti poslata u jednom zahtevu.integer1048575
Definiše parametre koji mogu biti prosleđeni direktno u node-postgres pool biblioteku.object
Definiše broj milisekundi koliko klijent mora ostati neaktivan u pool-u i ne biti preuzet pre nego što bude diskonektovan sa backend-a i odbačen. Postavite na 0 da onemogućite automatsko diskonektovanje neaktivnih klijenata.integer30000
Definiše broj sekundi koji predstavlja maksimalno trajanje.integer60000
Definiše broj milisekundi pre nego što upit istekne.integer60000
Definiše broj milisekundi pre nego što poziv upita istekne.integer60000
Definiše broj milisekundi za čekanje na konekciju.integer60000
Definiše parametre Dameng baze podataka.object
Definiše da li su imena kolona velika slova ili ne.booleanfalse
Definiše slučaj imena kolona.string"lower"
Definiše broj milisekundi čekanja na uspostavljanje veze.integer60000
Definiše da li je enkripcija prilikom prijave omogućena ili ne.booleanfalse
Definiše lokalnu vremensku zonu.integer0
Definiše broj sekundi nakon kojih se prekidaju neaktivne veze u bazenu (neiskorišćene u bazenu).integer60
Definiše broj milisekundi kada zahtev za vezu od strane klijenta ili servera ne dobija odgovor sa druge strane.integer60000
Definiše broj milisekundi koliko se poruke zadržavaju u redu pre nego što budu odbačene.integer60000
Definiše parametre Oracle baze podataka.object
Definiše povezivanje sa Oracle u Thick modu koristeći Oracle Instant Client u klasteru.booleantrue
Definiše broj sekundi čekanja na uspostavljanje veze.integer60
Definiše parametre MS SQL baze podataka.object
Definiše opcije MS SQL baze podataka.object
Definiše da li će podaci biti enkriptovani pre slanja preko mreže.booleanfalse
Definiše da li dolazi do enkripcije kada ne postoji verifikovani sertifikat servera.booleantrue
Definiše parametre bazena konekcija.object
Definiše broj milisekundi koliko klijent mora ostati neaktivan u bazenu i ne biti povučen pre nego što se isključi sa pozadinskog sistema i odbaci. Postavite na 0 da onemogućite automatsko isključivanje neaktivnih klijenata.integer30000
Definiše parametre konekcije MySQL baze podataka (uključujući SSL postavke) koji se mogu direktno proslediti node-mysql2 modulu.object
Definiše broj milisekundi čekanja na uspostavljanje veze.integer60000
Definiše broj milisekundi pre nego što upit istekne.integer60000

Ovi parametri definišu konfiguraciju baze podataka.

Primer
"services": {
    "CoAuthoring": {
        "sql": {
            "type": "postgres",
            "tableChanges": "doc_changes",
            "tableResult": "task_result",
            "dbHost": "localhost",
            "dbPort": 5432,
            "dbName": "onlyoffice",
            "dbUser": "onlyoffice",
            "dbPass": "onlyoffice",
            "charset": "utf8",
            "connectionlimit": 10,
            "max_allowed_packet": 1048575,
                "pgPoolExtraOptions": {
                "idleTimeoutMillis": 30000,
                "maxLifetimeSeconds": 60000,
                "statement_timeout": 60000,
                "query_timeout": 60000,
                "connectionTimeoutMillis": 60000
            },
            "damengExtraOptions": {
                "columnNameUpperCase": false,
                "columnNameCase": "lower",
                "connectTimeout": 60000,
                "loginEncrypt": false,
                "localTimezone": 0,
                "poolTimeout": 60,
                "socketTimeout": 60000,
                "queueTimeout": 60000
            },
            "oracleExtraOptions": {
                "thin": true,
                "connectTimeout": 60
            },
            "msSqlExtraOptions": {
                "options": {
                    "encrypt": false,
                    "trustServerCertificate": true
                },
                "pool": {
                    "idleTimeoutMillis": 30000
                }
            },
            "mysqlExtraOptions": {
                "connectTimeout": 60000,
                "queryTimeout": 60000
            }
        }
    }
}

Redis

ParametarOpisTipPodrazumevano
Definiše naziv baze podataka, "redis" ili "ioredis".string"redis"
Definiše prefiks naziva za sve korišćene strukture u Redis-u.string"ds:"
Definiše host Redis servera (naziv hosta ili IP adresa).string"127.0.0.1"
Definiše port Redis servera.integer6379
Definiše parametre (korisničko ime, lozinka, moduli itd.) koji se mogu direktno proslediti node-redis createClient biblioteci.objekat{}
Definiše parametre (rootNodes, defaults, modules itd.) koji se mogu direktno proslediti biblioteci node-redis clustering za povezivanje sa redis klasterom. Ovo podešavanje ima prioritet nad parametrom options za povezivanje sa pojedinačnim redisom. objekat{}
Definiše parametre (korisničko ime, lozinka, moduli itd.) koji se mogu direktno proslediti biblioteci ioredis RedisOptions.objekat
Definiše da li će povezivanje sa serverom biti odloženo dok se ne pošalje prva komanda ili se eksplicitno ne pozove redis.connect().booleantrue
Definiše listu čvorova klastera sa kojima želite da se povežete i koji se mogu direktno proslediti biblioteci ioredis cluster za povezivanje sa redis klasterom. Ovo podešavanje ima prioritet nad parametrom iooptions za povezivanje sa pojedinačnim redisom. niz[]
Definiše parametre (clusterRetryStrategy, dnsLookup, scaleReads itd.) koji se mogu direktno proslediti biblioteci ioredis cluster za povezivanje sa redis klasterom. Ovo podešavanje ima prioritet nad parametrom iooptions za povezivanje sa pojedinačnim redisom. objekat
Definiše da li će povezivanje sa serverom biti odloženo dok se ne pošalje prva komanda ili se eksplicitno ne pozove redis.connect().booleantrue

Ovi parametri definišu Redis konfiguraciju.

Primer
"services": {
    "CoAuthoring": {
        "redis": {
            "name": "redis",
            "prefix": "ds:",
            "host": "127.0.0.1",
            "port": 6379,
            "options": {},
            "optionsCluster": {},
            "iooptions": {
                "lazyConnect": true
            },
            "iooptionsClusterNodes": [],
            "iooptionsClusterOptions": {
                "lazyConnect": true
            }
        }
    }
}

PubSub servis

ParametarOpisTipPodrazumevano
Definiše maksimalnu veličinu promena koje se mogu preneti putem PubSub-a. Ako veličina premašuje navedenu vrednost, promene će se čitati iz baze podataka.celo1000

Ovaj parametar definiše konfiguraciju PubSub servisa.

Primer
"services": {
    "CoAuthoring": {
        "pubsub": {
            "maxChanges": 1000
        }
    }
}

Isticanje

ParametarOpisTipPodrazumevano
Definiše vreme za čuvanje zaključavanja.celo60
Definiše vreme trajanja statusa prisutnosti korisnika.celo300
Definiše vreme trajanja zaključavanja.celo604800
Definiše vreme za promenu indeksa.celo86400
Definiše vreme za zaključavanje dokumenata.celo30
Definiše vreme trajanja poruka.celo86400
Definiše vreme trajanja poslednjeg uspešnog čuvanja baze podataka.celo604800
Definiše vreme trajanja uspešnog forsiranog čuvanja.celo604800
Definiše vreme trajanja forsiranih zaključavanja u ioredis klaster modu.celo5000
Definiše vreme trajanja uspešnog čuvanja baze podataka.celo3600
Definiše vreme za početak provere, tokom koje se stari fajlovi brišu iz keša (podrazumevano svaka dva minuta).string"0 */2 * * * *"
Definiše vreme trajanja foldera u App_Data.celo86400
Definiše vreme za početak provere (podrazumevano svaki sat).string"00 00 */1 * * *"
Definiše broj foldera dokumenata koji se istovremeno brišu iz keša.celo100

Definiše trajanje neaktivne sesije. Ovaj parametar omogućava završetak sesije uređivanja za korisnika koji je u stanju mirovanja. Takođe se koristi za pokretanje procedure čuvanja dokumenta prekidom poslednje sesije uređivanja. Dakle, definiše vreme nakon kojeg će neaktivan korisnik biti isključen iz sesije uređivanja. Format vrednosti je "1s", "1m", "1h", "1d" itd.

Imajte na umu da pod neaktivnošću podrazumevamo odsustvo bilo kakve akcije u uređivaču, uključujući pomeranje kursora.
string"1h"
Definiše trajanje bilo koje sesije uređivanja.string"30d"
Definiše vreme pre nego što sessionidle ili sessionabsolute ttl istekne kada se šalje poruka upozorenja.string"2m"
Definiše vreme trajanja za PEM fajlove sa tajnama.string"1h"
Definiše vreme za proveru ttl PEM fajlova.string"10m"
Definiše vreme kada korisnik može ponovo otvoriti fajl nakon što dođe do greške zbog otvaranja već sačuvanog fajla koristeći stari ključ.string"5m"
Definiše vreme trajanja za listu mesečnih jedinstvenih korisnika.string"1y"

Ovi parametri definišu postavke isteka.

Primer
"services": {
"CoAuthoring": {
    "expire": {
        "saveLock": 60,
        "presence": 300,
        "locks": 604800,
        "changeindex": 86400,
        "lockDoc": 30,
        "message": 86400,
        "lastsave": 604800,
        "forcesave": 604800,
        "forcesaveLock": 5000,
        "saved": 3600,
        "documentsCron": "0 */2 * * * *",
        "files": 86400,
        "filesCron": "00 00 */1 * * *",
        "filesremovedatonce": 100,
        "sessionidle": "1h",
        "sessionabsolute": "30d",
        "sessionclosecommand": "2m",
        "pemStdTTL": "1h",
        "pemCheckPeriod": "10m",
        "updateVersionStatus": "5m",
        "monthUniqueUsers": "1y"
    }
}
}

IP filter

ParametarOpisTipPodrazumevano

Definiše pravila IP filtera koja sadrže sledeće parametre:

  • adresa - IP adresa integratora. Ovaj parametar može sadržati IP u formatu X.X.X.X za ipv4 ili u formatu xxxx.xxxx.xxxx.xxxx.xxxx.xxxx.xxxx.xxxx za ipv6, dns-ime ili * džoker znak za zamenu bilo kog simbola/simbola,
    tip: string,
    primer: "ip_adresa";
  • dozvoljeno - određuje da li je IP adresa pouzdana ili ne,
    tip: boolean,
    primer: true.
niz objekata
Definiše da li se IP filter koristi za zahtev ili ne.booleanfalse
Definiše kod greške za IP filter.integer403

Ovi parametri definišu konfiguraciju IP filtera.

Primer
"services": {
"CoAuthoring": {
    "ipfilter": {
        "rules": [{"address": "*", "allowed": true}],
        "useforrequest": false,
        "errorcode": 403
    }
}
}

Agent za filtriranje zahteva

ParametarOpisTipPodrazumevano
Definiše da li je dozvoljeno povezivanje privatne IP adrese ili ne. Ovo uključuje privatne IP adrese i rezervisane IP adrese.booleanfalse
Definiše da li je dozvoljeno povezivanje meta IP adrese ili ne. Meta adresa može biti 0.0.0.0 (IPv4) ili :: (IPv6) - meta adresa koja rutira drugu adresu.booleanfalse

Ovi parametri definišu konfiguraciju agenta za filtriranje zahteva.

Primer
"services": {
"CoAuthoring": {
    "request-filtering-agent" : {
        "allowPrivateIPAddress": false,
        "allowMetaIPAddress": false
    }
}
}

Tajni ključ

ParametarOpisTipPodrazumevano

Definiše parametre tajnog ključa za generisanje tokena u zahtevima sa strane klijenta u pregledaču za ONLYOFFICE Docs:

  • string - tajni ključ,
    tip: string,
    primer: "secret";
  • file - PEM fajl u kojem je tajna sačuvana,
    tip: string,
    primer: "".
objekat

Definiše parametre tajnog ključa za generisanje tokena u dolaznim HTTP zahtevima sa komandama iz servisa za skladištenje dokumenata ka servisu za komande dokumenata, servisu za konverziju dokumenata i servisu za izradu dokumenata:

  • string - tajni ključ,
    tip: string,
    primer: "secret";
  • file - PEM fajl u kojem je tajna sačuvana,
    tip: string,
    primer: "".
object

Definiše parametre tajnog ključa za generisanje tokena u odlaznim HTTP zahtevima na adresu callbackUrl od strane servisa za uređivanje dokumenata:

  • string - tajni ključ,
    tip: string,
    primer: "secret";
  • file - PEM fajl u kojem je tajna sačuvana,
    tip: string,
    primer: "".
object

Definiše parametre tajnog ključa za generisanje tokena sesije:

  • string - tajni ključ,
    tip: string,
    primer: "secret";
  • file - PEM fajl u kojem je tajna sačuvana,
    tip: string,
    primer: "".
object

Ovi parametri definišu konfiguraciju tajnog ključa.

Primer
"services": {
    "CoAuthoring": {
        "secret": {
            "browser": {"string": "secret", "file": ""},
            "inbox": {"string": "secret", "file": ""},
            "outbox": {"string": "secret", "file": ""},
            "session": {"string": "secret", "file": ""}
        }
    }
}

Token

ParametarOpisTipPodrazumevano
Definiše da li su tokeni omogućeni ili ne.object
Definiše da li je token u zahtevima sa strane klijentskog pretraživača omogućen ili ne.booleanfalse
Definiše da li su tokeni u HTTP zahtevima omogućeni ili ne.object
Definiše da li je token u dolaznim HTTP zahtevima omogućen ili ne.booleanfalse
Definiše da li je token u odlaznim HTTP zahtevima omogućen ili ne.booleanfalse
Definiše konfiguraciju tokena pretraživača.object
Definiše da li je token pretraživača jednak tokenu iz dolaznih zahteva (true) ili ne (false).booleantrue
Definiše konfiguraciju tokena iz dolaznih zahteva.object
Definiše HTTP zaglavlje koje će se koristiti za slanje tokena dolaznog zahteva.string"Authorization"
Definiše prefiks u HTTP zaglavlju koji će se koristiti za slanje tokena dolaznog zahteva.string"Bearer "
Definiše da li je token omogućen u telu dolaznog zahteva ili ne.booleanfalse
Definiše konfiguraciju tokena iz odlaznih zahteva.object
Definiše HTTP zaglavlje koje će se koristiti za slanje tokena odlaznog zahteva.string"Authorization"
Definiše prefiks u HTTP zaglavlju koji će se koristiti za slanje tokena odlaznog zahteva.string"Bearer "
Definiše algoritam koji se koristi za potpisivanje tokena odlaznog zahteva.string"HS256"
Definiše period kada token odlaznog zahteva ističe.string"5m"
Definiše da li je token omogućen u telu odlaznog zahteva ili ne.booleanfalse
Definiše regularni izraz koji specificira URL-ove sa kojih autorizacija treba biti isključena. Prazan string znači da je ova opcija onemogućena.string""
Definiše konfiguraciju tokena sesije.object
Definiše algoritam koji se koristi za potpisivanje tokena sesije.string"HS256"
Definiše period kada token sesije ističe.string"30d"
Definiše opcije za verifikaciju tokena.object
Definiše broj sekundi koji je prihvatljiv kada se radi sa razlikama u vremenu među različitim serverima.integer60

Ovi parametri definišu konfiguraciju tokena.

Primer
"services": {
"CoAuthoring": {
    "token": {
        "enable": {
            "browser": false,
            "request": {
                "inbox": false,
                "outbox": false
            }
        },
        "browser": {
            "secretFromInbox": true
        },
        "inbox": {
            "header": "Authorization",
            "prefix": "Bearer ",
            "inBody": false
        },
        "outbox": {
            "header": "Authorization",
            "prefix": "Bearer ",
            "algorithm": "HS256",
            "expires": "5m",
            "inBody": false,
            "urlExclusionRegex": ""
        },
        "session": {
            "algorithm": "HS256",
            "expires": "30d"
        },
        "verifyOptions": {
            "clockTolerance": 60
        }
    }
}
}

Dodaci

ParametarOpisTipPodrazumevano
Definiše putanju do foldera gde su svi dodaci sačuvani.string"/sdkjs-plugins"
Definiše listu dodataka koji se automatski pokreću.list[]

Ovi parametri definišu konfiguraciju dodataka.

Primer
"services": {
"CoAuthoring": {
    "plugins": {
        "uri": "/sdkjs-plugins",
        "autostart": []
    }
}
}

Teme

ParametarOpisTipPodrazumevano
Definiše putanju do foldera gde su sačuvani svi json fajlovi sa prilagođenim temama boja.string"/web-apps/apps/common/main/resources/themes"

Ovaj parametar definiše svojstva prilagođenih tema boja.

Primer
"services": {
"CoAuthoring": {
    "themes": {
        "uri": "/web-apps/apps/common/main/resources/themes"
    }
}
}

Editor

ParametarOpisTipPodrazumevano
Definiše putanju do provere pravopisa.string""
Definiše postavke za ponovno povezivanje editora sa serverom.object
Definiše maksimalan broj pokušaja za ponovno povezivanje editora.integer50
Definiše kašnjenje pokušaja za ponovno povezivanje editora.string"2s"
Definiše da li se promene u dokumentu čuvaju u binarnom (true) ili JSON (false) formatu.booleanfalse
Definiše maksimalnu veličinu payload-a za WebSocket.string"1.5MB"
Definiše ograničenje na ukupnu veličinu promena napravljenih u dokumentu. Kada se prekorači limit, korisnik dobija dijalog sa sugestijom da poništi poslednju akciju ili pređe u offline režim.string"150MB"

Ovi parametri definišu konfiguraciju editora.

Primer
"services": {
"CoAuthoring": {
    "editor":{
        "spellcheckerUrl": "",
        "reconnection":{
            "attempts": 50,
            "delay": "2s"
        },
        "binaryChanges": false,
        "websocketMaxPayloadSize": "1.5MB",
        "maxChangesSize": "150MB"
    }
}
}

SockJs

ParametarOpisTipPodrazumevano
Definiše putanju do sockjs.min.js fajla.string""
Definiše da li će CORS biti onemogućen ili ne. Vrednost true sprečava ranjivost zaglavlja Access-Control-Allow-Origin.booleantrue
Definiše da li je WebSocket protokol omogućen ili ne.booleantrue

Ovi parametri definišu konfiguraciju SockJs.

Primer
"services": {
"CoAuthoring": {
    "sockjs": {
        "sockjs_url": "",
        "disable_cors": true,
        "websocket": true
    }
}
}

Socket.IO

ParametarOpisTipPodrazumevano
Definiše svojstva konekcije.object
Definiše putanju koja se hvata na strani servera.string"/doc/"
Definiše da li će klijentski fajlovi biti posluženi ili ne.booleanfalse
Definiše period tajmauta u milisekundama unutar kojeg klijent mora da odgovori sa pong na server ping. Ako nema odgovora, server smatra da je veza zatvorena. Veza između servera i klijenta se proverava svakih pingInterval milisekundi. integer20000
Definiše interval vremena u milisekundama, koji se koristi za proveru da li je veza između servera i klijenta još uvek aktivna. Server šalje ping paket klijentu, i ako klijent ne odgovori sa pong u okviru pingTimeout perioda, server smatra da je veza zatvorena. integer25000
Definiše maksimalan broj bajtova koje jedna poruka može imati pre nego što se soket zatvori.integer1e8

Ovi parametri definišu konfiguraciju Socket.IO modula.

Primer
"socketio": {
"connection": {
    "path": "/doc/",
    "serveClient": false,
    "pingTimeout": 20000,
    "pingInterval": 25000,
    "maxHttpBufferSize": 1e8
}
}

Opcije povratnog poziva sa odlaganjem

ParametarOpisTipPodrazumevano
Definiše maksimalan broj pokušaja ponavljanja operacije.integer3
Definiše tajmaute povratnog poziva sa odlaganjem.object
Definiše eksponencijalni faktor koji će se koristiti.integer2
Definiše broj milisekundi pre nego što počne prvi pokušaj.integer1000
Definiše maksimalan broj milisekundi između dva pokušaja.integer2147483647
Definiše da li su tajmauti randomizovani množenjem sa faktorom između 1 i 2 ili ne.booleanfalse
Definiše HTTP statuse povratnog poziva sa odlaganjem.string"429,500-599"

Ovi parametri definišu opcije povratnog poziva sa odlaganjem.

Primer
"services": {
"CoAuthoring": {
    "callbackBackoffOptions": {
        "retries": 3,
        "timeout":{
            "factor": 2,
            "minTimeout": 1000,
            "maxTimeout": 2147483647,
            "randomize": false
        },
        "httpStatus": "429,500-599"
    }
}
}

Licenca

ParametarOpisTipPodrazumevano
Definiše putanju do fajla sa licencom.string""
Definiše procenat opsega ograničenja konekcija i konekcija_view čije prekoračenje izaziva pojavu upozorenja o ograničenju licence u logovima. integer70

Definiše tip paketa licence: 2 - Developer Edition.

Ovaj parametar se postavlja prilikom izrade verzije. Ne morate ga ručno konfigurisati.
integer2
Definiše vreme pre isteka licence kada se šalje upozorenje.string"30d"

Ovi parametri definišu konfiguraciju licence.

Primer
"license" : {
"license_file": "",
"warning_limit_percents": 70,
"packageType": 2,
"warning_license_expiration": "30d"
}

Konverter

ParametarOpisTipPodrazumevano
Definiše svojstva konvertera.object
Definiše maksimalnu veličinu fajla koji se zahteva (mereno u bajtovima).integer104857600
Definiše svojstva tajmauta za preuzimanje konvertovanog fajla.object

Definiše period koji specificira dva tajmauta:

  • tajmaut čitanja - vreme čekanja da server pošalje zaglavlja odgovora (i započne telo odgovora) pre nego što se zahtev prekine;
  • vreme čekanja za povezivanje - postavlja vreme čekanja za soket nakon neaktivnosti. Imajte na umu da povećanje vremena čekanja iznad OS-širokog TCP vremena čekanja veze neće imati efekta.

Ovaj parametar se šalje npm modulu.

string"2m"
Definiše vreme čekanja za ceo ciklus zahteva.string"2m"
Definiše maksimalan broj pokušaja preuzimanja konvertovanog fajla.integer3
Definiše kašnjenje između pokušaja preuzimanja konvertovanog fajla.integer1000
Definiše maksimalan broj procesa konverzije koji mogu biti aktivni u isto vreme.integer1
Definiše putanju do foldera sa fontovima.string"null"
Definiše putanju do foldera sa temama za prezentacije.string"null"
Definiše putanju do x2t konvertora fajlova.string"null"
Definiše putanju do aplikacije Document Builder.string"null"
Definiše putanju do sertifikata za potpisivanje PDF-a. Ovaj sertifikat može biti otpremljen u Admin Panel i korišćen za potpisivanje PDF obrazaca tokom Complete i Submit.string""
Definiše dodatne parametre za pokretanje x2t.string""
Definiše parametre koji mogu biti direktno prosleđeni node.js child_process.spawn biblioteci (samo za pokretanje x2t).object{}
Definiše putanju do fajlova sa greškama.string""
Definiše veličinu bafera za StreamWriter.integer8388608
Definiše maksimalan broj ponovnih isporuka poruka.integer2
Definiše ograničenja za ulazne fajlove.object
Definiše tipove OOXML fajlova za koje su ograničenja specificirana (tekstualni dokumenti/tabele/prezentacije). Ovo ne uključuje druge objekte, kao što su slike.string"docx;dotx;docm;dotm"/"xlsx;xltx;xlsm;xltm"/"pptx;ppsx;potx;pptm;ppsm;potm"
Definiše svojstva zip arhive.object
Definiše ukupnu veličinu dekompresovanih fajlova za tekstualne dokumente/tabele/prezentacije.string"50MB"/"300MB"/"50MB"
Definiše šablon imena za fajlove čije se veličine računaju.string"*.xml"

Ovi parametri definišu konfiguraciju konvertora fajlova.

Primer
"FileConverter": {
    "converter": {
        "maxDownloadBytes": 104857600,
        "downloadTimeout": {
            "connectionAndInactivity": "2m",
            "wholeCycle": "2m"
        },
        "downloadAttemptMaxCount": 3,
        "downloadAttemptDelay": 1000,
        "maxprocesscount": 1,
        "fontDir": "null",
        "presentationThemesDir": "null",
        "x2tPath": "null",
        "docbuilderPath": "null",
        "signingKeyStorePath": "",
        "args": "",
        "spawnOptions": {},
        "errorfiles": "",
        "streamWriterBufferSize": 8388608,
        "maxRedeliveredCount": 2,
        "inputLimits": [
            {
            "type": "docx;dotx;docm;dotm",
            "zip": {
                "uncompressed": "50MB",
                "template": "*.xml"
            }
            },
            {
            "type": "xlsx;xltx;xlsm;xltm",
            "zip": {
                "uncompressed": "300MB",
                "template": "*.xml"
            }
            },
            {
            "type": "pptx;ppsx;potx;pptm;ppsm;potm",
            "zip": {
                "uncompressed": "50MB",
                "template": "*.xml"
            }
            }
        ]
    }
}
Članak sa oznaka:
Pregledajte sve oznake