CMS365.FacebookSharp
6.17.7
See the version list below for details.
dotnet add package CMS365.FacebookSharp --version 6.17.7
NuGet\Install-Package CMS365.FacebookSharp -Version 6.17.7
<PackageReference Include="CMS365.FacebookSharp" Version="6.17.7" />
paket add CMS365.FacebookSharp --version 6.17.7
#r "nuget: CMS365.FacebookSharp, 6.17.7"
// Install CMS365.FacebookSharp as a Cake Addin #addin nuget:?package=CMS365.FacebookSharp&version=6.17.7 // Install CMS365.FacebookSharp as a Cake Tool #tool nuget:?package=CMS365.FacebookSharp&version=6.17.7
FacebookSharp: A .NET library for Facebook Graph API.
FacebookSharp is a .NET library that enables you to authenticate and make graph API calls to Facebook. It's used for posting feeds and contents on Facebook using C# and .NET
Installation
FacebookSharp is available on NuGet. Use the package manager console in Visual Studio to install it:
Install-Package CMS365.FacebookSharp
API support
FacebookSharp version | Facebook Graph API version | Build versions |
---|---|---|
6 | 17 | x |
FacebookSharp currently supports the following Facebook Graph APIs:
- Getting started
- Access and Security
- Using the FacebookSharp
Creating an App
Please visit https://developers.facebook.com/apps and create an app.
Access and Security
Please visit https://developers.facebook.com/tools/explorer/ and generate a user token.
You can adjust permissions based on your needs. This is a short lived token and can be used for Facebook Graph api for user level operations. We will use it to generate a long live user token.
User postman and send a request to the following endpoint and get a long lived user token.
https://graph.facebook.com/oauth/access_token?grant_type=fb_exchange_token&client_id=APP_CLIENT_ID&client_secret=APP_CLIENT_SECRET&fb_exchange_token=YOUR_SHORT_LIVED_USER_TOKEN_HERE
You will get a response like
{
"access_token": "vMF7UXNvRZC6m58zr0tRQJP3MVCZBd6JDhHkyCXjWcfag8hfcmjImn85B2YPZAUYK4eirj9ZA0ZAsp1TocZD",
"token_type": "bearer",
"expires_in": 5182228
}
We will get an access_token which is long lived user token and can be used for Facebook Graph api for user level operations but we have to generate a page token so that we can perform action on a Facebook page.
https://graph.facebook.com/FACEBOOK_PAGE_ID?fields=access_token&access_token=LONG_LIVED_USER_TOKEN
{
"access_token": "EAASZAbmgGb7YBAFWM3uNUKan1ZBTf4rIAQiLzPSNMa7Lm3Ak1R8tNAVwsORl0LZAcPNEURzFgl6",
"id": "111444904022049"
}
We have now got a page token which we will use to perform actions on a Facebook page.
Using the FacebookSharp
Initialize the instance with the page token
var facebookController = new FacebookSharp.FacebookController("EAASZAbmgGb7YBAFWM3uNUKan1ZBTf4rIAQiLzPSNMa7Lm3Ak1R8tNAVwsORl0LZAcPNEURzFgl6");
Page
Get page details
PageInfo pageInfo = await facebookController.GetPageDetailsAsync("[PAGE_ID]");
Post with multiline text and images
CreateFeedResponse feedWithImages = await facebookController.PostPageFeedAsync("[PAGE_ID]", new FacebookSharp.Entities.Page.PageFeedRequestContent()
{
MessageLines = new List<string>() { "I am a test message", "I am on next line", "https://google.com" },
PhotoUrls = new List<string>() { "https://google.com/34f4ea06a374b216cb1c778a0d1810c6_480x.jpg?v=1684836648" }
});
Post with multiline text and a link
CreateFeedResponse feedWithLink = await facebookController.PostPageFeedAsync("[PAGE_ID]",new List<string>()
{
"I am a test message", "I am on next line", "I am a third line", "I am a fourth line"
},
"https://google.com");
Get page albums
var pageAlbums = await facebookController.GetPageAlbumsAsync("[PAGE_ID]", string fields = "");
Get page albums
Returns most recent 25 conversations. List of fields is available at https://developers.facebook.com/tools/explorer/1294599377547190/?method=GET&path=me%2Fconversations
var pageConversations = await facebookController.GetPageConversations("[PAGE_ID]", string fields = "");
General Graph API methods
You can call direct graph API method If there is no mapping available. For example
Get
var info = await facebookController.Get("/[apge_id]?fields=name,about,link,cover");
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
-
net6.0
- Newtonsoft.Json (>= 13.0.3)
- RestSharp (>= 110.2.0)
-
net7.0
- Newtonsoft.Json (>= 13.0.3)
- RestSharp (>= 110.2.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.