TurnitinCoreApi - JavaScript client for turnitin_core_api Turnitin Core API (TCA) provides direct API access to the core functionality provided by Turnitin. TCA supports file submission, similarity report generation, group management, and visualization of report matches via Cloud Viewer or PDF download. Below is the full flow to successfully set up an integration scope, an API Key, and make calls to TCA. Integration Scope and API Key management is done via the Admin Console UI by logging in as an admin user. For more details, go to our developer portal documentation page.
TCA API calls must provide an API Key for authentication, so you must first have at least one integration scope associated with at least one API Key to use TCA.
First, login to Admin Console UI as an Admin user with permission to create Integration Scopes, under a tenant that is licensed to use the TCA product Integration Scopes (you can create a new one, or add keys to existing)
- Click
Integrations
in the side bar -->+ Add Integration
at top the top of the page --> Enter a name -->Add
Button API Keys - Click
Integrations
in the side bar -->Create API Key
Button next to a given Integration Scope --> Enter a name --> clickCreate and View button
- Copy/Save the key manually or click save to clipboard button to copy it (this is the only time it will show)
- Register a webhook
- Create a submission
- Upload a file for the submission
- Wait for the submission upload to process
- If you registered a webhook, a callback will be sent to it when upload is complete
- The status of the submission will also update to
COMPLETE
- Request a Similarity Report
- Wait for similarity report to process
- If you registered a webhook, a callback will be sent to it when report is complete
- The status of the report will also be updated to
COMPLETE
- Request a URL with parameters to view the Similarity Report
This SDK is automatically generated by the OpenAPI Generator project:
- API version: 1.0.258
- Package version: 1.0.258
- Build package: org.openapitools.codegen.languages.JavascriptClientCodegen
For Node.js
To publish the library as a npm, please follow the procedure in "Publishing npm packages".
Then install it via:
npm install turnitin_core_api --save
Finally, you need to build the module:
npm run build
To use the library locally without publishing to a remote npm registry, first install the dependencies by changing into the directory containing package.json
(and this README). Let's call this JAVASCRIPT_CLIENT_DIR
. Then run:
npm install
Next, link it globally in npm with the following, also from JAVASCRIPT_CLIENT_DIR
:
npm link
To use the link you just defined in your project, switch to the directory you want to use your turnitin_core_api from, and run:
npm link /path/to/<JAVASCRIPT_CLIENT_DIR>
Finally, you need to build the module:
npm run build
If the library is hosted at a git repository, e.g./~https://github.com/GIT_USER_ID/GIT_REPO_ID then install it via:
npm install GIT_USER_ID/GIT_REPO_ID --save
The library also works in the browser environment via npm and browserify. After following
the above steps with Node.js and installing browserify with npm install -g browserify
,
perform the following (assuming main.js is your entry file):
browserify main.js > bundle.js
Then include bundle.js in the HTML pages.
Using Webpack you may encounter the following error: "Module not found: Error: Cannot resolve module", most certainly you should disable AMD loader. Add/merge the following section to your webpack config:
module: {
rules: [
{
parser: {
amd: false
}
}
]
}
Please follow the installation instruction and execute the following JS code:
var TurnitinCoreApi = require('turnitin_core_api');
var defaultClient = TurnitinCoreApi.ApiClient.instance;
// Configure API key authorization: api_key
var api_key = defaultClient.authentications['api_key'];
api_key.apiKey = "YOUR API KEY"
// Uncomment the following line to set a prefix for the API key, e.g. "Token" (defaults to null)
//api_key.apiKeyPrefix['Authorization'] = "Token"
var api = new TurnitinCoreApi.EULAApi()
var xTurnitinIntegrationName = myintegration; // {String} a human readable string representing the type of integration being used
var xTurnitinIntegrationVersion = v1.0.2; // {String} the version of the integration platform being used
var versionId = latest; // {String} The EULA version ID (or `latest`)
var data = new TurnitinCoreApi.EulaAcceptRequest(); // {EulaAcceptRequest}
var callback = function(error, data, response) {
if (error) {
console.error(error);
} else {
console.log('API called successfully. Returned data: ' + data);
}
};
api.eulaVersionIdAcceptPost(xTurnitinIntegrationName, xTurnitinIntegrationVersion, versionId, data, callback);
All URIs are relative to https://app-us.turnitin.com/api/v1
Class | Method | HTTP request | Description |
---|---|---|---|
TurnitinCoreApi.EULAApi | eulaVersionIdAcceptPost | POST /eula/{version_id}/accept | Accepts a particular EULA version on behalf of an external user |
TurnitinCoreApi.EULAApi | eulaVersionIdAcceptUserIdGet | GET /eula/{version_id}/accept/{user_id} | Queries the acceptences of a particular EULA version on behalf of an external user |
TurnitinCoreApi.EULAApi | eulaVersionIdGet | GET /eula/{version_id} | Gets information about a particular EULA version |
TurnitinCoreApi.EULAApi | eulaVersionIdViewGet | GET /eula/{version_id}/view | Gets the text of a particular EULA version |
TurnitinCoreApi.FeaturesApi | featuresEnabledGet | GET /features-enabled | Get information about what features are allowed by the current license |
TurnitinCoreApi.GroupsApi | addGroupAttachment | POST /groups/{group_id}/attachments | Add attachment to a group. will create a group if it does not exist. |
TurnitinCoreApi.GroupsApi | deleteGroupAttachment | DELETE /groups/{group_id}/attachments/{attach_id} | Hard delete group attachment |
TurnitinCoreApi.GroupsApi | getGroup | GET /groups/{group_id} | Get group, group context and group context owners info |
TurnitinCoreApi.GroupsApi | getGroupAttachment | GET /groups/{group_id}/attachments/{attach_id} | Get group attachment |
TurnitinCoreApi.GroupsApi | getGroupAttachments | GET /groups/{group_id}/attachments | Get all attachments |
TurnitinCoreApi.GroupsApi | groupsGroupIdPut | PUT /groups/{group_id} | upsert group, group context and group context owners info |
TurnitinCoreApi.GroupsApi | updateGroupAttachment | PATCH /groups/{group_id}/attachments/{attach_id} | Patch a group attachment |
TurnitinCoreApi.GroupsApi | uploadGroupAttachment | PUT /groups/{group_id}/attachments/{attach_id}/original | Upload Submitted File |
TurnitinCoreApi.IndexApi | getIndexStatus | GET /submissions/{id}/index | Return index state of submission |
TurnitinCoreApi.IndexApi | indexSubmission | PUT /submissions/{id}/index | Index and return index state of submission |
TurnitinCoreApi.SimilarityApi | downloadSimilarityReportPdf | GET /submissions/{id}/similarity/pdf/{pdf_id} | GET download pdf |
TurnitinCoreApi.SimilarityApi | getSimilarityReportPdfStatus | GET /submissions/{id}/similarity/pdf/{pdf_id}/status | GET pdf download status |
TurnitinCoreApi.SimilarityApi | getSimilarityReportResults | GET /submissions/{id}/similarity | Get Similarity Report Results |
TurnitinCoreApi.SimilarityApi | getSimilarityReportUrl | POST /submissions/{id}/viewer-url | Returns a URL to access Cloud Viewer |
TurnitinCoreApi.SimilarityApi | requestSimilarityReport | PUT /submissions/{id}/similarity | Request Similarity Report generation |
TurnitinCoreApi.SimilarityApi | requestSimilarityReportPdf | POST /submissions/{id}/similarity/pdf | Request Pdf download and returns the Pdf Id |
TurnitinCoreApi.SubmissionApi | createSubmission | POST /submissions | Create a new Submission |
TurnitinCoreApi.SubmissionApi | deleteSubmission | DELETE /submissions/{id} | Deletes a submission and associated similarity report. |
TurnitinCoreApi.SubmissionApi | getSubmiddionDetails | GET /submissions/{id} | Get Submission Details |
TurnitinCoreApi.SubmissionApi | recoverSubmission | PUT /submissions/{id}/recover | Recover a soft deleted submission |
TurnitinCoreApi.SubmissionApi | uploadSubmittedFile | PUT /submissions/{id}/original | Upload Submitted File |
TurnitinCoreApi.WebhookApi | deleteWebhook | DELETE /webhooks/{id} | Delete Webhook endpoint |
TurnitinCoreApi.WebhookApi | getWebhook | GET /webhooks/{id} | Get Webhook endpoint info |
TurnitinCoreApi.WebhookApi | updateWebhook | PATCH /webhooks/{id} | Update Webhook endpoint info |
TurnitinCoreApi.WebhookApi | webhooksGet | GET /webhooks | List registered Webhook endpoints |
TurnitinCoreApi.WebhookApi | webhooksPost | POST /webhooks | Register a Webhook endpoint |
- TurnitinCoreApi.AddGroupAttachmentRequest
- TurnitinCoreApi.AddGroupAttachmentResponse
- TurnitinCoreApi.AggregateGroup
- TurnitinCoreApi.AnnotationsSettings
- TurnitinCoreApi.AuthorMetadataOverride
- TurnitinCoreApi.Error
- TurnitinCoreApi.Eula
- TurnitinCoreApi.EulaAcceptListItem
- TurnitinCoreApi.EulaAcceptRequest
- TurnitinCoreApi.EulaVersion
- TurnitinCoreApi.FeaturesEnabled
- TurnitinCoreApi.FeaturesGenerationSettings
- TurnitinCoreApi.FeaturesSimilarity
- TurnitinCoreApi.FeaturesSimilarityViewSettings
- TurnitinCoreApi.FeaturesTenant
- TurnitinCoreApi.FeaturesViewerModes
- TurnitinCoreApi.GenerateSimilarityPDF
- TurnitinCoreApi.GetGroupAttachments200Response
- TurnitinCoreApi.Group
- TurnitinCoreApi.GroupAttachmentResponse
- TurnitinCoreApi.GroupContext
- TurnitinCoreApi.IndexStateSettings
- TurnitinCoreApi.IndexingSettings
- TurnitinCoreApi.PDFStatusWebhookRequest
- TurnitinCoreApi.PdfStatusResponse
- TurnitinCoreApi.RateLimitError
- TurnitinCoreApi.RequestPdfResponse
- TurnitinCoreApi.Sidebar
- TurnitinCoreApi.SimilarityCompleteWebhookRequest
- TurnitinCoreApi.SimilarityGenerationSettings
- TurnitinCoreApi.SimilarityMetadata
- TurnitinCoreApi.SimilarityMetadataAllOf
- TurnitinCoreApi.SimilarityMetadataAllOfTopMatches
- TurnitinCoreApi.SimilarityPutRequest
- TurnitinCoreApi.SimilarityScoreData
- TurnitinCoreApi.SimilaritySettings
- TurnitinCoreApi.SimilaritySettingsModes
- TurnitinCoreApi.SimilaritySettingsViewSettings
- TurnitinCoreApi.SimilarityViewSettings
- TurnitinCoreApi.SimilarityViewerUrlResponse
- TurnitinCoreApi.SimilarityViewerUrlSettings
- TurnitinCoreApi.SimpleSubmissionResponse
- TurnitinCoreApi.SimpleSubmissionResponseAllOf
- TurnitinCoreApi.Submission
- TurnitinCoreApi.SubmissionAllOf
- TurnitinCoreApi.SubmissionBase
- TurnitinCoreApi.SubmissionBaseMetadata
- TurnitinCoreApi.SubmissionCompleteWebhookRequest
- TurnitinCoreApi.SubmissionCompleteWebhookRequestAllOf
- TurnitinCoreApi.SubmissionCompleteWebhookRequestAllOfMetadata
- TurnitinCoreApi.SubmissionSizeError
- TurnitinCoreApi.SuccessMessage
- TurnitinCoreApi.Users
- TurnitinCoreApi.ViewerPermissions
- TurnitinCoreApi.Webhook
- TurnitinCoreApi.WebhookAllOf
- TurnitinCoreApi.WebhookBase
- TurnitinCoreApi.WebhookPathRequest
- TurnitinCoreApi.WebhookWithSecret
- TurnitinCoreApi.WebhookWithSecretAllOf
- Type: API key
- API key parameter name: Authorization
- Location: HTTP header