Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Document HTTP API #1

Open
ferronrsmith opened this issue Aug 31, 2017 · 26 comments
Open

Document HTTP API #1

ferronrsmith opened this issue Aug 31, 2017 · 26 comments

Comments

@ferronrsmith
Copy link

The Web API is nice. It would help if this was documented so that it can be integrated into other systems. I have a distributed FS and use filemanager has the front-end for all of this.

When a user is created in our system we create one in filemanager user with a scope. So that it acts like a multi-tenant system. It's beautiful. We had to read through the web app to + code find endpoints.

Should have been documented.

@hacdias
Copy link
Member

hacdias commented Aug 31, 2017

😮 Yes, I have to write the docs for the web API. There was someone else who asked me the same too.

@hacdias hacdias transferred this issue from filebrowser/filebrowser Jan 6, 2019
@hacdias hacdias changed the title Document Filemanager API Document HTTP API Jan 6, 2019
@singlaive
Copy link

It is 2020, please where is the doc?

@Alsan
Copy link

Alsan commented Sep 26, 2020

+1 for such doc.

@skaravad
Copy link

skaravad commented Aug 9, 2021

I'm not quite sure if anyone is already using API's , I tracked the API calls from chrome for few POST calls like create user, the tricky part was to get the auth cookie , once you have it you can just wire your own python/curl etc.

Get Auth Cookie:

cookie=`curl -Ss localhost:8001/api/login --data-raw '{"username":"admin","password":"admin"}'`
echo "Cookie: auth=$cookie" > /tmp/cookie
curl -H "$(cat /tmp/cookie)"  localhost:8001/api/users --data-raw '{"what":"user","which":[],"data":{"scope":".","hideDotfiles":true,"username":"testUser","password":"PASSWORD"}}'

@mckaygerhard
Copy link

i already have half documented the api by reverse way of interaction.. but i still waithing to the current merge request will be done @on4r thanks in advance

@gaby
Copy link

gaby commented May 11, 2023

6 years later, still no docs. Is there some tool to auto-generate these?

@mckaygerhard
Copy link

@gaby the problem is the autor itselft.. it seems do not care about that

@RiverChu0
Copy link

2000 years later...

@icheered
Copy link

Is there already an update on the documentation? With a bunch of trial and error I managed to obtain the JWT token, but using it to authenticate has so far been impossible. This is the simple node script I wrote to try and download a testfile:

import axios from 'axios';
import fs from 'fs';

async function getToken() {
	const response = await axios.post('http://localhost:8080/api/login', {
		username: 'MY_USERNAME',
		password: 'MY_PASSWORD'
	});
	return response.data;
}

async function downloadFile(token) {
	const url = 'http://localhost:8080/api/resources/test';

	const response = await axios({
		method: 'GET',
		url: url,
		responseType: 'stream',
		headers: {
			Authorization: `Bearer ${token}`
		}
	});

	const writer = fs.createWriteStream('DownloadedTextFile.txt');

	response.data.pipe(writer);

	return new Promise((resolve, reject) => {
		writer.on('finish', resolve);
		writer.on('error', reject);
	});
}

async function main() {
	const token = await getToken();
	console.log('Token: ' + token);
	if (token) {
		await downloadFile(token);
	} else {
		console.log('No token. Aborting.');
	}
}

main().catch((e) => {
	console.error('Error: ', e);
});

This obtains a token, but when downloading the file using the token I get a '401 unauthorized' error.

@mckaygerhard
Copy link

@icheered i am thinking of possible cuases:

there is another way apart of const writer = fs.createWriteStream('DownloadedTextFile.txt'); ? cos is currently async ?

i dont know i am not expert in promise

@icheered
Copy link

I figured it out after a while, but it turns out you don't use Authorization: Bearer <token> like literally any other API out there, but you use 'X-Auth' header field to carry the JWT... I just wrote a short example on uploading and downloading files using the API using Node over here: filebrowser/filebrowser#2551 (this docs repo seems pretty dead...)

@mckaygerhard
Copy link

I just wrote a short example on uploading and downloading files using the API using Node over here: filebrowser/filebrowser#2551 (this docs repo seems pretty dead...)

yeah.. unfortunatelly .. many times i proposed forked the project but we need at least 2 mantainers for filebrowser and 1 for docs

@o1egl
Copy link
Member

o1egl commented Jul 24, 2023

It is an open source project. Any help in appreciated. You can help the community by writing API docs and opening a PR.

@mckaygerhard
Copy link

@o1egl thanks for response, finally you revive, we already provide some contributed parts..

@laker-93
Copy link

curl -H "$(cat /tmp/cookie)" localhost:8001/api/users --data-raw '{"what":"user","which":[],"data":{"scope":".","hideDotfiles":true,"username":"testUser","password":"PASSWORD"}}'

This gives me a 401 unauthorized despite having a cookie that was created from an admin account. Do you have an up to date example of how to add a user with a HTTP request?

@data3000sas
Copy link

data3000sas commented Nov 8, 2023

como puedo usar el token para loguearme automáticamente en filebrowser, esto es lo que tengo con php:

$data = array(
'username' => 'admin',
'password' => 'admin'
);
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, "https://prueba/api/login");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($data));
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/json'));
$token = curl_exec($ch);
curl_close($ch);

@svlassov
Copy link

curl -H "$(cat /tmp/cookie)" localhost:8001/api/users --data-raw '{"what":"user","which":[],"data":{"scope":".","hideDotfiles":true,"username":"testUser","password":"PASSWORD"}}'

This gives me a 401 unauthorized despite having a cookie that was created from an admin account. Do you have an up to date example of how to add a user with a HTTP request?

You should change:
echo "Cookie: auth=$cookie" > /tmp/cookie
to
echo "X-Auth:$cookie" > /tmp/cookie
I tested this in a bash script, it might be useful:

#!/usr/bin/env bash
#
#
#
API_URL="http://10.174.18.254:9607/api"
API_USER="admin"
API_PASSWORD="Adminaxitech!"
API_TMP_URI="/Users/svyatvlasso/Projects/Workflow/filebrowser/api/tmp/token_x_auth_heder"
#
#
#

# // retrieving token
#
echo -e date +"%Y-%m-%d %T"" [DEBUG] start retrieving token"

COOKIE_REQUEST_BODY=`echo "{\"username\":\"${API_USER}\",\"password\":\"${API_PASSWORD}\"}"`
echo -e date +"%Y-%m-%d %T"[DEBUG] "token request body contains: ${COOKIE_REQUEST_BODY}"
API_TOKEN=`curl -Ss ${API_URL}/login --data-raw "${COOKIE_REQUEST_BODY}"`
echo -e date +"%Y-%m-%d %T"" [DEBUG] token retrieved"
echo -e date +"%Y-%m-%d %T"" [TRACE] token is ${API_TOKEN}"

echo -e date +"%Y-%m-%d %T"" [DEBUG] saving token as X-Auth header"
echo "X-Auth:${API_TOKEN}" > "${API_TMP_URI}"
echo -e date +"%Y-%m-%d %T"" [DEBUG] token saved to ${API_TMP_URI}"

# // create new user
#
NEW_USER_USERNAME="testuser"
NEW_USER_PASSWORD="0000"
NEW_USER_HIDE_DOT_FILES="true"
NEW_USER_SCOPE="."
echo -e date +"%Y-%m-%d %T"" [DEBUG] create user with USERNAME -> ${NEW_USER_USERNAME} ; PASSWORD -> ${NEW_USER_PASSWORD} ; HIDE_DOT_FILES -> ${NEW_USER_HIDE_DOT_FILES} ; SCOPE -> ${NEW_USER_SCOPE}"

REQUEST_BODY=`echo "{\"what\":\"user\",\"which\":[],\"data\":{\"scope\":\"${NEW_USER_SCOPE}\",\"hideDotfiles\":${NEW_USER_HIDE_DOT_FILES},\"username\":\"${NEW_USER_USERNAME}\",\"password\":\"${NEW_USER_PASSWORD}\"}}"`

echo -e date +"%Y-%m-%d %T"" [DEBUG] request cookie is: $(cat ${API_TMP_URI})"
echo -e date +"%Y-%m-%d %T"" [DEBUG] request body is: ${REQUEST_BODY}"

curl -H "$(cat ${API_TMP_URI})"  ${API_URL}/users --data-raw "${REQUEST_BODY}"
OPERATION_EXIT_CODE=$?
if [ "${OPERATION_EXIT_CODE}" != "0" ]; then
  echo -e date +"%Y-%m-%d %T"" [DEBUG] can't create user, exit ${OPERATION_EXIT_CODE}"
  exit ${OPERATION_EXIT_CODE}
fi

echo -e date +"%Y-%m-%d %T"" [DEBUG] create user done"

@AlexFlash27
Copy link

How to automatically log in to file browser after receiving a token? I have this now:

        $url = "http://192.168.1.134:8084/api/login";

        $curl = curl_init($url);
        curl_setopt($curl, CURLOPT_URL, $url);
        curl_setopt($curl, CURLOPT_POST, true);
        curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);

        $headers = array(
           "Content-Type: application/json",
        );
        curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);

        $data = <<<DATA
        {"username": "1303", "password": "1303", "recaptcha": ""}

        DATA;

        curl_setopt($curl, CURLOPT_POSTFIELDS, $data);

        $token = curl_exec($curl);
        curl_close($curl);

@icheered
Copy link

Check filebrowser/filebrowser#2551.
Long story short: You put the token in the X-Auth header field instead of the standard Authorization: Bearer <token> field

@AlexFlash27
Copy link

Check filebrowser/filebrowser#2551. Long story short: You put the token in the X-Auth header field instead of the standard Authorization: Bearer <token> field

I know about it. But how to redirect to http://localhost:8084/files/ page already signed-in with the provided credentials and recieved token? Basically i want to have a link that automatically sign-in user.

@vinhnemo
Copy link

Still no docs for APIs lol

@laker-93
Copy link

laker-93 commented Aug 5, 2024

Anyone know what APIs I could use to upload files to filebrowser? I essentially want to do the equivalent of dragging and dropping some files in to the filebrowser UI but with HTTP APIs. Something like:

/upload and then in the body specify the path of the files I want to upload on my local machine.

@laker-93
Copy link

laker-93 commented Aug 5, 2024

Anyone know what APIs I could use to upload files to filebrowser? I essentially want to do the equivalent of dragging and dropping some files in to the filebrowser UI but with HTTP APIs. Something like:

/upload and then in the body specify the path of the files I want to upload on my local machine.

Just this sample script which solves my use case nicely. Thanks. filebrowser/filebrowser#2551

@maxron84
Copy link

maxron84 commented Nov 20, 2024

Hello. I do not understand what is the problem for the devs to document their own REST API endpoints, when the frontend is obviously using the endpoints already. Find here listed the endpoints that are needed in my use case:

FB: Get Token
curl --request POST
--url http://localhost:8080/api/login
--header 'Content-Type: application/json'
--header 'User-Agent: insomnia/10.0.0'
--data '{
"username": "admin",
"password": "admin"
}'

FB: List Entities in Folder
curl --request GET
--url http://localhost:8080/api/resources/somefolder
--header 'X-Auth: Returned-API-Key'
--header 'User-Agent: insomnia/10.0.0'

FB: Create Entity by Path
curl --request POST
--url http://localhost:8080/api/resources/somefolder/sometext.txt
--header 'X-Auth: Returned-API-Key'
--header 'Content-Type: text/plain'
--header 'User-Agent: insomnia/10.0.0'
--data SGVsbG8gV29ybGQhCg==

FB: Remove Entity by Path
curl --request DELETE
--url http://localhost:8080/api/resources/somefolder/sometext.txt
--header 'X-Auth: Returned-API-Key'
--header 'User-Agent: insomnia/10.0.0'

FB: Rename Entity by Query
curl --request PATCH
--url 'http://localhost:8080/api/resources/somefolder/sometext.txt?action=rename&destination=%2Fsomefolder%2Frenamedtext.txt&override=false&rename=false'
--header 'X-Auth: Returned-API-Key'
--header 'User-Agent: insomnia/10.0.0'

FB: Get Raw File
curl --request GET
--url http://localhost:8080/api/raw/somefolder/sometext.txt
--header 'X-Auth: Returned-API-Key'
--header 'User-Agent: insomnia/10.0.0'

FB: Get n Entities by Properties
curl --request GET
--url 'http://localhost:8080/api/search/?query=somefile'
--header 'X-Auth: Returned-API-Key'
--header 'User-Agent: insomnia/10.0.0'
FURTHER INFO:
E.G. Get by type image AND the name: http://localhost:8080/api/search/?query=type%3Aimage%20somefile
Or by type audio: http://localhost:8080/api/search/?query=type%3Aaudio%20
Or by parts of the name to filter more wide: http://localhost:8080/api/search/?query=some
...etc

These are tested and work well in the endpoint testing application called insomnia in Zorin OS.

@wingjson
Copy link

2000years later

@l1ghtn1ng-sec
Copy link

need restful api document

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests